ref: 7ab72c35e8ce3d7fc28ce0d1beced2fa6800423b
parent: 9ae1d0349c423d5451bbed6de8627dee3aec44a7
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Thu Jun 20 09:17:36 EDT 2019
bcm, kw, omap, teg2: implement setregisters()
--- a/sys/src/9/bcm/arch.c
+++ b/sys/src/9/bcm/arch.c
@@ -74,7 +74,9 @@
void
setregisters(Ureg* ureg, char* pureg, char* uva, int n)
{- USED(ureg, pureg, uva, n);
+ ulong v = ureg->psr;
+ memmove(pureg, uva, n);
+ ureg->psr = ureg->psr & ~(PsrMask|PsrDfiq|PsrDirq) | v & (PsrMask|PsrDfiq|PsrDirq);
}
/*
--- a/sys/src/9/kw/arch.c
+++ b/sys/src/9/kw/arch.c
@@ -74,7 +74,9 @@
void
setregisters(Ureg* ureg, char* pureg, char* uva, int n)
{- USED(ureg, pureg, uva, n);
+ ulong v = ureg->psr;
+ memmove(pureg, uva, n);
+ ureg->psr = ureg->psr & ~(PsrMask|PsrDfiq|PsrDirq) | v & (PsrMask|PsrDfiq|PsrDirq);
}
/*
--- a/sys/src/9/omap/arch.c
+++ b/sys/src/9/omap/arch.c
@@ -74,7 +74,9 @@
void
setregisters(Ureg* ureg, char* pureg, char* uva, int n)
{- USED(ureg, pureg, uva, n);
+ ulong v = ureg->psr;
+ memmove(pureg, uva, n);
+ ureg->psr = ureg->psr & ~(PsrMask|PsrDfiq|PsrDirq) | v & (PsrMask|PsrDfiq|PsrDirq);
}
/*
--- a/sys/src/9/teg2/arch.c
+++ b/sys/src/9/teg2/arch.c
@@ -74,7 +74,9 @@
void
setregisters(Ureg* ureg, char* pureg, char* uva, int n)
{- USED(ureg, pureg, uva, n);
+ ulong v = ureg->psr;
+ memmove(pureg, uva, n);
+ ureg->psr = ureg->psr & ~(PsrMask|PsrDfiq|PsrDirq) | v & (PsrMask|PsrDfiq|PsrDirq);
}
/*
--
⑨