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