Path: blob/master/arch/riscv/include/uapi/asm/ucontext.h
26513 views
/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */1/*2* Copyright (C) 2012 ARM Ltd.3* Copyright (C) 2017 SiFive, Inc.4*5* This file was copied from arch/arm64/include/uapi/asm/ucontext.h6*/7#ifndef _UAPI_ASM_RISCV_UCONTEXT_H8#define _UAPI_ASM_RISCV_UCONTEXT_H910#include <linux/types.h>1112struct ucontext {13unsigned long uc_flags;14struct ucontext *uc_link;15stack_t uc_stack;16sigset_t uc_sigmask;17/*18* There's some padding here to allow sigset_t to be expanded in the19* future. Though this is unlikely, other architectures put uc_sigmask20* at the end of this structure and explicitly state it can be21* expanded, so we didn't want to box ourselves in here.22*/23__u8 __unused[1024 / 8 - sizeof(sigset_t)];24/*25* We can't put uc_sigmask at the end of this structure because we need26* to be able to expand sigcontext in the future. For example, the27* vector ISA extension will almost certainly add ISA state. We want28* to ensure all user-visible ISA state can be saved and restored via a29* ucontext, so we're putting this at the end in order to allow for30* infinite extensibility. Since we know this will be extended and we31* assume sigset_t won't be extended an extreme amount, we're32* prioritizing this.33*/34struct sigcontext uc_mcontext;35};3637#endif /* _UAPI_ASM_RISCV_UCONTEXT_H */383940