Fix some comments.
Set up stack frames in copyin/copyout and friends (if DDB is defined) so that ddb stack traces can trace through them.
This commit is contained in:
parent
7c18481cf2
commit
2bce28091c
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: locore_subr.S,v 1.17 2003/03/13 13:44:19 scw Exp $ */
|
/* $NetBSD: locore_subr.S,v 1.18 2003/03/19 11:34:28 scw Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2002 Wasabi Systems, Inc.
|
* Copyright 2002 Wasabi Systems, Inc.
|
||||||
@ -64,8 +64,6 @@
|
|||||||
Lsh5_init_env:
|
Lsh5_init_env:
|
||||||
/*
|
/*
|
||||||
* Fix up the vector table.
|
* Fix up the vector table.
|
||||||
* Note: For now, we don't touch RESVEC on the assumption that
|
|
||||||
* a ROM-based debugger is being used.
|
|
||||||
*/
|
*/
|
||||||
LEA(_C_LABEL(sh5_vector_table), r0)
|
LEA(_C_LABEL(sh5_vector_table), r0)
|
||||||
putcon r0, vbr
|
putcon r0, vbr
|
||||||
@ -82,6 +80,8 @@ Lsh5_init_env:
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* If we have an FPU, ensure it's quiescent
|
* If we have an FPU, ensure it's quiescent
|
||||||
|
* XXX: The kernel currently requires an FPU for certain
|
||||||
|
* operations.
|
||||||
*/
|
*/
|
||||||
getcon sr, r0
|
getcon sr, r0
|
||||||
pta/u 1f, tr0
|
pta/u 1f, tr0
|
||||||
@ -342,7 +342,11 @@ ENTRY_NOPROFILE(splraise)
|
|||||||
* r2 r3 r4
|
* r2 r3 r4
|
||||||
*/
|
*/
|
||||||
ENTRY(copyout)
|
ENTRY(copyout)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
add r18, r63, r61
|
add r18, r63, r61
|
||||||
|
#endif
|
||||||
movi EFAULT, r60 /* Assume there was a problem */
|
movi EFAULT, r60 /* Assume there was a problem */
|
||||||
pta/u Lcopyexit, tr1
|
pta/u Lcopyexit, tr1
|
||||||
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
||||||
@ -404,7 +408,11 @@ ENTRY(copyout)
|
|||||||
* r2 r3 r4
|
* r2 r3 r4
|
||||||
*/
|
*/
|
||||||
ENTRY(copyin)
|
ENTRY(copyin)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
add r18, r63, r61
|
add r18, r63, r61
|
||||||
|
#endif
|
||||||
movi EFAULT, r60 /* Assume there was a problem */
|
movi EFAULT, r60 /* Assume there was a problem */
|
||||||
pta/u Lcopyexit, tr1
|
pta/u Lcopyexit, tr1
|
||||||
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
||||||
@ -461,7 +469,12 @@ Lcopyerr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r63 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r63 /* Clear pcb_onfault */
|
||||||
Lcopyexit:
|
Lcopyexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#else
|
||||||
ptabs/l r61, tr0
|
ptabs/l r61, tr0
|
||||||
|
#endif
|
||||||
or r60, r63, r2 /* Copy error code */
|
or r60, r63, r2 /* Copy error code */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -473,7 +486,11 @@ Lcopyexit:
|
|||||||
* r2 r3 r4 r5
|
* r2 r3 r4 r5
|
||||||
*/
|
*/
|
||||||
ENTRY(copyoutstr)
|
ENTRY(copyoutstr)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/u r18, tr0
|
ptabs/u r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lcopystrerr, tr3
|
pta/u Lcopystrerr, tr3
|
||||||
movi EFAULT, r6 /* Assume the worst */
|
movi EFAULT, r6 /* Assume the worst */
|
||||||
movi 0, r7
|
movi 0, r7
|
||||||
@ -518,7 +535,11 @@ ENTRY(copyoutstr)
|
|||||||
* r2 r3 r4 r5
|
* r2 r3 r4 r5
|
||||||
*/
|
*/
|
||||||
ENTRY(copyinstr)
|
ENTRY(copyinstr)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/u r18, tr0
|
ptabs/u r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lcopystrerr, tr3
|
pta/u Lcopystrerr, tr3
|
||||||
movi EFAULT, r6 /* Assume the worst */
|
movi EFAULT, r6 /* Assume the worst */
|
||||||
movi 0, r7
|
movi 0, r7
|
||||||
@ -563,6 +584,10 @@ Lcopystrerr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r63 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r63 /* Clear pcb_onfault */
|
||||||
or r6, r63, r2 /* Grab return code */
|
or r6, r63, r2 /* Grab return code */
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
beq/u r5, r63, tr0 /* Just return if "done" == NULL */
|
beq/u r5, r63, tr0 /* Just return if "done" == NULL */
|
||||||
STPTR r5, 0, r7 /* NOTE: sizeof(size_t) = sizeof(ptr) */
|
STPTR r5, 0, r7 /* NOTE: sizeof(size_t) = sizeof(ptr) */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
@ -600,7 +625,11 @@ ENTRY(copystr)
|
|||||||
* r2 r3 r4
|
* r2 r3 r4
|
||||||
*/
|
*/
|
||||||
ENTRY(kcopy)
|
ENTRY(kcopy)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
add r18, r63, r61
|
add r18, r63, r61
|
||||||
|
#endif
|
||||||
movi EFAULT, r60 /* Assume there was a problem */
|
movi EFAULT, r60 /* Assume there was a problem */
|
||||||
pta/u Lkcopyexit, tr1
|
pta/u Lkcopyexit, tr1
|
||||||
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
bge/u r63, r4, tr1 /* Return EFAULT if len <= 0 */
|
||||||
@ -654,7 +683,12 @@ Lkcopyerr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r6 /* Restore pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r6 /* Restore pcb_onfault */
|
||||||
Lkcopyexit:
|
Lkcopyexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#else
|
||||||
ptabs/l r61, tr0
|
ptabs/l r61, tr0
|
||||||
|
#endif
|
||||||
or r60, r63, r2 /* Copy error code */
|
or r60, r63, r2 /* Copy error code */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -668,7 +702,11 @@ Lkcopyexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(subyte)
|
ENTRY(subyte)
|
||||||
ALTENTRY(suibyte)
|
ALTENTRY(suibyte)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lsubexit, tr1
|
pta/u Lsubexit, tr1
|
||||||
movi EFAULT, r5 /* Assume there was a problem */
|
movi EFAULT, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -690,6 +728,10 @@ Lsuberr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lsubexit:
|
Lsubexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy error code */
|
or r5, r63, r2 /* Copy error code */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -703,7 +745,11 @@ Lsubexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(susword)
|
ENTRY(susword)
|
||||||
ALTENTRY(suisword)
|
ALTENTRY(suisword)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lsusexit, tr1
|
pta/u Lsusexit, tr1
|
||||||
movi EFAULT, r5 /* Assume there was a problem */
|
movi EFAULT, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -725,6 +771,10 @@ Lsuserr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lsusexit:
|
Lsusexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy error code */
|
or r5, r63, r2 /* Copy error code */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -738,7 +788,11 @@ Lsusexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(suword)
|
ENTRY(suword)
|
||||||
ALTENTRY(suiword)
|
ALTENTRY(suiword)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lsuwexit, tr1
|
pta/u Lsuwexit, tr1
|
||||||
movi EFAULT, r5 /* Assume there was a problem */
|
movi EFAULT, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -760,6 +814,10 @@ Lsuwerr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lsuwexit:
|
Lsuwexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy error code */
|
or r5, r63, r2 /* Copy error code */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -773,7 +831,11 @@ Lsuwexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(fubyte)
|
ENTRY(fubyte)
|
||||||
ALTENTRY(fuibyte)
|
ALTENTRY(fuibyte)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lfubexit, tr1
|
pta/u Lfubexit, tr1
|
||||||
movi -1, r5 /* Assume there was a problem */
|
movi -1, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -794,6 +856,10 @@ Lfuberr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lfubexit:
|
Lfubexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy result */
|
or r5, r63, r2 /* Copy result */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -807,7 +873,11 @@ Lfubexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(fusword)
|
ENTRY(fusword)
|
||||||
ALTENTRY(fuisword)
|
ALTENTRY(fuisword)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lfusexit, tr1
|
pta/u Lfusexit, tr1
|
||||||
movi -1, r5 /* Assume there was a problem */
|
movi -1, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -828,6 +898,10 @@ Lfuserr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lfusexit:
|
Lfusexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy result */
|
or r5, r63, r2 /* Copy result */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
@ -841,7 +915,11 @@ Lfusexit:
|
|||||||
*/
|
*/
|
||||||
ENTRY(fuword)
|
ENTRY(fuword)
|
||||||
ALTENTRY(fuiword)
|
ALTENTRY(fuiword)
|
||||||
|
#ifdef DDB
|
||||||
|
LINK_FRAME(0)
|
||||||
|
#else
|
||||||
ptabs/l r18, tr0
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
pta/u Lfuwexit, tr1
|
pta/u Lfuwexit, tr1
|
||||||
movi -1, r5 /* Assume there was a problem */
|
movi -1, r5 /* Assume there was a problem */
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
@ -862,6 +940,10 @@ Lfuwerr:
|
|||||||
LDPTR r0, CI_CURPCB, r0
|
LDPTR r0, CI_CURPCB, r0
|
||||||
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
STPTR r0, PCB_ONFAULT, r8 /* Clear pcb_onfault */
|
||||||
Lfuwexit:
|
Lfuwexit:
|
||||||
|
#ifdef DDB
|
||||||
|
UNLINK_FRAME(0)
|
||||||
|
ptabs/l r18, tr0
|
||||||
|
#endif
|
||||||
or r5, r63, r2 /* Copy result */
|
or r5, r63, r2 /* Copy result */
|
||||||
blink tr0, r63
|
blink tr0, r63
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user