85 lines
2.4 KiB
C
85 lines
2.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
// Copyright (C) 2005-2017 Andes Technology Corporation
|
|
|
|
#ifndef _ASMNDS32_SIGCONTEXT_H
|
|
#define _ASMNDS32_SIGCONTEXT_H
|
|
|
|
/*
|
|
* Signal context structure - contains all info to do with the state
|
|
* before the signal handler was invoked. Note: only add new entries
|
|
* to the end of the structure.
|
|
*/
|
|
struct fpu_struct {
|
|
unsigned long long fd_regs[32];
|
|
unsigned long fpcsr;
|
|
/*
|
|
* When CONFIG_SUPPORT_DENORMAL_ARITHMETIC is defined, kernel prevents
|
|
* hardware from treating the denormalized output as an underflow case
|
|
* and rounding it to a normal number. Hence kernel enables the UDF and
|
|
* IEX trap in the fpcsr register to step in the calculation.
|
|
* However, the UDF and IEX trap enable bit in $fpcsr also lose
|
|
* their use.
|
|
*
|
|
* UDF_IEX_trap replaces the feature of UDF and IEX trap enable bit in
|
|
* $fpcsr to control the trap of underflow and inexact. The bit filed
|
|
* of UDF_IEX_trap is the same as $fpcsr, 10th bit is used to enable UDF
|
|
* exception trapping and 11th bit is used to enable IEX exception
|
|
* trapping.
|
|
*
|
|
* UDF_IEX_trap is only modified through fp_udfiex_crtl syscall.
|
|
* Therefore, UDF_IEX_trap needn't be saved and restored in each
|
|
* context switch.
|
|
*/
|
|
unsigned long UDF_IEX_trap;
|
|
};
|
|
|
|
struct zol_struct {
|
|
unsigned long nds32_lc; /* $LC */
|
|
unsigned long nds32_le; /* $LE */
|
|
unsigned long nds32_lb; /* $LB */
|
|
};
|
|
|
|
struct sigcontext {
|
|
unsigned long trap_no;
|
|
unsigned long error_code;
|
|
unsigned long oldmask;
|
|
unsigned long nds32_r0;
|
|
unsigned long nds32_r1;
|
|
unsigned long nds32_r2;
|
|
unsigned long nds32_r3;
|
|
unsigned long nds32_r4;
|
|
unsigned long nds32_r5;
|
|
unsigned long nds32_r6;
|
|
unsigned long nds32_r7;
|
|
unsigned long nds32_r8;
|
|
unsigned long nds32_r9;
|
|
unsigned long nds32_r10;
|
|
unsigned long nds32_r11;
|
|
unsigned long nds32_r12;
|
|
unsigned long nds32_r13;
|
|
unsigned long nds32_r14;
|
|
unsigned long nds32_r15;
|
|
unsigned long nds32_r16;
|
|
unsigned long nds32_r17;
|
|
unsigned long nds32_r18;
|
|
unsigned long nds32_r19;
|
|
unsigned long nds32_r20;
|
|
unsigned long nds32_r21;
|
|
unsigned long nds32_r22;
|
|
unsigned long nds32_r23;
|
|
unsigned long nds32_r24;
|
|
unsigned long nds32_r25;
|
|
unsigned long nds32_fp; /* $r28 */
|
|
unsigned long nds32_gp; /* $r29 */
|
|
unsigned long nds32_lp; /* $r30 */
|
|
unsigned long nds32_sp; /* $r31 */
|
|
unsigned long nds32_ipc;
|
|
unsigned long fault_address;
|
|
unsigned long used_math_flag;
|
|
/* FPU Registers */
|
|
struct fpu_struct fpu;
|
|
struct zol_struct zol;
|
|
};
|
|
|
|
#endif
|