llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT--> @llvm/pr-subscribers-backend-aarch64 Author: None (llvmbot) <details> <summary>Changes</summary> Backport 53283dc Requested by: @<!-- -->kovdan01 --- Patch is 49.04 KiB, truncated to 20.00 KiB below, full version: https://github.com/llvm/llvm-project/pull/101043.diff 3 Files Affected: - (modified) llvm/test/CodeGen/AArch64/ptrauth-fpac.ll (+51-49) - (modified) llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign-with-blend.ll (+80-59) - (modified) llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign.ll (+110-95) ``````````diff diff --git a/llvm/test/CodeGen/AArch64/ptrauth-fpac.ll b/llvm/test/CodeGen/AArch64/ptrauth-fpac.ll index 6afe1a93d986e..d5340dcebad57 100644 --- a/llvm/test/CodeGen/AArch64/ptrauth-fpac.ll +++ b/llvm/test/CodeGen/AArch64/ptrauth-fpac.ll @@ -1,12 +1,14 @@ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py -; RUN: llc < %s -mtriple arm64e-apple-darwin -verify-machineinstrs | FileCheck %s --check-prefixes=ALL,NOFPAC -; RUN: llc < %s -mtriple arm64e-apple-darwin -mattr=+fpac -verify-machineinstrs | FileCheck %s --check-prefixes=ALL,FPAC +; RUN: llc < %s -mtriple arm64e-apple-darwin -verify-machineinstrs | FileCheck %s -DL="L" --check-prefixes=ALL,NOFPAC +; RUN: llc < %s -mtriple arm64e-apple-darwin -mattr=+fpac -verify-machineinstrs | FileCheck %s -DL="L" --check-prefixes=ALL,FPAC +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -verify-machineinstrs | FileCheck %s -DL=".L" --check-prefixes=ALL,NOFPAC +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -mattr=+fpac -verify-machineinstrs | FileCheck %s -DL=".L" --check-prefixes=ALL,FPAC target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128" define i64 @test_auth_ia(i64 %arg, i64 %arg1) { ; ALL-LABEL: test_auth_ia: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autia x16, x1 ; ALL-NEXT: mov x0, x16 @@ -17,7 +19,7 @@ define i64 @test_auth_ia(i64 %arg, i64 %arg1) { define i64 @test_auth_ia_zero(i64 %arg) { ; ALL-LABEL: test_auth_ia_zero: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autiza x16 ; ALL-NEXT: mov x0, x16 @@ -28,7 +30,7 @@ define i64 @test_auth_ia_zero(i64 %arg) { define i64 @test_auth_ib(i64 %arg, i64 %arg1) { ; ALL-LABEL: test_auth_ib: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autib x16, x1 ; ALL-NEXT: mov x0, x16 @@ -39,7 +41,7 @@ define i64 @test_auth_ib(i64 %arg, i64 %arg1) { define i64 @test_auth_ib_zero(i64 %arg) { ; ALL-LABEL: test_auth_ib_zero: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autizb x16 ; ALL-NEXT: mov x0, x16 @@ -50,7 +52,7 @@ define i64 @test_auth_ib_zero(i64 %arg) { define i64 @test_auth_da(i64 %arg, i64 %arg1) { ; ALL-LABEL: test_auth_da: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autda x16, x1 ; ALL-NEXT: mov x0, x16 @@ -61,7 +63,7 @@ define i64 @test_auth_da(i64 %arg, i64 %arg1) { define i64 @test_auth_da_zero(i64 %arg) { ; ALL-LABEL: test_auth_da_zero: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autdza x16 ; ALL-NEXT: mov x0, x16 @@ -72,7 +74,7 @@ define i64 @test_auth_da_zero(i64 %arg) { define i64 @test_auth_db(i64 %arg, i64 %arg1) { ; ALL-LABEL: test_auth_db: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autdb x16, x1 ; ALL-NEXT: mov x0, x16 @@ -83,7 +85,7 @@ define i64 @test_auth_db(i64 %arg, i64 %arg1) { define i64 @test_auth_db_zero(i64 %arg) { ; ALL-LABEL: test_auth_db_zero: -; ALL: ; %bb.0: +; ALL: %bb.0: ; ALL-NEXT: mov x16, x0 ; ALL-NEXT: autdzb x16 ; ALL-NEXT: mov x0, x16 @@ -96,15 +98,15 @@ define i64 @test_auth_db_zero(i64 %arg) { ; the validity of a signature. define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_ia_ia: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autia x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpaci x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_0 +; NOFPAC-NEXT: b.eq [[L]]auth_success_0 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_0 +; NOFPAC-NEXT: b [[L]]resign_end_0 ; NOFPAC-NEXT: Lauth_success_0: ; NOFPAC-NEXT: pacia x16, x2 ; NOFPAC-NEXT: Lresign_end_0: @@ -112,7 +114,7 @@ define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_ia_ia: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autia x16, x1 ; FPAC-NEXT: pacia x16, x2 @@ -124,15 +126,15 @@ define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_ib_ia: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autib x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpaci x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_1 +; NOFPAC-NEXT: b.eq [[L]]auth_success_1 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_1 +; NOFPAC-NEXT: b [[L]]resign_end_1 ; NOFPAC-NEXT: Lauth_success_1: ; NOFPAC-NEXT: pacia x16, x2 ; NOFPAC-NEXT: Lresign_end_1: @@ -140,7 +142,7 @@ define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_ib_ia: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autib x16, x1 ; FPAC-NEXT: pacia x16, x2 @@ -152,15 +154,15 @@ define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_da_ia: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autda x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_2 +; NOFPAC-NEXT: b.eq [[L]]auth_success_2 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_2 +; NOFPAC-NEXT: b [[L]]resign_end_2 ; NOFPAC-NEXT: Lauth_success_2: ; NOFPAC-NEXT: pacia x16, x2 ; NOFPAC-NEXT: Lresign_end_2: @@ -168,7 +170,7 @@ define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_da_ia: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autda x16, x1 ; FPAC-NEXT: pacia x16, x2 @@ -180,15 +182,15 @@ define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_db_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_db_ia: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autdb x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_3 +; NOFPAC-NEXT: b.eq [[L]]auth_success_3 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_3 +; NOFPAC-NEXT: b [[L]]resign_end_3 ; NOFPAC-NEXT: Lauth_success_3: ; NOFPAC-NEXT: pacia x16, x2 ; NOFPAC-NEXT: Lresign_end_3: @@ -196,7 +198,7 @@ define i64 @test_resign_db_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_db_ia: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autdb x16, x1 ; FPAC-NEXT: pacia x16, x2 @@ -208,15 +210,15 @@ define i64 @test_resign_db_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_db_ib(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_db_ib: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autdb x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_4 +; NOFPAC-NEXT: b.eq [[L]]auth_success_4 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_4 +; NOFPAC-NEXT: b [[L]]resign_end_4 ; NOFPAC-NEXT: Lauth_success_4: ; NOFPAC-NEXT: pacib x16, x2 ; NOFPAC-NEXT: Lresign_end_4: @@ -224,7 +226,7 @@ define i64 @test_resign_db_ib(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_db_ib: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autdb x16, x1 ; FPAC-NEXT: pacib x16, x2 @@ -236,15 +238,15 @@ define i64 @test_resign_db_ib(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_db_da: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autdb x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_5 +; NOFPAC-NEXT: b.eq [[L]]auth_success_5 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_5 +; NOFPAC-NEXT: b [[L]]resign_end_5 ; NOFPAC-NEXT: Lauth_success_5: ; NOFPAC-NEXT: pacda x16, x2 ; NOFPAC-NEXT: Lresign_end_5: @@ -252,7 +254,7 @@ define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_db_da: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autdb x16, x1 ; FPAC-NEXT: pacda x16, x2 @@ -264,15 +266,15 @@ define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_db_db(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_db_db: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autdb x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_6 +; NOFPAC-NEXT: b.eq [[L]]auth_success_6 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_6 +; NOFPAC-NEXT: b [[L]]resign_end_6 ; NOFPAC-NEXT: Lauth_success_6: ; NOFPAC-NEXT: pacdb x16, x2 ; NOFPAC-NEXT: Lresign_end_6: @@ -280,7 +282,7 @@ define i64 @test_resign_db_db(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_db_db: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autdb x16, x1 ; FPAC-NEXT: pacdb x16, x2 @@ -292,15 +294,15 @@ define i64 @test_resign_db_db(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_iza_db: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autiza x16 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpaci x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_7 +; NOFPAC-NEXT: b.eq [[L]]auth_success_7 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_7 +; NOFPAC-NEXT: b [[L]]resign_end_7 ; NOFPAC-NEXT: Lauth_success_7: ; NOFPAC-NEXT: pacdb x16, x2 ; NOFPAC-NEXT: Lresign_end_7: @@ -308,7 +310,7 @@ define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_iza_db: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autiza x16 ; FPAC-NEXT: pacdb x16, x2 @@ -320,15 +322,15 @@ define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-LABEL: test_resign_da_dzb: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autda x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpacd x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_8 +; NOFPAC-NEXT: b.eq [[L]]auth_success_8 ; NOFPAC-NEXT: mov x16, x17 -; NOFPAC-NEXT: b Lresign_end_8 +; NOFPAC-NEXT: b [[L]]resign_end_8 ; NOFPAC-NEXT: Lauth_success_8: ; NOFPAC-NEXT: pacdzb x16 ; NOFPAC-NEXT: Lresign_end_8: @@ -336,7 +338,7 @@ define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_resign_da_dzb: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autda x16, x1 ; FPAC-NEXT: pacdzb x16 @@ -348,20 +350,20 @@ define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_auth_trap_attribute(i64 %arg, i64 %arg1) "ptrauth-auth-traps" { ; NOFPAC-LABEL: test_auth_trap_attribute: -; NOFPAC: ; %bb.0: +; NOFPAC: %bb.0: ; NOFPAC-NEXT: mov x16, x0 ; NOFPAC-NEXT: autia x16, x1 ; NOFPAC-NEXT: mov x17, x16 ; NOFPAC-NEXT: xpaci x17 ; NOFPAC-NEXT: cmp x16, x17 -; NOFPAC-NEXT: b.eq Lauth_success_9 +; NOFPAC-NEXT: b.eq [[L]]auth_success_9 ; NOFPAC-NEXT: brk #0xc470 ; NOFPAC-NEXT: Lauth_success_9: ; NOFPAC-NEXT: mov x0, x16 ; NOFPAC-NEXT: ret ; ; FPAC-LABEL: test_auth_trap_attribute: -; FPAC: ; %bb.0: +; FPAC: %bb.0: ; FPAC-NEXT: mov x16, x0 ; FPAC-NEXT: autia x16, x1 ; FPAC-NEXT: mov x0, x16 diff --git a/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign-with-blend.ll b/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign-with-blend.ll index 3b93acd8e46f7..74d2370c74c54 100644 --- a/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign-with-blend.ll +++ b/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign-with-blend.ll @@ -1,24 +1,39 @@ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel=0 -verify-machineinstrs \ -; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s --check-prefix=UNCHECKED +; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s -DL="L" --check-prefixes=UNCHECKED,UNCHECKED-DARWIN ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel -global-isel-abort=1 -verify-machineinstrs \ -; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s --check-prefix=UNCHECKED +; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s -DL="L" --check-prefixes=UNCHECKED,UNCHECKED-DARWIN ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel=0 -verify-machineinstrs \ -; RUN: | FileCheck %s --check-prefix=CHECKED +; RUN: | FileCheck %s -DL="L" --check-prefixes=CHECKED,CHECKED-DARWIN ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel -global-isel-abort=1 -verify-machineinstrs \ -; RUN: | FileCheck %s --check-prefix=CHECKED +; RUN: | FileCheck %s -DL="L" --check-prefixes=CHECKED,CHECKED-DARWIN ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel=0 -verify-machineinstrs \ -; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s --check-prefix=TRAP +; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s -DL="L" --check-prefixes=TRAP,TRAP-DARWIN ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel -global-isel-abort=1 -verify-machineinstrs \ -; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s --check-prefix=TRAP +; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s -DL="L" --check-prefixes=TRAP,TRAP-DARWIN + +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel=0 -verify-machineinstrs \ +; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s -DL=".L" --check-prefixes=UNCHECKED,UNCHECKED-ELF +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel -global-isel-abort=1 -verify-machineinstrs \ +; RUN: -aarch64-ptrauth-auth-checks=none | FileCheck %s -DL=".L" --check-prefixes=UNCHECKED,UNCHECKED-ELF + +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel=0 -verify-machineinstrs \ +; RUN: | FileCheck %s -DL=".L" --check-prefixes=CHECKED,CHECKED-ELF +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel -global-isel-abort=1 -verify-machineinstrs \ +; RUN: | FileCheck %s -DL=".L" --check-prefixes=CHECKED,CHECKED-ELF + +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel=0 -verify-machineinstrs \ +; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s -DL=".L" --check-prefixes=TRAP,TRAP-ELF +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel -global-isel-abort=1 -verify-machineinstrs \ +; RUN: -aarch64-ptrauth-auth-checks=trap | FileCheck %s -DL=".L" --check-prefixes=TRAP,TRAP-ELF target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128" define i64 @test_auth_blend(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_auth_blend: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: mov x17, x1 ; UNCHECKED-NEXT: movk x17, #65535, lsl #48 @@ -27,7 +42,7 @@ define i64 @test_auth_blend(i64 %arg, i64 %arg1) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_blend: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: mov x17, x1 ; CHECKED-NEXT: movk x17, #65535, lsl #48 @@ -36,7 +51,7 @@ define i64 @test_auth_blend(i64 %arg, i64 %arg1) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_blend: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: mov x17, x1 ; TRAP-NEXT: movk x17, #65535, lsl #48 @@ -44,7 +59,7 @@ define i64 @test_auth_blend(i64 %arg, i64 %arg1) { ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_0 +; TRAP-NEXT: b.eq [[L]]auth_success_0 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_0: ; TRAP-NEXT: mov x0, x16 @@ -56,7 +71,7 @@ define i64 @test_auth_blend(i64 %arg, i64 %arg1) { define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_blend: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: mov x17, x1 ; UNCHECKED-NEXT: movk x17, #12345, lsl #48 @@ -68,7 +83,7 @@ define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_blend: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: mov x17, x1 ; CHECKED-NEXT: movk x17, #12345, lsl #48 @@ -76,9 +91,9 @@ define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_0 +; CHECKED-NEXT: b.eq [[L]]auth_success_0 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_0 +; CHECKED-NEXT: b [[L]]resign_end_0 ; CHECKED-NEXT: Lauth_success_0: ; CHECKED-NEXT: mov x17, x2 ; CHECKED-NEXT: movk x17, #56789, lsl #48 @@ -88,7 +103,7 @@ define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_blend: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: mov x17, x1 ; TRAP-NEXT: movk x17, #12345, lsl #48 @@ -96,7 +111,7 @@ define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_1 +; TRAP-NEXT: b.eq [[L]]auth_success_1 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_1: ; TRAP-NEXT: mov x17, x2 @@ -112,18 +127,18 @@ define i64 @test_resign_blend(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_blend_and_const(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_resign_blend_and_const: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: mov x17, x1 ; UNCHECKED-NEXT: movk x17, #12345, lsl #48 ; UNCHECKED-NEXT: autda x16, x17 -; UNCHECKED-NEXT: mov x17, #56789 ; =0xddd5 +; UNCHECKED-NEXT: mov x17, #56789 ; UNCHECKED-NEXT: pacdb x16, x17 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_blend_and_const: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: mov x17, x1 ; CHECKED-NEXT: movk x17, #12345, lsl #48 @@ -131,18 +146,18 @@ define i64 @test_resign_blend_and_const(i64 %arg, i64 %arg1) { ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_1 +; CHECKED-NEXT: b.eq [[L]]auth_success_1 ; ... [truncated] `````````` </details> https://github.com/llvm/llvm-project/pull/101043 _______________________________________________ llvm-branch-commits mailing list llvm-branch-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-branch-commits