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