18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci// Copyright (C) 2020 ARM Limited 38c2ecf20Sopenharmony_ci 48c2ecf20Sopenharmony_ci#include "helper.h" 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_cisize_t keyia_sign(size_t ptr) 78c2ecf20Sopenharmony_ci{ 88c2ecf20Sopenharmony_ci asm volatile("paciza %0" : "+r" (ptr)); 98c2ecf20Sopenharmony_ci return ptr; 108c2ecf20Sopenharmony_ci} 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_cisize_t keyib_sign(size_t ptr) 138c2ecf20Sopenharmony_ci{ 148c2ecf20Sopenharmony_ci asm volatile("pacizb %0" : "+r" (ptr)); 158c2ecf20Sopenharmony_ci return ptr; 168c2ecf20Sopenharmony_ci} 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_cisize_t keyda_sign(size_t ptr) 198c2ecf20Sopenharmony_ci{ 208c2ecf20Sopenharmony_ci asm volatile("pacdza %0" : "+r" (ptr)); 218c2ecf20Sopenharmony_ci return ptr; 228c2ecf20Sopenharmony_ci} 238c2ecf20Sopenharmony_ci 248c2ecf20Sopenharmony_cisize_t keydb_sign(size_t ptr) 258c2ecf20Sopenharmony_ci{ 268c2ecf20Sopenharmony_ci asm volatile("pacdzb %0" : "+r" (ptr)); 278c2ecf20Sopenharmony_ci return ptr; 288c2ecf20Sopenharmony_ci} 298c2ecf20Sopenharmony_ci 308c2ecf20Sopenharmony_cisize_t keyg_sign(size_t ptr) 318c2ecf20Sopenharmony_ci{ 328c2ecf20Sopenharmony_ci /* output is encoded in the upper 32 bits */ 338c2ecf20Sopenharmony_ci size_t dest = 0; 348c2ecf20Sopenharmony_ci size_t modifier = 0; 358c2ecf20Sopenharmony_ci 368c2ecf20Sopenharmony_ci asm volatile("pacga %0, %1, %2" : "=r" (dest) : "r" (ptr), "r" (modifier)); 378c2ecf20Sopenharmony_ci 388c2ecf20Sopenharmony_ci return dest; 398c2ecf20Sopenharmony_ci} 40