1// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | llvm-objdump -d - | FileCheck  %s
2
3// Test that we avoid relaxing these instructions and instead generate versions
4// that use 8-bit immediate values.
5
6bar:
7// CHECK:      Disassembly of section imul:
8// CHECK-EMPTY:
9// CHECK-NEXT: <imul>:
10// CHECK-NEXT:   0: 66 6b db 80                   imulw $-128, %bx, %bx
11// CHECK-NEXT:   4: 66 6b 1c 25 00 00 00 00 7f    imulw $127, 0, %bx
12// CHECK-NEXT:   d: 6b db 00                      imull $0, %ebx, %ebx
13// CHECK-NEXT:  10: 6b 1c 25 00 00 00 00 01       imull $1, 0, %ebx
14// CHECK-NEXT:  18: 48 6b db ff                   imulq $-1, %rbx, %rbx
15// CHECK-NEXT:  1c: 48 6b 1c 25 00 00 00 00 2a    imulq $42, 0, %rbx
16        .section imul,"x"
17        imul $-128, %bx,  %bx
18        imul $127, bar,  %bx
19        imul $0, %ebx, %ebx
20        imul $1, bar,  %ebx
21        imul $-1, %rbx, %rbx
22        imul $42, bar,  %rbx
23
24
25// CHECK:      <and>:
26// CHECK-NEXT:   0: 66 83 e3 7f                   andw $127, %bx
27// CHECK-NEXT:   4: 66 83 24 25 00 00 00 00 00    andw $0, 0
28// CHECK-NEXT:   d: 83 e3 01                      andl $1, %ebx
29// CHECK-NEXT:  10: 83 24 25 00 00 00 00 ff       andl $-1, 0
30// CHECK-NEXT:  18: 48 83 e3 2a                   andq $42, %rbx
31// CHECK-NEXT:  1c: 48 83 24 25 00 00 00 00 80    andq $-128, 0
32        .section and,"x"
33        and  $127, %bx
34        andw $0, bar
35        and  $1, %ebx
36        andl $-1, bar
37        and  $42, %rbx
38        andq $-128, bar
39
40// CHECK:      <or>:
41// CHECK-NEXT:   0: 66 83 cb 00                   orw $0, %bx
42// CHECK-NEXT:   4: 66 83 0c 25 00 00 00 00 01    orw $1, 0
43// CHECK-NEXT:   d: 83 cb ff                      orl $-1, %ebx
44// CHECK-NEXT:  10: 83 0c 25 00 00 00 00 2a       orl $42, 0
45// CHECK-NEXT:  18: 48 83 cb 80                   orq $-128, %rbx
46// CHECK-NEXT:  1c: 48 83 0c 25 00 00 00 00 7f    orq $127, 0
47        .section or,"x"
48        or  $0, %bx
49        orw $1, bar
50        or  $-1, %ebx
51        orl $42, bar
52        or  $-128, %rbx
53        orq $127, bar
54
55// CHECK:      <xor>:
56// CHECK-NEXT:   0: 66 83 f3 01                   xorw $1, %bx
57// CHECK-NEXT:   4: 66 83 34 25 00 00 00 00 ff    xorw $-1, 0
58// CHECK-NEXT:   d: 83 f3 2a                      xorl $42, %ebx
59// CHECK-NEXT:  10: 83 34 25 00 00 00 00 80       xorl $-128, 0
60// CHECK-NEXT:  18: 48 83 f3 7f                   xorq $127, %rbx
61// CHECK-NEXT:  1c: 48 83 34 25 00 00 00 00 00    xorq $0, 0
62        .section xor,"x"
63        xor  $1, %bx
64        xorw $-1, bar
65        xor  $42, %ebx
66        xorl $-128, bar
67        xor  $127, %rbx
68        xorq $0, bar
69
70// CHECK:      <add>:
71// CHECK-NEXT:   0: 66 83 c3 ff                   addw $-1, %bx
72// CHECK-NEXT:   4: 66 83 04 25 00 00 00 00 2a    addw $42, 0
73// CHECK-NEXT:   d: 83 c3 80                      addl $-128, %ebx
74// CHECK-NEXT:  10: 83 04 25 00 00 00 00 7f       addl $127, 0
75// CHECK-NEXT:  18: 48 83 c3 00                   addq $0, %rbx
76// CHECK-NEXT:  1c: 48 83 04 25 00 00 00 00 01    addq $1, 0
77        .section add,"x"
78        add  $-1, %bx
79        addw $42, bar
80        add  $-128, %ebx
81        addl $127, bar
82        add  $0, %rbx
83        addq $1, bar
84
85// CHECK:      Disassembly of section sub:
86// CHECK-EMPTY:
87// CHECK-NEXT: <sub>:
88// CHECK-NEXT:   0: 66 83 eb 2a                   subw $42, %bx
89// CHECK-NEXT:   4: 66 83 2c 25 00 00 00 00 80    subw $-128, 0
90// CHECK-NEXT:   d: 83 eb 7f                      subl $127, %ebx
91// CHECK-NEXT:  10: 83 2c 25 00 00 00 00 00       subl $0, 0
92// CHECK-NEXT:  18: 48 83 eb 01                   subq $1, %rbx
93// CHECK-NEXT:  1c: 48 83 2c 25 00 00 00 00 ff    subq $-1, 0
94        .section sub,"x"
95        sub  $42, %bx
96        subw $-128, bar
97        sub  $127, %ebx
98        subl $0, bar
99        sub  $1, %rbx
100        subq $-1, bar
101
102// CHECK:      Disassembly of section cmp:
103// CHECK-EMPTY:
104// CHECK-NEXT: <cmp>:
105// CHECK-NEXT:   0: 66 83 fb 80                   cmpw $-128, %bx
106// CHECK-NEXT:   4: 66 83 3c 25 00 00 00 00 7f    cmpw $127, 0
107// CHECK-NEXT:   d: 83 fb 00                      cmpl $0, %ebx
108// CHECK-NEXT:  10: 83 3c 25 00 00 00 00 01       cmpl $1, 0
109// CHECK-NEXT:  18: 48 83 fb ff                   cmpq $-1, %rbx
110// CHECK-NEXT:  1c: 48 83 3c 25 00 00 00 00 2a    cmpq $42, 0
111        .section cmp,"x"
112        cmp  $-128, %bx
113        cmpw $127, bar
114        cmp  $0, %ebx
115        cmpl $1, bar
116        cmp  $-1, %rbx
117        cmpq $42, bar
118
119// CHECK:      Disassembly of section push:
120// CHECK-EMPTY:
121// CHECK-NEXT: <push>:
122// CHECK-NEXT:   0: 66 6a 80                      pushw $-128
123// CHECK-NEXT:   3: 66 6a 7f                      pushw $127
124// CHECK-NEXT:   6: 6a 80                         pushq $-128
125// CHECK-NEXT:   8: 6a 7f                         pushq $127
126        .section push,"x"
127        pushw $-128
128        pushw $127
129        push  $-128
130        push  $127
131