diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-05-04 00:23:48 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-05-04 00:23:48 +0200 |
commit | 14685d65958bed4d68b9c60564fa8d09aa746462 (patch) | |
tree | f2480af19061f27c67a36a2bb8fd7f41d047732a /sys/src/ape/lib/ap/mips | |
parent | 7657312dcf5b9435ff848b20dfc3a0546ab8a500 (diff) |
ape: return plan9 error strings from strerror()
when _syserrno() fails to map a plan9 error string to
a unix error number, we copy the plan9 error string
to the per process error buffer "plan9err" and set
errno = EPLAN9.
when strerror() is called with EPLAN9, it returns
a pointer to the plan9err buffer.
Diffstat (limited to 'sys/src/ape/lib/ap/mips')
-rw-r--r-- | sys/src/ape/lib/ap/mips/main9.s | 7 | ||||
-rw-r--r-- | sys/src/ape/lib/ap/mips/main9p.s | 9 |
2 files changed, 11 insertions, 5 deletions
diff --git a/sys/src/ape/lib/ap/mips/main9.s b/sys/src/ape/lib/ap/mips/main9.s index 12125fdb2..7e725f4c1 100644 --- a/sys/src/ape/lib/ap/mips/main9.s +++ b/sys/src/ape/lib/ap/mips/main9.s @@ -2,18 +2,21 @@ GLOBL _tos(SB), $4 GLOBL _errnoloc(SB), $4 +GLOBL _plan9err(SB), $4 GLOBL _privates(SB), $4 GLOBL _nprivates(SB), $4 -TEXT _main(SB), 1, $(16+NPRIVATES*4) +TEXT _main(SB), 1, $(16+4+128+NPRIVATES*4) MOVW $setR30(SB), R30 /* _tos = arg */ MOVW R1, _tos(SB) - MOVW $p-68(SP), R1 + MOVW $16(R29), R1 MOVW R1, _errnoloc(SB) ADDU $4, R1 + MOVW R1, _plan9err(SB) + ADDU $128, R1 MOVW R1, _privates(SB) MOVW $NPRIVATES, R1 MOVW R1, _nprivates(SB) diff --git a/sys/src/ape/lib/ap/mips/main9p.s b/sys/src/ape/lib/ap/mips/main9p.s index 1339b3267..f57a2a95c 100644 --- a/sys/src/ape/lib/ap/mips/main9p.s +++ b/sys/src/ape/lib/ap/mips/main9p.s @@ -2,20 +2,23 @@ GLOBL _tos(SB), $4 GLOBL _errnoloc(SB), $4 +GLOBL _plan9err(SB), $4 GLOBL _privates(SB), $4 GLOBL _nprivates(SB), $4 -TEXT _mainp(SB), 1, $(16+NPRIVATES*4) +TEXT _mainp(SB), 1, $(16+4+128+NPRIVATES*4) MOVW $setR30(SB), R30 /* _tos = arg */ MOVW R1, _tos(SB) - MOVW $p-68(SP), R1 + MOVW $16(R29), R1 MOVW R1, _errnoloc(SB) ADDU $4, R1 + MOVW R1, _plan9err(SB) + ADDU $128, R1 MOVW R1, _privates(SB) - MOVW $(NPRIVATES-1), R1 + MOVW $NPRIVATES, R1 MOVW R1, _nprivates(SB) /* _profmain(); */ |