1b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0 249863894SWill Deacon 349863894SWill Deacon #include <linux/errno.h> 449863894SWill Deacon #include <linux/kernel.h> 549863894SWill Deacon #include <linux/perf_event.h> 649863894SWill Deacon #include <linux/bug.h> 768db0cf1SIngo Molnar #include <linux/sched/task_stack.h> 849863894SWill Deacon #include <asm/perf_regs.h> 949863894SWill Deacon #include <asm/ptrace.h> 1049863894SWill Deacon perf_reg_value(struct pt_regs * regs,int idx)1149863894SWill Deaconu64 perf_reg_value(struct pt_regs *regs, int idx) 1249863894SWill Deacon { 1349863894SWill Deacon if (WARN_ON_ONCE((u32)idx >= PERF_REG_ARM_MAX)) 1449863894SWill Deacon return 0; 1549863894SWill Deacon 1649863894SWill Deacon return regs->uregs[idx]; 1749863894SWill Deacon } 1849863894SWill Deacon 1949863894SWill Deacon #define REG_RESERVED (~((1ULL << PERF_REG_ARM_MAX) - 1)) 2049863894SWill Deacon perf_reg_validate(u64 mask)2149863894SWill Deaconint perf_reg_validate(u64 mask) 2249863894SWill Deacon { 2349863894SWill Deacon if (!mask || mask & REG_RESERVED) 2449863894SWill Deacon return -EINVAL; 2549863894SWill Deacon 2649863894SWill Deacon return 0; 2749863894SWill Deacon } 2849863894SWill Deacon perf_reg_abi(struct task_struct * task)2949863894SWill Deaconu64 perf_reg_abi(struct task_struct *task) 3049863894SWill Deacon { 3149863894SWill Deacon return PERF_SAMPLE_REGS_ABI_32; 3249863894SWill Deacon } 3388a7c26aSAndy Lutomirski perf_get_regs_user(struct perf_regs * regs_user,struct pt_regs * regs)3488a7c26aSAndy Lutomirskivoid perf_get_regs_user(struct perf_regs *regs_user, 35*76a4efa8SPeter Zijlstra struct pt_regs *regs) 3688a7c26aSAndy Lutomirski { 3788a7c26aSAndy Lutomirski regs_user->regs = task_pt_regs(current); 3888a7c26aSAndy Lutomirski regs_user->abi = perf_reg_abi(current); 3988a7c26aSAndy Lutomirski } 40