mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
Convert MC tests to .s so codegen changes won't break them.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122786 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e508dd4c75
commit
bbdcd44361
78
test/MC/ELF/basic-elf-32.s
Normal file
78
test/MC/ELF/basic-elf-32.s
Normal file
@ -0,0 +1,78 @@
|
||||
// RUN: llvm-mc -filetype=obj -triple i686-pc-linux-gnu %s -o - | elf-dump | FileCheck %s
|
||||
|
||||
.text
|
||||
.globl main
|
||||
.align 16, 0x90
|
||||
.type main,@function
|
||||
main: # @main
|
||||
# BB#0:
|
||||
subl $4, %esp
|
||||
movl $.L.str1, (%esp)
|
||||
calll puts
|
||||
movl $.L.str2, (%esp)
|
||||
calll puts
|
||||
xorl %eax, %eax
|
||||
addl $4, %esp
|
||||
ret
|
||||
.Ltmp0:
|
||||
.size main, .Ltmp0-main
|
||||
|
||||
.type .L.str1,@object # @.str1
|
||||
.section .rodata.str1.1,"aMS",@progbits,1
|
||||
.L.str1:
|
||||
.asciz "Hello"
|
||||
.size .L.str1, 6
|
||||
|
||||
.type .L.str2,@object # @.str2
|
||||
.L.str2:
|
||||
.asciz "World!"
|
||||
.size .L.str2, 7
|
||||
|
||||
.section .note.GNU-stack,"",@progbits
|
||||
|
||||
// CHECK: ('e_indent[EI_CLASS]', 0x00000001)
|
||||
// CHECK: ('e_indent[EI_DATA]', 0x00000001)
|
||||
// CHECK: ('e_indent[EI_VERSION]', 0x00000001)
|
||||
// CHECK: ('_sections', [
|
||||
// CHECK: # Section 0
|
||||
// CHECK: (('sh_name', 0x00000000) # ''
|
||||
|
||||
// CHECK: # '.text'
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: # 'main'
|
||||
// CHECK: ('st_bind', 0x00000001)
|
||||
// CHECK-NEXT: ('st_type', 0x00000002)
|
||||
|
||||
// CHECK: # 'puts'
|
||||
// CHECK: ('st_bind', 0x00000001)
|
||||
// CHECK-NEXT: ('st_type', 0x00000000)
|
||||
|
||||
// CHECK: # '.rel.text'
|
||||
|
||||
// CHECK: ('_relocations', [
|
||||
// CHECK: # Relocation 0x00000000
|
||||
// CHECK: (('r_offset', 0x00000006)
|
||||
// CHECK: ('r_type', 0x00000001)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000001
|
||||
// CHECK: (('r_offset', 0x0000000b)
|
||||
// CHECK: ('r_type', 0x00000002)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000002
|
||||
// CHECK: (('r_offset', 0x00000012)
|
||||
// CHECK: ('r_type', 0x00000001)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000003
|
||||
// CHECK: (('r_offset', 0x00000017)
|
||||
// CHECK: ('r_type', 0x00000002)
|
||||
// CHECK: ),
|
||||
// CHECK: ])
|
82
test/MC/ELF/basic-elf-64.s
Normal file
82
test/MC/ELF/basic-elf-64.s
Normal file
@ -0,0 +1,82 @@
|
||||
// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o - | elf-dump | FileCheck %s
|
||||
|
||||
.text
|
||||
.globl main
|
||||
.align 16, 0x90
|
||||
.type main,@function
|
||||
main: # @main
|
||||
# BB#0:
|
||||
subq $8, %rsp
|
||||
movl $.L.str1, %edi
|
||||
callq puts
|
||||
movl $.L.str2, %edi
|
||||
callq puts
|
||||
xorl %eax, %eax
|
||||
addq $8, %rsp
|
||||
ret
|
||||
.Ltmp0:
|
||||
.size main, .Ltmp0-main
|
||||
|
||||
.type .L.str1,@object # @.str1
|
||||
.section .rodata.str1.1,"aMS",@progbits,1
|
||||
.L.str1:
|
||||
.asciz "Hello"
|
||||
.size .L.str1, 6
|
||||
|
||||
.type .L.str2,@object # @.str2
|
||||
.L.str2:
|
||||
.asciz "World!"
|
||||
.size .L.str2, 7
|
||||
|
||||
.section .note.GNU-stack,"",@progbits
|
||||
|
||||
// CHECK: ('e_indent[EI_CLASS]', 0x00000002)
|
||||
// CHECK: ('e_indent[EI_DATA]', 0x00000001)
|
||||
// CHECK: ('e_indent[EI_VERSION]', 0x00000001)
|
||||
// CHECK: ('_sections', [
|
||||
// CHECK: # Section 0
|
||||
// CHECK: (('sh_name', 0x00000000) # ''
|
||||
|
||||
// CHECK: # '.text'
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: ('st_bind', 0x00000000)
|
||||
// CHECK: ('st_type', 0x00000003)
|
||||
|
||||
// CHECK: # 'main'
|
||||
// CHECK-NEXT: ('st_bind', 0x00000001)
|
||||
// CHECK-NEXT: ('st_type', 0x00000002)
|
||||
|
||||
// CHECK: # 'puts'
|
||||
// CHECK-NEXT: ('st_bind', 0x00000001)
|
||||
// CHECK-NEXT: ('st_type', 0x00000000)
|
||||
|
||||
// CHECK: # '.rela.text'
|
||||
|
||||
// CHECK: ('_relocations', [
|
||||
// CHECK: # Relocation 0x00000000
|
||||
// CHECK: (('r_offset', 0x00000005)
|
||||
// CHECK: ('r_type', 0x0000000a)
|
||||
// CHECK: ('r_addend', 0x00000000)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000001
|
||||
// CHECK: (('r_offset', 0x0000000a)
|
||||
// CHECK: ('r_type', 0x00000002)
|
||||
// CHECK: ('r_addend', 0xfffffffc)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000002
|
||||
// CHECK: (('r_offset', 0x0000000f)
|
||||
// CHECK: ('r_type', 0x0000000a)
|
||||
// CHECK: ('r_addend', 0x00000006)
|
||||
// CHECK: ),
|
||||
// CHECK: # Relocation 0x00000003
|
||||
// CHECK: (('r_offset', 0x00000014)
|
||||
// CHECK: ('r_type', 0x00000002)
|
||||
// CHECK: ('r_addend', 0xfffffffc)
|
||||
// CHECK: ),
|
||||
// CHECK: ])
|
@ -1,111 +0,0 @@
|
||||
; RUN: llc -filetype=obj -mtriple i686-pc-linux-gnu %s -o - | elf-dump | FileCheck -check-prefix=32 %s
|
||||
; RUN: llc -filetype=obj -mtriple x86_64-pc-linux-gnu %s -o - | elf-dump | FileCheck -check-prefix=64 %s
|
||||
|
||||
@.str1 = private constant [6 x i8] c"Hello\00"
|
||||
@.str2 = private constant [7 x i8] c"World!\00"
|
||||
|
||||
define i32 @main() nounwind {
|
||||
%1 = call i32 @puts(i8* getelementptr inbounds ([6 x i8]* @.str1, i32 0, i32 0))
|
||||
%2 = call i32 @puts(i8* getelementptr inbounds ([7 x i8]* @.str2, i32 0, i32 0))
|
||||
ret i32 0
|
||||
}
|
||||
|
||||
declare i32 @puts(i8* nocapture) nounwind
|
||||
|
||||
; 32: ('e_indent[EI_CLASS]', 0x00000001)
|
||||
; 32: ('e_indent[EI_DATA]', 0x00000001)
|
||||
; 32: ('e_indent[EI_VERSION]', 0x00000001)
|
||||
; 32: ('_sections', [
|
||||
; 32: # Section 0
|
||||
; 32: (('sh_name', 0x00000000) # ''
|
||||
|
||||
; 32: # '.text'
|
||||
|
||||
; 32: ('st_bind', 0x00000000)
|
||||
; 32: ('st_type', 0x00000003)
|
||||
|
||||
; 32: ('st_bind', 0x00000000)
|
||||
; 32: ('st_type', 0x00000003)
|
||||
|
||||
; 32: ('st_bind', 0x00000000)
|
||||
; 32: ('st_type', 0x00000003)
|
||||
|
||||
; 32: # 'main'
|
||||
; 32: ('st_bind', 0x00000001)
|
||||
; 32-NEXT: ('st_type', 0x00000002)
|
||||
|
||||
; 32: # 'puts'
|
||||
; 32: ('st_bind', 0x00000001)
|
||||
; 32-NEXT: ('st_type', 0x00000000)
|
||||
|
||||
; 32: # '.rel.text'
|
||||
|
||||
; 32: ('_relocations', [
|
||||
; 32: # Relocation 0x00000000
|
||||
; 32: (('r_offset', 0x00000006)
|
||||
; 32: ('r_type', 0x00000001)
|
||||
; 32: ),
|
||||
; 32: # Relocation 0x00000001
|
||||
; 32: (('r_offset', 0x0000000b)
|
||||
; 32: ('r_type', 0x00000002)
|
||||
; 32: ),
|
||||
; 32: # Relocation 0x00000002
|
||||
; 32: (('r_offset', 0x00000012)
|
||||
; 32: ('r_type', 0x00000001)
|
||||
; 32: ),
|
||||
; 32: # Relocation 0x00000003
|
||||
; 32: (('r_offset', 0x00000017)
|
||||
; 32: ('r_type', 0x00000002)
|
||||
; 32: ),
|
||||
; 32: ])
|
||||
|
||||
; 64: ('e_indent[EI_CLASS]', 0x00000002)
|
||||
; 64: ('e_indent[EI_DATA]', 0x00000001)
|
||||
; 64: ('e_indent[EI_VERSION]', 0x00000001)
|
||||
; 64: ('_sections', [
|
||||
; 64: # Section 0
|
||||
; 64: (('sh_name', 0x00000000) # ''
|
||||
|
||||
; 64: # '.text'
|
||||
|
||||
; 64: ('st_bind', 0x00000000)
|
||||
; 64: ('st_type', 0x00000003)
|
||||
|
||||
; 64: ('st_bind', 0x00000000)
|
||||
; 64: ('st_type', 0x00000003)
|
||||
|
||||
; 64: ('st_bind', 0x00000000)
|
||||
; 64: ('st_type', 0x00000003)
|
||||
|
||||
; 64: # 'main'
|
||||
; 64-NEXT: ('st_bind', 0x00000001)
|
||||
; 64-NEXT: ('st_type', 0x00000002)
|
||||
|
||||
; 64: # 'puts'
|
||||
; 64-NEXT: ('st_bind', 0x00000001)
|
||||
; 64-NEXT: ('st_type', 0x00000000)
|
||||
|
||||
; 64: # '.rela.text'
|
||||
|
||||
; 64: ('_relocations', [
|
||||
; 64: # Relocation 0x00000000
|
||||
; 64: (('r_offset', 0x00000005)
|
||||
; 64: ('r_type', 0x0000000a)
|
||||
; 64: ('r_addend', 0x00000000)
|
||||
; 64: ),
|
||||
; 64: # Relocation 0x00000001
|
||||
; 64: (('r_offset', 0x0000000a)
|
||||
; 64: ('r_type', 0x00000002)
|
||||
; 64: ('r_addend', 0xfffffffc)
|
||||
; 64: ),
|
||||
; 64: # Relocation 0x00000002
|
||||
; 64: (('r_offset', 0x0000000f)
|
||||
; 64: ('r_type', 0x0000000a)
|
||||
; 64: ('r_addend', 0x00000006)
|
||||
; 64: ),
|
||||
; 64: # Relocation 0x00000003
|
||||
; 64: (('r_offset', 0x00000014)
|
||||
; 64: ('r_type', 0x00000002)
|
||||
; 64: ('r_addend', 0xfffffffc)
|
||||
; 64: ),
|
||||
; 64: ])
|
@ -1,16 +0,0 @@
|
||||
; RUN: llc -filetype=obj -mtriple i686-pc-linux-gnu %s -o - | elf-dump | FileCheck %s
|
||||
|
||||
define i32 @f() nounwind optsize ssp {
|
||||
entry:
|
||||
%call = tail call i32 inttoptr (i64 42 to i32 ()*)() nounwind optsize
|
||||
%add = add nsw i32 %call, 1
|
||||
ret i32 %add
|
||||
}
|
||||
|
||||
; CHECK: ('_relocations', [
|
||||
; CHECK-NEXT: # Relocation 0x00000000
|
||||
; CHECK-NEXT: (('r_offset', 0x00000004)
|
||||
; CHECK-NEXT: ('r_sym', 0x00000000)
|
||||
; CHECK-NEXT: ('r_type', 0x00000002)
|
||||
; CHECK-NEXT: ),
|
||||
; CHECK-NEXT: ])
|
24
test/MC/ELF/call-abs.s
Normal file
24
test/MC/ELF/call-abs.s
Normal file
@ -0,0 +1,24 @@
|
||||
// RUN: llvm-mc -filetype=obj -triple i686-pc-linux-gnu %s -o - | elf-dump | FileCheck %s
|
||||
|
||||
.text
|
||||
.globl f
|
||||
.type f,@function
|
||||
f: # @f
|
||||
# BB#0: # %entry
|
||||
subl $4, %esp
|
||||
calll 42
|
||||
incl %eax
|
||||
addl $4, %esp
|
||||
ret
|
||||
.Ltmp0:
|
||||
.size f, .Ltmp0-f
|
||||
|
||||
.section .note.GNU-stack,"",@progbits
|
||||
|
||||
// CHECK: ('_relocations', [
|
||||
// CHECK-NEXT: # Relocation 0x00000000
|
||||
// CHECK-NEXT: (('r_offset', 0x00000004)
|
||||
// CHECK-NEXT: ('r_sym', 0x00000000)
|
||||
// CHECK-NEXT: ('r_type', 0x00000002)
|
||||
// CHECK-NEXT: ),
|
||||
// CHECK-NEXT: ])
|
Loading…
Reference in New Issue
Block a user