Home | History | Annotate | Download | only in ELF
      1 // RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump  --dump-section-data | FileCheck  %s
      2 
      3 // Test that we correctly relax these instructions into versions that use
      4 // 16 or 32 bit immediate values.
      5 
      6 bar:
      7 // CHECK: 'imul'
      8 // CHECK: ('_section_data', '6669db00 0066691c 25000000 00000069 db000000 00691c25 00000000 00000000 4869db00 00000048 691c2500 00000000 000000')
      9         .section imul
     10         imul $foo, %bx,  %bx
     11         imul $foo, bar,  %bx
     12         imul $foo, %ebx, %ebx
     13         imul $foo, bar,  %ebx
     14         imul $foo, %rbx, %rbx
     15         imul $foo, bar,  %rbx
     16 
     17 // CHECK: and'
     18 // CHECK:('_section_data', '6681e300 00668124 25000000 00000081 e3000000 00812425 00000000 00000000 4881e300 00000048 81242500 00000000 000000')
     19         .section and
     20         and  $foo, %bx
     21         andw $foo, bar
     22         and  $foo, %ebx
     23         andl $foo, bar
     24         and  $foo, %rbx
     25         andq $foo, bar
     26 
     27 // CHECK: 'or'
     28 // CHECK: ('_section_data', '6681cb00 0066810c 25000000 00000081 cb000000 00810c25 00000000 00000000 4881cb00 00000048 810c2500 00000000 000000')
     29         .section or
     30         or  $foo, %bx
     31         orw $foo, bar
     32         or  $foo, %ebx
     33         orl $foo, bar
     34         or  $foo, %rbx
     35         orq $foo, bar
     36 
     37 // CHECK: 'xor'
     38 // CHECK: ('_section_data', '6681f300 00668134 25000000 00000081 f3000000 00813425 00000000 00000000 4881f300 00000048 81342500 00000000 000000')
     39         .section xor
     40         xor  $foo, %bx
     41         xorw $foo, bar
     42         xor  $foo, %ebx
     43         xorl $foo, bar
     44         xor  $foo, %rbx
     45         xorq $foo, bar
     46 
     47 // CHECK: 'add'
     48 // CHECK: ('_section_data', '6681c300 00668104 25000000 00000081 c3000000 00810425 00000000 00000000 4881c300 00000048 81042500 00000000 000000')
     49         .section add
     50         add  $foo, %bx
     51         addw $foo, bar
     52         add  $foo, %ebx
     53         addl $foo, bar
     54         add  $foo, %rbx
     55         addq $foo, bar
     56 
     57 // CHECK: 'sub'
     58 // CHECK: ('_section_data', '6681eb00 0066812c 25000000 00000081 eb000000 00812c25 00000000 00000000 4881eb00 00000048 812c2500 00000000 000000')
     59         .section sub
     60         sub  $foo, %bx
     61         subw $foo, bar
     62         sub  $foo, %ebx
     63         subl $foo, bar
     64         sub  $foo, %rbx
     65         subq $foo, bar
     66 
     67 // CHECK: 'cmp'
     68 // CHECK: ('_section_data', '6681fb00 0066813c 25000000 00000081 fb000000 00813c25 00000000 00000000 4881fb00 00000048 813c2500 00000000 000000')
     69         .section cmp
     70         cmp  $foo, %bx
     71         cmpw $foo, bar
     72         cmp  $foo, %ebx
     73         cmpl $foo, bar
     74         cmp  $foo, %rbx
     75         cmpq $foo, bar
     76