mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
72062f5744
This patch adds support for AArch64 (ARM's 64-bit architecture) to LLVM in the "experimental" category. Currently, it won't be built unless requested explicitly. This initial commit should have support for: + Assembly of all scalar (i.e. non-NEON, non-Crypto) instructions (except the late addition CRC instructions). + CodeGen features required for C++03 and C99. + Compilation for the "small" memory model: code+static data < 4GB. + Absolute and position-independent code. + GNU-style (i.e. "__thread") TLS. + Debugging information. The principal omission, currently, is performance tuning. This patch excludes the NEON support also reviewed due to an outbreak of batshit insanity in our legal department. That will be committed soon bringing the changes to precisely what has been approved. Further reviews would be gratefully received. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@174054 91177308-0d34-0410-b5e6-96231b3b80d8
18 lines
503 B
Plaintext
18 lines
503 B
Plaintext
# RUN: llvm-mc -triple=aarch64 -disassemble < %s 2>&1 | FileCheck %s
|
|
|
|
# None of these instructions should be classified as unpredictable:
|
|
|
|
# CHECK-NOT: potentially undefined instruction encoding
|
|
|
|
# Stores from duplicated registers should be fine.
|
|
0xe3 0x0f 0x80 0xa9
|
|
# CHECK: stp x3, x3, [sp, #0]!
|
|
|
|
# d5 != x5 so "ldp d5, d6, [x5, #24]!" is fine.
|
|
0xa5 0x98 0xc1 0x6d
|
|
# CHECK: ldp d5, d6, [x5, #24]!
|
|
|
|
# xzr != sp so "stp xzr, xzr, [sp, #8]!" is fine.
|
|
0xff 0xff 0x80 0xa9
|
|
# CHECK: stp xzr, xzr, [sp, #8]!
|