mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
5de5d4b6d0
movw r0, :lower16:(L_foo$non_lazy_ptr-(LPC0_0+4)) movt r0, :upper16:(L_foo$non_lazy_ptr-(LPC0_0+4)) LPC0_0: add r0, pc, r0 It's not yet enabled by default as some tests are failing. I suspect bugs in down stream tools. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123619 91177308-0d34-0410-b5e6-96231b3b80d8
36 lines
1.1 KiB
LLVM
36 lines
1.1 KiB
LLVM
; RUN: llc %s -mtriple=armv7-linux-gnueabi -filetype=obj -o - | \
|
|
; RUN: elf-dump --dump-section-data | FileCheck -check-prefix=OBJ %s
|
|
; RUN: llc %s -mtriple=armv7-linux-gnueabi -o - | \
|
|
; RUN: FileCheck -check-prefix=ASM %s
|
|
|
|
|
|
@dummy = internal global i32 666
|
|
@array00 = internal global [20 x i32] zeroinitializer
|
|
@sum = internal global i32 55
|
|
@STRIDE = internal global i32 8
|
|
|
|
; ASM: .type array00,%object @ @array00
|
|
; ASM-NEXT: .lcomm array00,80 @ @array00
|
|
; ASM-NEXT: .type _MergedGlobals,%object @ @_MergedGlobals
|
|
|
|
|
|
|
|
; OBJ: Section 0x00000003
|
|
; OBJ-NEXT: '.bss'
|
|
|
|
; OBJ: 'array00'
|
|
; OBJ-NEXT: 'st_value', 0x00000000
|
|
; OBJ-NEXT: 'st_size', 0x00000050
|
|
; OBJ-NEXT: 'st_bind', 0x00000000
|
|
; OBJ-NEXT: 'st_type', 0x00000001
|
|
; OBJ-NEXT: 'st_other', 0x00000000
|
|
; OBJ-NEXT: 'st_shndx', 0x00000003
|
|
|
|
define i32 @main(i32 %argc) nounwind {
|
|
%1 = load i32* @sum, align 4
|
|
%2 = getelementptr [20 x i32]* @array00, i32 0, i32 %argc
|
|
%3 = load i32* %2, align 4
|
|
%4 = add i32 %1, %3
|
|
ret i32 %4;
|
|
}
|