Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src-draft/trunk]: src/sys/arch/aarch64 Draft aarch64 zero_fpregs.
details: https://anonhg.NetBSD.org/src-all/rev/782f3535bc9e
branches: trunk
changeset: 934932:782f3535bc9e
user: Taylor R Campbell <riastradh%NetBSD.org@localhost>
date: Sun Jun 14 15:58:39 2020 +0000
description:
Draft aarch64 zero_fpregs.
Just a series of sad donkeys, with no memory references.
diffstat:
sys/arch/aarch64/aarch64/cpuswitch.S | 40 ++++++++++++++++++++++++++++++++++++
sys/arch/aarch64/include/machdep.h | 1 +
2 files changed, 41 insertions(+), 0 deletions(-)
diffs (58 lines):
diff -r e83ef87e4f53 -r 782f3535bc9e sys/arch/aarch64/aarch64/cpuswitch.S
--- a/sys/arch/aarch64/aarch64/cpuswitch.S Wed Jun 17 18:29:42 2020 +0000
+++ b/sys/arch/aarch64/aarch64/cpuswitch.S Sun Jun 14 15:58:39 2020 +0000
@@ -538,3 +538,43 @@
str w9, [x0, #FPREG_FPSR]
ret
END(save_fpregs)
+
+ENTRY_NP(zero_fpregs)
+ eor v0.16b, v0.16b, v0.16b
+ eor v1.16b, v1.16b, v1.16b
+ eor v2.16b, v2.16b, v2.16b
+ eor v3.16b, v3.16b, v3.16b
+ eor v4.16b, v4.16b, v4.16b
+ eor v5.16b, v5.16b, v5.16b
+ eor v6.16b, v6.16b, v6.16b
+ eor v7.16b, v7.16b, v7.16b
+ eor v8.16b, v8.16b, v8.16b
+ eor v9.16b, v9.16b, v9.16b
+ eor v10.16b, v10.16b, v10.16b
+ eor v11.16b, v11.16b, v11.16b
+ eor v12.16b, v12.16b, v12.16b
+ eor v13.16b, v13.16b, v13.16b
+ eor v14.16b, v14.16b, v14.16b
+ eor v15.16b, v15.16b, v15.16b
+ eor v16.16b, v16.16b, v16.16b
+ eor v17.16b, v17.16b, v17.16b
+ eor v18.16b, v18.16b, v18.16b
+ eor v19.16b, v19.16b, v19.16b
+ eor v20.16b, v20.16b, v20.16b
+ eor v21.16b, v21.16b, v21.16b
+ eor v22.16b, v22.16b, v22.16b
+ eor v23.16b, v23.16b, v23.16b
+ eor v24.16b, v24.16b, v24.16b
+ eor v25.16b, v25.16b, v25.16b
+ eor v26.16b, v26.16b, v26.16b
+ eor v27.16b, v27.16b, v27.16b
+ eor v28.16b, v28.16b, v28.16b
+ eor v29.16b, v29.16b, v29.16b
+ eor v30.16b, v30.16b, v30.16b
+ eor v31.16b, v31.16b, v31.16b
+ eor x8, x8, x8
+ eor x9, x9, x9
+ msr fpcr, x8
+ msr fpsr, x9
+ ret
+END(zero_fpregs)
diff -r e83ef87e4f53 -r 782f3535bc9e sys/arch/aarch64/include/machdep.h
--- a/sys/arch/aarch64/include/machdep.h Wed Jun 17 18:29:42 2020 +0000
+++ b/sys/arch/aarch64/include/machdep.h Sun Jun 14 15:58:39 2020 +0000
@@ -144,6 +144,7 @@
struct fpreg;
void load_fpregs(const struct fpreg *);
void save_fpregs(struct fpreg *);
+void zero_fpregs(void);
#ifdef TRAP_SIGDEBUG
Home |
Main Index |
Thread Index |
Old Index