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/386 | |
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/386')
-rw-r--r-- | sys/src/ape/lib/ap/386/main9.s | 7 | ||||
-rw-r--r-- | sys/src/ape/lib/ap/386/main9p.s | 7 |
2 files changed, 10 insertions, 4 deletions
diff --git a/sys/src/ape/lib/ap/386/main9.s b/sys/src/ape/lib/ap/386/main9.s index a5f351df9..6b4a3189b 100644 --- a/sys/src/ape/lib/ap/386/main9.s +++ b/sys/src/ape/lib/ap/386/main9.s @@ -2,16 +2,19 @@ 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, $(12+4+128+NPRIVATES*4) /* _tos = arg */ MOVL AX, _tos(SB) LEAL 12(SP), AX MOVL AX, _errnoloc(SB) - LEAL 16(SP), AX + ADDL $4, AX + MOVL AX, _plan9err(SB) + ADDL $128, AX MOVL AX, _privates(SB) MOVL $NPRIVATES, _nprivates(SB) diff --git a/sys/src/ape/lib/ap/386/main9p.s b/sys/src/ape/lib/ap/386/main9p.s index 5d22c0f2e..bb272acd3 100644 --- a/sys/src/ape/lib/ap/386/main9p.s +++ b/sys/src/ape/lib/ap/386/main9p.s @@ -2,16 +2,19 @@ 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, $(12+4+128+NPRIVATES*4) /* _tos = arg */ MOVL AX, _tos(SB) LEAL 12(SP), AX MOVL AX, _errnoloc(SB) - LEAL 16(SP), AX + ADDL $4, AX + MOVL AX, _plan9err(SB) + ADDL $128, AX MOVL AX, _privates(SB) MOVL $NPRIVATES, _nprivates(SB) |