1f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | llvm-readobj -s -sd | FileCheck  %s
2e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
3e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola// Test that we correctly relax these instructions into versions that use
4e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola// 16 or 32 bit immediate values.
5e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
6e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindolabar:
7f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: imul
8f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
9f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6669DB00 0066691C 25000000 00000069
10f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: DB000000 00691C25 00000000 00000000
11f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4869DB00 00000048 691C2500 00000000
12f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
13f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
14e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section imul
15e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, %bx,  %bx
16e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, bar,  %bx
17e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, %ebx, %ebx
18e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, bar,  %ebx
19e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, %rbx, %rbx
20e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        imul $foo, bar,  %rbx
21e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
22f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck
23f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: and
24f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
25f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6681E300 00668124 25000000 00000081
26f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: E3000000 00812425 00000000 00000000
27f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4881E300 00000048 81242500 00000000
28f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
29f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
30e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section and
31e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        and  $foo, %bx
32e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        andw $foo, bar
33e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        and  $foo, %ebx
34e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        andl $foo, bar
35e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        and  $foo, %rbx
36e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        andq $foo, bar
37e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
38f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: or
39f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
40f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6681CB00 0066810C 25000000 00000081
41f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: CB000000 00810C25 00000000 00000000
42f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4881CB00 00000048 810C2500 00000000
43f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
44f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
45e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section or
46e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        or  $foo, %bx
47e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        orw $foo, bar
48e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        or  $foo, %ebx
49e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        orl $foo, bar
50e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        or  $foo, %rbx
51e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        orq $foo, bar
52e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
53f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: xor
54f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
55f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6681F300 00668134 25000000 00000081
56f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: F3000000 00813425 00000000 00000000
57f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4881F300 00000048 81342500 00000000
58f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
59f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
60e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section xor
61e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xor  $foo, %bx
62e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xorw $foo, bar
63e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xor  $foo, %ebx
64e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xorl $foo, bar
65e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xor  $foo, %rbx
66e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        xorq $foo, bar
67e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
68f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: add
69f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
70f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6681C300 00668104 25000000 00000081
71f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: C3000000 00810425 00000000 00000000
72f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4881C300 00000048 81042500 00000000
73f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
74f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
75e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section add
76e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        add  $foo, %bx
77e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        addw $foo, bar
78e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        add  $foo, %ebx
79e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        addl $foo, bar
80e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        add  $foo, %rbx
81e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        addq $foo, bar
82e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
83f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: sub
84f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
85f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   000: 6681EB00 0066812C 25000000 00000081
86f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   010: EB000000 00812C25 00000000 00000000
87f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   020: 4881EB00 00000048 812C2500 00000000
88f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   030: 000000
89f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
90e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section sub
91e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        sub  $foo, %bx
92e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        subw $foo, bar
93e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        sub  $foo, %ebx
94e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        subl $foo, bar
95e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        sub  $foo, %rbx
96e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        subq $foo, bar
97e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola
98f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      Name: cmp
99f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK:      SectionData (
100f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0000: 6681FB00 0066813C 25000000 00000081
101f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0010: FB000000 00813C25 00000000 00000000
102f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0020: 4881FB00 00000048 813C2500 00000000
103f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT:   0030: 000000
104f89da7210b09a0a0f7c9ee216cd54dca03c6b64aNico Rieck// CHECK-NEXT: )
105e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        .section cmp
106e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmp  $foo, %bx
107e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmpw $foo, bar
108e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmp  $foo, %ebx
109e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmpl $foo, bar
110e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmp  $foo, %rbx
111e4f506ff4ba8ddc70b6b7c77feceabb0b53b6ccfRafael Espindola        cmpq $foo, bar
112