mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
44e92e0364
Currently, the nds32 FPU dose not support the arithmetic of denormalized number. When the nds32 FPU finds the result of the instruction is a denormlized number, the nds32 FPU considers it to be an underflow condition and rounds the result to an appropriate number. It may causes some loss of precision. This commit proposes a solution to re-execute the instruction by the FPU emulator to enhance the precision. To transfer calculations from user space to kernel space, this feature will enable the underflow exception trap by default. Enabling this feature may cause some side effects: 1. Performance loss due to extra FPU exception 2. Need another scheme to control real underflow trap A new parameter, UDF_trap, which is belong to FPU context is used to control underflow trap. User can configure this feature via CONFIG_SUPPORT_DENORMAL_ARITHMETIC Signed-off-by: Vincent Chen <vincentc@andestech.com> Acked-by: Greentime Hu <greentime@andestech.com> Signed-off-by: Greentime Hu <greentime@andestech.com>
15 lines
462 B
C
15 lines
462 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
// Copyright (C) 2005-2017 Andes Technology Corporation
|
|
|
|
#define __ARCH_WANT_STAT64
|
|
#define __ARCH_WANT_SYNC_FILE_RANGE2
|
|
|
|
/* Use the standard ABI for syscalls */
|
|
#include <asm-generic/unistd.h>
|
|
|
|
/* Additional NDS32 specific syscalls. */
|
|
#define __NR_cacheflush (__NR_arch_specific_syscall)
|
|
#define __NR_udftrap (__NR_arch_specific_syscall + 1)
|
|
__SYSCALL(__NR_cacheflush, sys_cacheflush)
|
|
__SYSCALL(__NR_udftrap, sys_udftrap)
|