forked from OSchip/llvm-project
86 lines
2.4 KiB
ArmAsm
86 lines
2.4 KiB
ArmAsm
// RUN: llvm-mc -triple i686-windows -filetype obj -o %t.obj %s
|
|
// RUN: llvm-rtdyld -triple i686-windows -dummy-extern _printf=0x7ffffffd -dummy-extern _OutputDebugStringA@4=0x7ffffffe -dummy-extern _ExitProcess@4=0x7fffffff -verify -check=%s %t.obj
|
|
|
|
.text
|
|
|
|
.def _main
|
|
.scl 2
|
|
.type 32
|
|
.endef
|
|
.global _main
|
|
_main:
|
|
rel1:
|
|
call _function // IMAGE_REL_I386_REL32
|
|
# rtdyld-check: decode_operand(rel1, 0) = (_function-_main-4-1)
|
|
xorl %eax, %eax
|
|
rel12:
|
|
jmp _printf
|
|
# rtdyld-check: decode_operand(rel12, 0)[31:0] = (_printf-_main-4-8)
|
|
|
|
.def _function
|
|
.scl 2
|
|
.type 32
|
|
.endef
|
|
_function:
|
|
rel2:
|
|
pushl string
|
|
rel3:
|
|
calll *__imp__OutputDebugStringA // IMAGE_REL_I386_DIR32
|
|
# rtdyld-check: decode_operand(rel3, 3) = __imp__OutputDebugStringA
|
|
addl $4, %esp
|
|
pushl $0
|
|
rel4:
|
|
calll *__imp__ExitProcess // IMAGE_REL_I386_DIR32
|
|
# rtdyld-check: decode_operand(rel4, 3) = __imp__ExitProcess
|
|
addl $4, %esp
|
|
retl
|
|
|
|
.data
|
|
|
|
.global __imp__OutputDebugStringA
|
|
.align 4
|
|
__imp__OutputDebugStringA:
|
|
.long "_OutputDebugStringA@4" // IMAGE_REL_I386_DIR32
|
|
# rtdyld-check: *{4}__imp__OutputDebugStringA = 0x7ffffffe
|
|
|
|
.global __imp__ExitProcess
|
|
.align 4
|
|
__imp__ExitProcess:
|
|
.long "_ExitProcess@4" // IMAGE_REL_I386_DIR32
|
|
# rtdyld-check: *{4}__imp__ExitProcess = 0x7fffffff
|
|
|
|
.global relocations
|
|
relocations:
|
|
rel5:
|
|
.long _function@imgrel // IMAGE_REL_I386_DIR32NB
|
|
# rtdyld-check: *{4}rel5 = _function - section_addr(COFF_i386.s.tmp.obj, .text)
|
|
rel6:
|
|
# rtdyld-check: *{2}rel6 = 1
|
|
.secidx __imp__OutputDebugStringA // IMAGE_REL_I386_SECTION
|
|
rel7:
|
|
# rtdyld-check: *{4}rel7 = string - section_addr(COFF_i386.s.tmp.obj, .data)
|
|
.secrel32 string // IMAGE_REL_I386_SECREL
|
|
|
|
# Test that addends work.
|
|
rel8:
|
|
# rtdyld-check: *{4}rel8 = string
|
|
.long string // IMAGE_REL_I386_DIR32
|
|
rel9:
|
|
# rtdyld-check: *{4}rel9 = string+1
|
|
.long string+1 // IMAGE_REL_I386_DIR32
|
|
rel10:
|
|
# rtdyld-check: *{4}rel10 = string - section_addr(COFF_i386.s.tmp.obj, .text) + 1
|
|
.long string@imgrel+1 // IMAGE_REL_I386_DIR32NB
|
|
rel11:
|
|
# rtdyld-check: *{4}rel11 = string - section_addr(COFF_i386.s.tmp.obj, .data) + 1
|
|
.long string@SECREL32+1 // IMAGE_REL_I386_SECREL
|
|
|
|
# We explicitly add padding to put string outside of the 16bit address space
|
|
# (absolute and as an offset from .data), so that relocations involving
|
|
# 32bit addresses / offsets are not accidentally truncated to 16 bits.
|
|
.space 65536
|
|
.global string
|
|
.align 1
|
|
string:
|
|
.asciz "Hello World!\n"
|