mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
f89da7210b
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@179361 91177308-0d34-0410-b5e6-96231b3b80d8
112 lines
3.2 KiB
ArmAsm
112 lines
3.2 KiB
ArmAsm
// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | llvm-readobj -s -sd | FileCheck %s
|
|
|
|
// Test that we correctly relax these instructions into versions that use
|
|
// 16 or 32 bit immediate values.
|
|
|
|
bar:
|
|
// CHECK: Name: imul
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6669DB00 0066691C 25000000 00000069
|
|
// CHECK-NEXT: 0010: DB000000 00691C25 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4869DB00 00000048 691C2500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section imul
|
|
imul $foo, %bx, %bx
|
|
imul $foo, bar, %bx
|
|
imul $foo, %ebx, %ebx
|
|
imul $foo, bar, %ebx
|
|
imul $foo, %rbx, %rbx
|
|
imul $foo, bar, %rbx
|
|
|
|
|
|
// CHECK: Name: and
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6681E300 00668124 25000000 00000081
|
|
// CHECK-NEXT: 0010: E3000000 00812425 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4881E300 00000048 81242500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section and
|
|
and $foo, %bx
|
|
andw $foo, bar
|
|
and $foo, %ebx
|
|
andl $foo, bar
|
|
and $foo, %rbx
|
|
andq $foo, bar
|
|
|
|
// CHECK: Name: or
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6681CB00 0066810C 25000000 00000081
|
|
// CHECK-NEXT: 0010: CB000000 00810C25 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4881CB00 00000048 810C2500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section or
|
|
or $foo, %bx
|
|
orw $foo, bar
|
|
or $foo, %ebx
|
|
orl $foo, bar
|
|
or $foo, %rbx
|
|
orq $foo, bar
|
|
|
|
// CHECK: Name: xor
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6681F300 00668134 25000000 00000081
|
|
// CHECK-NEXT: 0010: F3000000 00813425 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4881F300 00000048 81342500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section xor
|
|
xor $foo, %bx
|
|
xorw $foo, bar
|
|
xor $foo, %ebx
|
|
xorl $foo, bar
|
|
xor $foo, %rbx
|
|
xorq $foo, bar
|
|
|
|
// CHECK: Name: add
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6681C300 00668104 25000000 00000081
|
|
// CHECK-NEXT: 0010: C3000000 00810425 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4881C300 00000048 81042500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section add
|
|
add $foo, %bx
|
|
addw $foo, bar
|
|
add $foo, %ebx
|
|
addl $foo, bar
|
|
add $foo, %rbx
|
|
addq $foo, bar
|
|
|
|
// CHECK: Name: sub
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 000: 6681EB00 0066812C 25000000 00000081
|
|
// CHECK-NEXT: 010: EB000000 00812C25 00000000 00000000
|
|
// CHECK-NEXT: 020: 4881EB00 00000048 812C2500 00000000
|
|
// CHECK-NEXT: 030: 000000
|
|
// CHECK-NEXT: )
|
|
.section sub
|
|
sub $foo, %bx
|
|
subw $foo, bar
|
|
sub $foo, %ebx
|
|
subl $foo, bar
|
|
sub $foo, %rbx
|
|
subq $foo, bar
|
|
|
|
// CHECK: Name: cmp
|
|
// CHECK: SectionData (
|
|
// CHECK-NEXT: 0000: 6681FB00 0066813C 25000000 00000081
|
|
// CHECK-NEXT: 0010: FB000000 00813C25 00000000 00000000
|
|
// CHECK-NEXT: 0020: 4881FB00 00000048 813C2500 00000000
|
|
// CHECK-NEXT: 0030: 000000
|
|
// CHECK-NEXT: )
|
|
.section cmp
|
|
cmp $foo, %bx
|
|
cmpw $foo, bar
|
|
cmp $foo, %ebx
|
|
cmpl $foo, bar
|
|
cmp $foo, %rbx
|
|
cmpq $foo, bar
|