Path: blob/master/tools/testing/selftests/arm64/signal/testcases/fpmr_siginfo.c
26295 views
// SPDX-License-Identifier: GPL-2.01/*2* Copyright (C) 2023 ARM Limited3*4* Verify that the FPMR register context in signal frames is set up as5* expected.6*/78#include <signal.h>9#include <ucontext.h>10#include <sys/auxv.h>11#include <sys/prctl.h>12#include <unistd.h>13#include <asm/sigcontext.h>1415#include "test_signals_utils.h"16#include "testcases.h"1718static union {19ucontext_t uc;20char buf[1024 * 128];21} context;2223#define SYS_FPMR "S3_3_C4_C4_2"2425static uint64_t get_fpmr(void)26{27uint64_t val;2829asm volatile (30"mrs %0, " SYS_FPMR "\n"31: "=r"(val)32:33: "cc");3435return val;36}3738int fpmr_present(struct tdescr *td, siginfo_t *si, ucontext_t *uc)39{40struct _aarch64_ctx *head = GET_BUF_RESV_HEAD(context);41struct fpmr_context *fpmr_ctx;42size_t offset;43bool in_sigframe;44bool have_fpmr;45__u64 orig_fpmr;4647have_fpmr = getauxval(AT_HWCAP2) & HWCAP2_FPMR;48if (have_fpmr)49orig_fpmr = get_fpmr();5051if (!get_current_context(td, &context.uc, sizeof(context)))52return 1;5354fpmr_ctx = (struct fpmr_context *)55get_header(head, FPMR_MAGIC, td->live_sz, &offset);5657in_sigframe = fpmr_ctx != NULL;5859fprintf(stderr, "FPMR sigframe %s on system %s FPMR\n",60in_sigframe ? "present" : "absent",61have_fpmr ? "with" : "without");6263td->pass = (in_sigframe == have_fpmr);6465if (have_fpmr && fpmr_ctx) {66if (fpmr_ctx->fpmr != orig_fpmr) {67fprintf(stderr, "FPMR in frame is %llx, was %llx\n",68fpmr_ctx->fpmr, orig_fpmr);69td->pass = false;70}71}7273return 0;74}7576struct tdescr tde = {77.name = "FPMR",78.descr = "Validate that FPMR is present as expected",79.timeout = 3,80.run = fpmr_present,81};828384