mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-09 17:43:57 +00:00
c9de3b4d26
Summary: As for x86_64, the default image base for AArch64 and i386 should be aligned to a superpage appropriate for the architecture. On AArch64, this is 2 MiB, on i386 it is 4 MiB. Reviewers: emaste, grimar, javed.absar, espindola, ruiu, peter.smith, srhines, rprichard Reviewed By: ruiu, peter.smith Subscribers: jfb, markj, arichardson, krytarowski, kristof.beyls, llvm-commits Differential Revision: https://reviews.llvm.org/D50297 llvm-svn: 342746
46 lines
1.6 KiB
ArmAsm
46 lines
1.6 KiB
ArmAsm
// REQUIRES: aarch64
|
|
// RUN: llvm-mc -filetype=obj -triple=aarch64-none-linux %s -o %t
|
|
// RUN: not ld.lld %t -o /dev/null 2>&1 | FileCheck %s
|
|
|
|
// Test derived from a typical ODR violation where a global is declared
|
|
// extern int but defined as a half or byte sized type.
|
|
.section .text
|
|
.globl _start
|
|
.type _start, %function
|
|
// Access foo2 as if it were an aligned 32-bit int, expect an error as
|
|
// foo is not aligned
|
|
|
|
_start:
|
|
ldrb w2, [x0, #:lo12:foo1] // Ok as no shift involved
|
|
ldrh w2, [x0, #:lo12:foo1] // Error foo1 is not 2-byte aligned
|
|
ldrh w2, [x0, #:lo12:foo2] // Ok as foo2 is 2-byte aligned
|
|
ldr w2, [x0, #:lo12:foo2] // Error foo2 is not 4-byte aligned
|
|
ldr w2, [x0, #:lo12:foo4] // Ok as foo4 is 4-byte aligned
|
|
ldr x3, [x0, #:lo12:foo4] // Error foo4 is not 8-byte aligned
|
|
ldr x3, [x0, #:lo12:foo8] // Ok as foo8 is 8-byte aligned
|
|
ldr q0, [x0, #:lo12:foo8] // Error foo8 is not 16-byte aligned
|
|
ldr q0, [x0, #:lo12:foo16] // Ok as foo16 is 16-byte aligned
|
|
|
|
.section .data.bool, "a", @nobits
|
|
.balign 16
|
|
.globl foo16
|
|
.globl foo1
|
|
.globl foo2
|
|
.globl foo4
|
|
.globl foo8
|
|
foo16:
|
|
.space 1
|
|
foo1:
|
|
.space 1
|
|
foo2:
|
|
.space 2
|
|
foo4:
|
|
.space 4
|
|
foo8:
|
|
.space 8
|
|
|
|
// CHECK: improper alignment for relocation R_AARCH64_LDST16_ABS_LO12_NC: 0x220001 is not aligned to 2 bytes
|
|
// CHECK-NEXT: improper alignment for relocation R_AARCH64_LDST32_ABS_LO12_NC: 0x220002 is not aligned to 4 bytes
|
|
// CHECK-NEXT: improper alignment for relocation R_AARCH64_LDST64_ABS_LO12_NC: 0x220004 is not aligned to 8 bytes
|
|
// CHECK-NEXT: improper alignment for relocation R_AARCH64_LDST128_ABS_LO12_NC: 0x220008 is not aligned to 16 bytes
|