https://github.com/llvmbot created https://github.com/llvm/llvm-project/pull/101043
Backport 53283dc Requested by: @kovdan01 >From ab15377089a82bf5c438b589126df805577c1d80 Mon Sep 17 00:00:00 2001 From: Daniil Kovalev <dkova...@accesssoftek.com> Date: Fri, 26 Jul 2024 23:00:16 +0300 Subject: [PATCH] [PAC][test] Add tests against Linux triples for auth/resign lowering (#100744) The lowering implementation and tests against arm64e-apple-darwin triple were added previously in #79024. (cherry picked from commit 53283dc4645ee13f33dd9b98cc935b376bf78232) --- llvm/test/CodeGen/AArch64/ptrauth-fpac.ll | 100 ++++----- ...trauth-intrinsic-auth-resign-with-blend.ll | 139 +++++++----- .../AArch64/ptrauth-intrinsic-auth-resign.ll | 205 ++++++++++-------- 3 files changed, 241 insertions(+), 203 deletions(-) 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 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_1 +; CHECKED-NEXT: b [[L]]resign_end_1 ; CHECKED-NEXT: Lauth_success_1: -; CHECKED-NEXT: mov x17, #56789 ; =0xddd5 +; CHECKED-NEXT: mov x17, #56789 ; CHECKED-NEXT: pacdb x16, x17 ; CHECKED-NEXT: Lresign_end_1: ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_blend_and_const: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: mov x17, x1 ; TRAP-NEXT: movk x17, #12345, lsl #48 @@ -150,10 +165,10 @@ define i64 @test_resign_blend_and_const(i64 %arg, i64 %arg1) { ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_2 +; TRAP-NEXT: b.eq [[L]]auth_success_2 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_2: -; TRAP-NEXT: mov x17, #56789 ; =0xddd5 +; TRAP-NEXT: mov x17, #56789 ; TRAP-NEXT: pacdb x16, x17 ; TRAP-NEXT: mov x0, x16 ; TRAP-NEXT: ret @@ -164,7 +179,7 @@ define i64 @test_resign_blend_and_const(i64 %arg, i64 %arg1) { define i64 @test_resign_blend_and_addr(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_blend_and_addr: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: mov x17, x1 ; UNCHECKED-NEXT: movk x17, #12345, lsl #48 @@ -174,7 +189,7 @@ define i64 @test_resign_blend_and_addr(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_blend_and_addr: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: mov x17, x1 ; CHECKED-NEXT: movk x17, #12345, lsl #48 @@ -182,9 +197,9 @@ define i64 @test_resign_blend_and_addr(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_2 +; CHECKED-NEXT: b.eq [[L]]auth_success_2 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_2 +; CHECKED-NEXT: b [[L]]resign_end_2 ; CHECKED-NEXT: Lauth_success_2: ; CHECKED-NEXT: pacdb x16, x2 ; CHECKED-NEXT: Lresign_end_2: @@ -192,7 +207,7 @@ define i64 @test_resign_blend_and_addr(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_blend_and_addr: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: mov x17, x1 ; TRAP-NEXT: movk x17, #12345, lsl #48 @@ -200,7 +215,7 @@ define i64 @test_resign_blend_and_addr(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_3 +; TRAP-NEXT: b.eq [[L]]auth_success_3 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_3: ; TRAP-NEXT: pacdb x16, x2 @@ -212,38 +227,44 @@ define i64 @test_resign_blend_and_addr(i64 %arg, i64 %arg1, i64 %arg2) { } define i64 @test_auth_too_large_discriminator(i64 %arg, i64 %arg1) { -; UNCHECKED-LABEL: test_auth_too_large_discriminator: -; UNCHECKED: ; %bb.0: -; UNCHECKED-NEXT: mov w8, #65536 ; =0x10000 -; UNCHECKED-NEXT: bfi x1, x8, #48, #16 -; UNCHECKED-NEXT: mov x16, x0 -; UNCHECKED-NEXT: autda x16, x1 -; UNCHECKED-NEXT: mov x0, x16 -; UNCHECKED-NEXT: ret +; UNCHECKED-LABEL: test_auth_too_large_discriminator: +; UNCHECKED: %bb.0: +; UNCHECKED-NEXT: mov w8, #65536 +; UNCHECKED-DARWIN-NEXT: bfi x1, x8, #48, #16 +; UNCHECKED-DARWIN-NEXT: mov x16, x0 +; UNCHECKED-ELF-NEXT: mov x16, x0 +; UNCHECKED-ELF-NEXT: bfi x1, x8, #48, #16 +; UNCHECKED-NEXT: autda x16, x1 +; UNCHECKED-NEXT: mov x0, x16 +; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_too_large_discriminator: -; CHECKED: ; %bb.0: -; CHECKED-NEXT: mov w8, #65536 ; =0x10000 -; CHECKED-NEXT: bfi x1, x8, #48, #16 -; CHECKED-NEXT: mov x16, x0 -; CHECKED-NEXT: autda x16, x1 -; CHECKED-NEXT: mov x0, x16 -; CHECKED-NEXT: ret +; CHECKED: %bb.0: +; CHECKED-NEXT: mov w8, #65536 +; CHECKED-DARWIN-NEXT: bfi x1, x8, #48, #16 +; CHECKED-DARWIN-NEXT: mov x16, x0 +; CHECKED-ELF-NEXT: mov x16, x0 +; CHECKED-ELF-NEXT: bfi x1, x8, #48, #16 +; CHECKED-NEXT: autda x16, x1 +; CHECKED-NEXT: mov x0, x16 +; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_too_large_discriminator: -; TRAP: ; %bb.0: -; TRAP-NEXT: mov w8, #65536 ; =0x10000 -; TRAP-NEXT: bfi x1, x8, #48, #16 -; TRAP-NEXT: mov x16, x0 -; TRAP-NEXT: autda x16, x1 -; TRAP-NEXT: mov x17, x16 -; TRAP-NEXT: xpacd x17 -; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_4 -; TRAP-NEXT: brk #0xc472 -; TRAP-NEXT: Lauth_success_4: -; TRAP-NEXT: mov x0, x16 -; TRAP-NEXT: ret +; TRAP: %bb.0: +; TRAP-NEXT: mov w8, #65536 +; TRAP-DARWIN-NEXT: bfi x1, x8, #48, #16 +; TRAP-DARWIN-NEXT: mov x16, x0 +; TRAP-ELF-NEXT: mov x16, x0 +; TRAP-ELF-NEXT: bfi x1, x8, #48, #16 +; TRAP-NEXT: autda x16, x1 +; TRAP-NEXT: mov x17, x16 +; TRAP-NEXT: xpacd x17 +; TRAP-NEXT: cmp x16, x17 +; TRAP-NEXT: b.eq [[L]]auth_success_4 +; TRAP-NEXT: brk #0xc472 +; TRAP-NEXT: Lauth_success_4: +; TRAP-NEXT: mov x0, x16 +; TRAP-NEXT: ret %tmp0 = call i64 @llvm.ptrauth.blend(i64 %arg1, i64 65536) %tmp1 = call i64 @llvm.ptrauth.auth(i64 %arg, i32 2, i64 %tmp0) ret i64 %tmp1 diff --git a/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign.ll b/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign.ll index 62c9fba853adb..fdd5ae29f35ea 100644 --- a/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign.ll +++ b/llvm/test/CodeGen/AArch64/ptrauth-intrinsic-auth-resign.ll @@ -1,44 +1,59 @@ ; 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-prefix=UNCHECKED ; 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-prefix=UNCHECKED ; RUN: llc < %s -mtriple arm64e-apple-darwin -global-isel=0 -verify-machineinstrs \ -; RUN: | FileCheck %s --check-prefix=CHECKED +; RUN: | FileCheck %s -DL="L" --check-prefix=CHECKED ; 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-prefix=CHECKED ; 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-prefix=TRAP ; 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-prefix=TRAP + +; 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-prefix=UNCHECKED +; 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-prefix=UNCHECKED + +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel=0 -verify-machineinstrs \ +; RUN: | FileCheck %s -DL=".L" --check-prefix=CHECKED +; RUN: llc < %s -mtriple aarch64-linux-gnu -mattr=+pauth -global-isel -global-isel-abort=1 -verify-machineinstrs \ +; RUN: | FileCheck %s -DL=".L" --check-prefix=CHECKED + +; 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-prefix=TRAP +; 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-prefix=TRAP target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128" define i64 @test_auth_ia(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_auth_ia: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autia x16, x1 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_ia: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autia x16, x1 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_ia: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autia x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_0 +; TRAP-NEXT: b.eq [[L]]auth_success_0 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_0: ; TRAP-NEXT: mov x0, x16 @@ -49,27 +64,27 @@ define i64 @test_auth_ia(i64 %arg, i64 %arg1) { define i64 @test_auth_ia_zero(i64 %arg) { ; UNCHECKED-LABEL: test_auth_ia_zero: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autiza x16 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_ia_zero: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autiza x16 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_ia_zero: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autiza x16 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_1 +; TRAP-NEXT: b.eq [[L]]auth_success_1 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_1: ; TRAP-NEXT: mov x0, x16 @@ -80,27 +95,27 @@ define i64 @test_auth_ia_zero(i64 %arg) { define i64 @test_auth_ib(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_auth_ib: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autib x16, x1 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_ib: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autib x16, x1 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_ib: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autib x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_2 +; TRAP-NEXT: b.eq [[L]]auth_success_2 ; TRAP-NEXT: brk #0xc471 ; TRAP-NEXT: Lauth_success_2: ; TRAP-NEXT: mov x0, x16 @@ -111,27 +126,27 @@ define i64 @test_auth_ib(i64 %arg, i64 %arg1) { define i64 @test_auth_ib_zero(i64 %arg) { ; UNCHECKED-LABEL: test_auth_ib_zero: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autizb x16 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_ib_zero: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autizb x16 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_ib_zero: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autizb x16 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_3 +; TRAP-NEXT: b.eq [[L]]auth_success_3 ; TRAP-NEXT: brk #0xc471 ; TRAP-NEXT: Lauth_success_3: ; TRAP-NEXT: mov x0, x16 @@ -142,27 +157,27 @@ define i64 @test_auth_ib_zero(i64 %arg) { define i64 @test_auth_da(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_auth_da: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autda x16, x1 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_da: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autda x16, x1 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_da: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autda x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_4 +; TRAP-NEXT: b.eq [[L]]auth_success_4 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_4: ; TRAP-NEXT: mov x0, x16 @@ -173,27 +188,27 @@ define i64 @test_auth_da(i64 %arg, i64 %arg1) { define i64 @test_auth_da_zero(i64 %arg) { ; UNCHECKED-LABEL: test_auth_da_zero: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autdza x16 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_da_zero: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autdza x16 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_da_zero: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autdza x16 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_5 +; TRAP-NEXT: b.eq [[L]]auth_success_5 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_5: ; TRAP-NEXT: mov x0, x16 @@ -204,27 +219,27 @@ define i64 @test_auth_da_zero(i64 %arg) { define i64 @test_auth_db(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_auth_db: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autdb x16, x1 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_db: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autdb x16, x1 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_db: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autdb x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_6 +; TRAP-NEXT: b.eq [[L]]auth_success_6 ; TRAP-NEXT: brk #0xc473 ; TRAP-NEXT: Lauth_success_6: ; TRAP-NEXT: mov x0, x16 @@ -235,27 +250,27 @@ define i64 @test_auth_db(i64 %arg, i64 %arg1) { define i64 @test_auth_db_zero(i64 %arg) { ; UNCHECKED-LABEL: test_auth_db_zero: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autdzb x16 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_db_zero: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autdzb x16 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_db_zero: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autdzb x16 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_7 +; TRAP-NEXT: b.eq [[L]]auth_success_7 ; TRAP-NEXT: brk #0xc473 ; TRAP-NEXT: Lauth_success_7: ; TRAP-NEXT: mov x0, x16 @@ -268,7 +283,7 @@ 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) { ; UNCHECKED-LABEL: test_resign_ia_ia: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autia x16, x1 ; UNCHECKED-NEXT: pacia x16, x2 @@ -276,15 +291,15 @@ define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_ia_ia: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autia x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpaci 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: pacia x16, x2 ; CHECKED-NEXT: Lresign_end_0: @@ -292,13 +307,13 @@ define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_ia_ia: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autia x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_8 +; TRAP-NEXT: b.eq [[L]]auth_success_8 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_8: ; TRAP-NEXT: pacia x16, x2 @@ -310,7 +325,7 @@ define i64 @test_resign_ia_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_ib_ia: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autib x16, x1 ; UNCHECKED-NEXT: pacia x16, x2 @@ -318,15 +333,15 @@ define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_ib_ia: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autib x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpaci x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_1 +; CHECKED-NEXT: b.eq [[L]]auth_success_1 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_1 +; CHECKED-NEXT: b [[L]]resign_end_1 ; CHECKED-NEXT: Lauth_success_1: ; CHECKED-NEXT: pacia x16, x2 ; CHECKED-NEXT: Lresign_end_1: @@ -334,13 +349,13 @@ define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_ib_ia: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autib x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_9 +; TRAP-NEXT: b.eq [[L]]auth_success_9 ; TRAP-NEXT: brk #0xc471 ; TRAP-NEXT: Lauth_success_9: ; TRAP-NEXT: pacia x16, x2 @@ -352,7 +367,7 @@ define i64 @test_resign_ib_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_da_ia: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autda x16, x1 ; UNCHECKED-NEXT: pacia x16, x2 @@ -360,15 +375,15 @@ define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_da_ia: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autda x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_2 +; CHECKED-NEXT: b.eq [[L]]auth_success_2 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_2 +; CHECKED-NEXT: b [[L]]resign_end_2 ; CHECKED-NEXT: Lauth_success_2: ; CHECKED-NEXT: pacia x16, x2 ; CHECKED-NEXT: Lresign_end_2: @@ -376,13 +391,13 @@ define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_da_ia: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autda x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_10 +; TRAP-NEXT: b.eq [[L]]auth_success_10 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_10: ; TRAP-NEXT: pacia x16, x2 @@ -394,7 +409,7 @@ define i64 @test_resign_da_ia(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_db_da: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autdb x16, x1 ; UNCHECKED-NEXT: pacda x16, x2 @@ -402,15 +417,15 @@ define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_db_da: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autdb x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_3 +; CHECKED-NEXT: b.eq [[L]]auth_success_3 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_3 +; CHECKED-NEXT: b [[L]]resign_end_3 ; CHECKED-NEXT: Lauth_success_3: ; CHECKED-NEXT: pacda x16, x2 ; CHECKED-NEXT: Lresign_end_3: @@ -418,13 +433,13 @@ define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_db_da: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autdb x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_11 +; TRAP-NEXT: b.eq [[L]]auth_success_11 ; TRAP-NEXT: brk #0xc473 ; TRAP-NEXT: Lauth_success_11: ; TRAP-NEXT: pacda x16, x2 @@ -436,7 +451,7 @@ define i64 @test_resign_db_da(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_iza_db: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autiza x16 ; UNCHECKED-NEXT: pacdb x16, x2 @@ -444,15 +459,15 @@ define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_iza_db: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autiza x16 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpaci x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_4 +; CHECKED-NEXT: b.eq [[L]]auth_success_4 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_4 +; CHECKED-NEXT: b [[L]]resign_end_4 ; CHECKED-NEXT: Lauth_success_4: ; CHECKED-NEXT: pacdb x16, x2 ; CHECKED-NEXT: Lresign_end_4: @@ -460,13 +475,13 @@ define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_iza_db: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autiza x16 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_12 +; TRAP-NEXT: b.eq [[L]]auth_success_12 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_12: ; TRAP-NEXT: pacdb x16, x2 @@ -478,7 +493,7 @@ define i64 @test_resign_iza_db(i64 %arg, i64 %arg1, i64 %arg2) { define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-LABEL: test_resign_da_dzb: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autda x16, x1 ; UNCHECKED-NEXT: pacdzb x16 @@ -486,15 +501,15 @@ define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_da_dzb: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autda x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_5 +; CHECKED-NEXT: b.eq [[L]]auth_success_5 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_5 +; CHECKED-NEXT: b [[L]]resign_end_5 ; CHECKED-NEXT: Lauth_success_5: ; CHECKED-NEXT: pacdzb x16 ; CHECKED-NEXT: Lresign_end_5: @@ -502,13 +517,13 @@ define i64 @test_resign_da_dzb(i64 %arg, i64 %arg1, i64 %arg2) { ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_da_dzb: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autda x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_13 +; TRAP-NEXT: b.eq [[L]]auth_success_13 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_13: ; TRAP-NEXT: pacdzb x16 @@ -520,33 +535,33 @@ 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" { ; UNCHECKED-LABEL: test_auth_trap_attribute: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autia x16, x1 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_trap_attribute: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autia x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpaci x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_6 +; CHECKED-NEXT: b.eq [[L]]auth_success_6 ; CHECKED-NEXT: brk #0xc470 ; CHECKED-NEXT: Lauth_success_6: ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_trap_attribute: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autia x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_14 +; TRAP-NEXT: b.eq [[L]]auth_success_14 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_14: ; TRAP-NEXT: mov x0, x16 @@ -557,30 +572,30 @@ define i64 @test_auth_trap_attribute(i64 %arg, i64 %arg1) "ptrauth-auth-traps" { define i64 @test_auth_ia_constdisc(i64 %arg) { ; UNCHECKED-LABEL: test_auth_ia_constdisc: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 -; UNCHECKED-NEXT: mov x17, #256 ; =0x100 +; UNCHECKED-NEXT: mov x17, #256 ; UNCHECKED-NEXT: autia x16, x17 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_auth_ia_constdisc: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 -; CHECKED-NEXT: mov x17, #256 ; =0x100 +; CHECKED-NEXT: mov x17, #256 ; CHECKED-NEXT: autia x16, x17 ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_auth_ia_constdisc: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 -; TRAP-NEXT: mov x17, #256 ; =0x100 +; TRAP-NEXT: mov x17, #256 ; TRAP-NEXT: autia x16, x17 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpaci x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_15 +; TRAP-NEXT: b.eq [[L]]auth_success_15 ; TRAP-NEXT: brk #0xc470 ; TRAP-NEXT: Lauth_success_15: ; TRAP-NEXT: mov x0, x16 @@ -591,42 +606,42 @@ define i64 @test_auth_ia_constdisc(i64 %arg) { define i64 @test_resign_da_constdisc(i64 %arg, i64 %arg1) { ; UNCHECKED-LABEL: test_resign_da_constdisc: -; UNCHECKED: ; %bb.0: +; UNCHECKED: %bb.0: ; UNCHECKED-NEXT: mov x16, x0 ; UNCHECKED-NEXT: autda x16, x1 -; UNCHECKED-NEXT: mov x17, #256 ; =0x100 +; UNCHECKED-NEXT: mov x17, #256 ; UNCHECKED-NEXT: pacda x16, x17 ; UNCHECKED-NEXT: mov x0, x16 ; UNCHECKED-NEXT: ret ; ; CHECKED-LABEL: test_resign_da_constdisc: -; CHECKED: ; %bb.0: +; CHECKED: %bb.0: ; CHECKED-NEXT: mov x16, x0 ; CHECKED-NEXT: autda x16, x1 ; CHECKED-NEXT: mov x17, x16 ; CHECKED-NEXT: xpacd x17 ; CHECKED-NEXT: cmp x16, x17 -; CHECKED-NEXT: b.eq Lauth_success_7 +; CHECKED-NEXT: b.eq [[L]]auth_success_7 ; CHECKED-NEXT: mov x16, x17 -; CHECKED-NEXT: b Lresign_end_6 +; CHECKED-NEXT: b [[L]]resign_end_6 ; CHECKED-NEXT: Lauth_success_7: -; CHECKED-NEXT: mov x17, #256 ; =0x100 +; CHECKED-NEXT: mov x17, #256 ; CHECKED-NEXT: pacda x16, x17 ; CHECKED-NEXT: Lresign_end_6: ; CHECKED-NEXT: mov x0, x16 ; CHECKED-NEXT: ret ; ; TRAP-LABEL: test_resign_da_constdisc: -; TRAP: ; %bb.0: +; TRAP: %bb.0: ; TRAP-NEXT: mov x16, x0 ; TRAP-NEXT: autda x16, x1 ; TRAP-NEXT: mov x17, x16 ; TRAP-NEXT: xpacd x17 ; TRAP-NEXT: cmp x16, x17 -; TRAP-NEXT: b.eq Lauth_success_16 +; TRAP-NEXT: b.eq [[L]]auth_success_16 ; TRAP-NEXT: brk #0xc472 ; TRAP-NEXT: Lauth_success_16: -; TRAP-NEXT: mov x17, #256 ; =0x100 +; TRAP-NEXT: mov x17, #256 ; TRAP-NEXT: pacda x16, x17 ; TRAP-NEXT: mov x0, x16 ; TRAP-NEXT: ret _______________________________________________ llvm-branch-commits mailing list llvm-branch-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-branch-commits