未验证 提交 9671f706 编写于 作者: A Alan Kao 提交者: Palmer Dabbelt

Allow to disable FPU support

FPU codes have been separated from common part in previous patches.
This patch add the CONFIG_FPU option and some stubs, so that a no-FPU
configuration is allowed.
Signed-off-by: NAlan Kao <alankao@andestech.com>
Cc: Greentime Hu <greentime@andestech.com>
Cc: Vincent Chen <vincentc@andestech.com>
Cc: Zong Li <zong@andestech.com>
Cc: Nick Hu <nickhu@andestech.com>
Reviewed-by: NChristoph Hellwig <hch@lst.de>
Signed-off-by: NPalmer Dabbelt <palmer@sifive.com>
上级 e8be5302
...@@ -208,6 +208,15 @@ config RISCV_BASE_PMU ...@@ -208,6 +208,15 @@ config RISCV_BASE_PMU
endmenu endmenu
config FPU
bool "FPU support"
default y
help
Say N here if you want to disable all floating-point related procedure
in the kernel.
If you don't know what to do here, say Y.
endmenu endmenu
menu "Kernel type" menu "Kernel type"
......
...@@ -44,7 +44,7 @@ KBUILD_CFLAGS += -Wall ...@@ -44,7 +44,7 @@ KBUILD_CFLAGS += -Wall
riscv-march-$(CONFIG_ARCH_RV32I) := rv32im riscv-march-$(CONFIG_ARCH_RV32I) := rv32im
riscv-march-$(CONFIG_ARCH_RV64I) := rv64im riscv-march-$(CONFIG_ARCH_RV64I) := rv64im
riscv-march-$(CONFIG_RISCV_ISA_A) := $(riscv-march-y)a riscv-march-$(CONFIG_RISCV_ISA_A) := $(riscv-march-y)a
riscv-march-y := $(riscv-march-y)fd riscv-march-$(CONFIG_FPU) := $(riscv-march-y)fd
riscv-march-$(CONFIG_RISCV_ISA_C) := $(riscv-march-y)c riscv-march-$(CONFIG_RISCV_ISA_C) := $(riscv-march-y)c
KBUILD_CFLAGS += -march=$(subst fd,,$(riscv-march-y)) KBUILD_CFLAGS += -march=$(subst fd,,$(riscv-march-y))
KBUILD_AFLAGS += -march=$(riscv-march-y) KBUILD_AFLAGS += -march=$(riscv-march-y)
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include <asm/ptrace.h> #include <asm/ptrace.h>
#include <asm/csr.h> #include <asm/csr.h>
#ifdef CONFIG_FPU
extern void __fstate_save(struct task_struct *save_to); extern void __fstate_save(struct task_struct *save_to);
extern void __fstate_restore(struct task_struct *restore_from); extern void __fstate_restore(struct task_struct *restore_from);
...@@ -55,6 +56,15 @@ static inline void __switch_to_aux(struct task_struct *prev, ...@@ -55,6 +56,15 @@ static inline void __switch_to_aux(struct task_struct *prev,
fstate_restore(next, task_pt_regs(next)); fstate_restore(next, task_pt_regs(next));
} }
#define DEFAULT_SSTATUS (SR_SPIE | SR_FS_INITIAL)
#else
#define fstate_save(task, regs) do { } while (0)
#define fstate_restore(task, regs) do { } while (0)
#define __switch_to_aux(__prev, __next) do { } while (0)
#define DEFAULT_SSTATUS (SR_SPIE | SR_FS_OFF)
#endif
extern struct task_struct *__switch_to(struct task_struct *, extern struct task_struct *__switch_to(struct task_struct *,
struct task_struct *); struct task_struct *);
......
...@@ -13,7 +13,6 @@ extra-y += vmlinux.lds ...@@ -13,7 +13,6 @@ extra-y += vmlinux.lds
obj-y += cpu.o obj-y += cpu.o
obj-y += cpufeature.o obj-y += cpufeature.o
obj-y += entry.o obj-y += entry.o
obj-y += fpu.o
obj-y += irq.o obj-y += irq.o
obj-y += process.o obj-y += process.o
obj-y += ptrace.o obj-y += ptrace.o
...@@ -32,6 +31,7 @@ obj-y += vdso/ ...@@ -32,6 +31,7 @@ obj-y += vdso/
CFLAGS_setup.o := -mcmodel=medany CFLAGS_setup.o := -mcmodel=medany
obj-$(CONFIG_FPU) += fpu.o
obj-$(CONFIG_SMP) += smpboot.o obj-$(CONFIG_SMP) += smpboot.o
obj-$(CONFIG_SMP) += smp.o obj-$(CONFIG_SMP) += smp.o
obj-$(CONFIG_MODULES) += module.o obj-$(CONFIG_MODULES) += module.o
......
...@@ -76,7 +76,7 @@ void show_regs(struct pt_regs *regs) ...@@ -76,7 +76,7 @@ void show_regs(struct pt_regs *regs)
void start_thread(struct pt_regs *regs, unsigned long pc, void start_thread(struct pt_regs *regs, unsigned long pc,
unsigned long sp) unsigned long sp)
{ {
regs->sstatus = SR_SPIE /* User mode, irqs on */ | SR_FS_INITIAL; regs->sstatus = DEFAULT_SSTATUS;
regs->sepc = pc; regs->sepc = pc;
regs->sp = sp; regs->sp = sp;
set_fs(USER_DS); set_fs(USER_DS);
...@@ -84,12 +84,14 @@ void start_thread(struct pt_regs *regs, unsigned long pc, ...@@ -84,12 +84,14 @@ void start_thread(struct pt_regs *regs, unsigned long pc,
void flush_thread(void) void flush_thread(void)
{ {
#ifdef CONFIG_FPU
/* /*
* Reset FPU context * Reset FPU context
* frm: round to nearest, ties to even (IEEE default) * frm: round to nearest, ties to even (IEEE default)
* fflags: accrued exceptions cleared * fflags: accrued exceptions cleared
*/ */
memset(&current->thread.fstate, 0, sizeof(current->thread.fstate)); memset(&current->thread.fstate, 0, sizeof(current->thread.fstate));
#endif
} }
int arch_dup_task_struct(struct task_struct *dst, struct task_struct *src) int arch_dup_task_struct(struct task_struct *dst, struct task_struct *src)
......
...@@ -37,6 +37,7 @@ struct rt_sigframe { ...@@ -37,6 +37,7 @@ struct rt_sigframe {
struct ucontext uc; struct ucontext uc;
}; };
#ifdef CONFIG_FPU
static long restore_fp_state(struct pt_regs *regs, static long restore_fp_state(struct pt_regs *regs,
union __riscv_fp_state *sc_fpregs) union __riscv_fp_state *sc_fpregs)
{ {
...@@ -85,6 +86,10 @@ static long save_fp_state(struct pt_regs *regs, ...@@ -85,6 +86,10 @@ static long save_fp_state(struct pt_regs *regs,
return err; return err;
} }
#else
#define save_fp_state(task, regs) (0)
#define restore_fp_state(task, regs) (0)
#endif
static long restore_sigcontext(struct pt_regs *regs, static long restore_sigcontext(struct pt_regs *regs,
struct sigcontext __user *sc) struct sigcontext __user *sc)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册