1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 11:13:28 +01:00
llvm-mirror/test/CodeGen/AArch64/framelayout-offset-immediate-change.mir
Shoaib Meenai ebf24ce8e1 [AArch64] Fix offset calculation
r374772 changed Offset to be an int64_t but left NewOffset as an int.
Scale is unsigned, so in the calculation `Offset - NewOffset * Scale`,
`NewOffset * Scale` was promoted to unsigned and was then zero-extended
to 64 bits, leading to an incorrect computation which manifested as an
out-of-memory when building the Swift standard library for Android
aarch64. Promote NewOffset to int64_t to fix this, and promote
EmittableOffset as well, since its one user passes it to a function
which takes an int64_t anyway.

Test case based on a suggestion by Sander de Smalen!

Differential Revision: https://reviews.llvm.org/D69018

llvm-svn: 375043
2019-10-16 21:41:05 +00:00

18 lines
522 B
YAML

# RUN: llc -mtriple=aarch64-none-linux-gnu -run-pass=prologepilog %s -o - | FileCheck %s
---
name: framelayout_offset_immediate_change
tracksRegLiveness: true
fixedStack:
- { id: 0, offset: 0, size: 1}
body: |
bb.0:
$x0 = LDURXi %fixed-stack.0, -264
RET_ReallyLR
...
# CHECK: name: framelayout_offset_immediate_change
# CHECK: body: |
# CHECK-NEXT: bb.0:
# CHECK-NEXT: $x8 = SUBXri $sp, 8, 0
# CHECK-NEXT: $x0 = LDURXi killed $x8, -256
# CHECK-NEXT: RET_ReallyLR