diff options
| author | Russ Cox <rsc@swtch.com> | 2020-01-19 22:39:22 -0500 |
|---|---|---|
| committer | Russ Cox <rsc@swtch.com> | 2020-01-19 23:04:58 -0500 |
| commit | 41b3e8b9893a8561af7e85ca98444bc284b4013d (patch) | |
| tree | e9bf7fdeefbdb7d2e6c1ebc25c7888b81f0bb16b /src/libthread/power-ucontext.c | |
| parent | ac8042dfa9819f76ccfedd4aa36c1239322808b8 (diff) | |
| download | plan9port-41b3e8b9893a8561af7e85ca98444bc284b4013d.tar.gz plan9port-41b3e8b9893a8561af7e85ca98444bc284b4013d.zip | |
libthread: use consistent stack calculation code in makecontext
Also reduce duplication: makecontext is per-arch not per-os-arch.
May fix #353.
Diffstat (limited to 'src/libthread/power-ucontext.c')
| -rw-r--r-- | src/libthread/power-ucontext.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/libthread/power-ucontext.c b/src/libthread/power-ucontext.c new file mode 100644 index 00000000..32a8e931 --- /dev/null +++ b/src/libthread/power-ucontext.c @@ -0,0 +1,26 @@ +#include "threadimpl.h" + +void +makecontext(ucontext_t *ucp, void (*func)(void), int argc, ...) +{ + ulong *sp, *tos; + va_list arg; + + if(argc != 2) + sysfatal("libthread: makecontext misused"); + sp = USPALIGN(ucp, 16); + ucp->mc.pc = (long)func; + ucp->mc.sp = (long)sp; + va_start(arg, argc); + ucp->mc.r3 = va_arg(arg, long); + ucp->mc.r4 = va_arg(arg, long); + va_end(arg); +} + +int +swapcontext(ucontext_t *oucp, ucontext_t *ucp) +{ + if(getcontext(oucp) == 0) + setcontext(ucp); + return 0; +} |
