* Exception handlers get overwritten
@ 2001-05-15 22:11 Tommy S. Christensen
2001-05-15 23:48 ` Kevin D. Kissell
2001-05-16 12:08 ` Exception handlers get overwritten, and more than you ever wanted to know about EJTAG Kevin D. Kissell
0 siblings, 2 replies; 6+ messages in thread
From: Tommy S. Christensen @ 2001-05-15 22:11 UTC (permalink / raw)
To: linux-mips
With LOADADDR set to 0x80000000, except_vec0_r4600 and
except_vec0_nevada are overwritten in trap_init() before they
get installed at KSEG0.
The fix is easy:
diff -u -r1.53 traps.c
--- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53
+++ arch/mips/kernel/traps.c 2001/05/15 21:39:56
@@ -837,7 +837,9 @@
* Copy the EJTAG debug exception vector handler code to it's
final
* destination.
*/
+#ifdef WHONEEDSTLB
memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80);
+#endif
/*
* Only some CPUs have the watch exceptions or a dedicated
OK, a kinder fix would be something like:
diff -u -r1.25 head.S
--- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25
+++ arch/mips/kernel/head.S 2001/05/15 21:39:40
@@ -44,7 +44,7 @@
* FIXME: Use the initcode feature to get rid of unused handler
* variants.
*/
- .fill 0x280
+ .fill 0x380
/*
* This is space for the interrupt handlers.
* After trap_init() they are located at virtual address KSEG0.
I wonder why this never hit anybody else ...
Regards,
Tommy Christensen
^ permalink raw reply [flat|nested] 6+ messages in thread* Re: Exception handlers get overwritten 2001-05-15 22:11 Exception handlers get overwritten Tommy S. Christensen @ 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-16 6:56 ` Carsten Langgaard 2001-05-16 12:08 ` Exception handlers get overwritten, and more than you ever wanted to know about EJTAG Kevin D. Kissell 1 sibling, 2 replies; 6+ messages in thread From: Kevin D. Kissell @ 2001-05-15 23:48 UTC (permalink / raw) To: Tommy S. Christensen, linux-mips I don't know who checked in the EJTAG vector stuff, but a few words of explanation and advice are in order. MIPS32/MIPS64 CPUs have optional support for EJTAG, which introduces a "Debug" mode of execution which is similar to, but not identical to, Kernel mode. The only way into Debug mode is to take a Debug exception - not to be confused with a breakpoint or watchpoint exception. These are caused either by EJTAG hardware breakpoints being hit, or by an external assertion on the EJTAG interface. When the CPU enters Debug mode, it transfers either to a location in the EJTAG pseudo memory (an overlay of high physical memory that maps to packet transactions on the JTAG interface) or to the boot ROM vector area. They can never vector directly to the 0x80000000 page! Now, since the hardware breakpoint channels are potentially a cool feature to be able to exploit from an OS - they allow breakpoints in ROM code, for example - I once prototyped and debugged the necessary code in OpenBSD to allow the kernel to be invoked from a Debug exception, and to allow the kernel to "call down" into the Debug mode code to set breakpoints, etc.. To do this, one *must* have support in the boot ROM of the platform. The boot ROM exception vector can take advantage of the EJTAG scratch register to save enough context to transfer control, intact, to a pseudo-vector in the OS vector page (one of those rare occasions where the jump delay slot is a lifesaver). The location of that pseudo-vector is purely a software convention, and should be chosen to be beyond *any* hardware vectors, including those for the MIPS32/64 and Nevada dedicated hardware interrupt vectors. I've been meaning for some time now to re-implement the OpenBSD EJTAG hooks in Linux, but have simply never had the time. It sounds like someone else has started down that path without having looked at all the issues. I'll try to dig out my old example ROM vector code and post it to the newsgroup (it's only a few lines), along with the EJTAG kernel interface code from OpenBSD to serve as an example. Kevin K. ----- Original Message ----- From: "Tommy S. Christensen" <tommy.christensen@eicon.com> To: <linux-mips@oss.sgi.com> Sent: Wednesday, May 16, 2001 12:11 AM Subject: Exception handlers get overwritten > With LOADADDR set to 0x80000000, except_vec0_r4600 and > except_vec0_nevada are overwritten in trap_init() before they > get installed at KSEG0. > > The fix is easy: > > diff -u -r1.53 traps.c > --- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53 > +++ arch/mips/kernel/traps.c 2001/05/15 21:39:56 > @@ -837,7 +837,9 @@ > * Copy the EJTAG debug exception vector handler code to it's > final > * destination. > */ > +#ifdef WHONEEDSTLB > memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80); > +#endif > > /* > * Only some CPUs have the watch exceptions or a dedicated > > > OK, a kinder fix would be something like: > > diff -u -r1.25 head.S > --- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25 > +++ arch/mips/kernel/head.S 2001/05/15 21:39:40 > @@ -44,7 +44,7 @@ > * FIXME: Use the initcode feature to get rid of unused handler > * variants. > */ > - .fill 0x280 > + .fill 0x380 > /* > * This is space for the interrupt handlers. > * After trap_init() they are located at virtual address KSEG0. > > > I wonder why this never hit anybody else ... > > Regards, > Tommy Christensen ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Exception handlers get overwritten 2001-05-15 23:48 ` Kevin D. Kissell @ 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-16 6:56 ` Carsten Langgaard 1 sibling, 0 replies; 6+ messages in thread From: Kevin D. Kissell @ 2001-05-15 23:48 UTC (permalink / raw) To: Tommy S. Christensen, linux-mips I don't know who checked in the EJTAG vector stuff, but a few words of explanation and advice are in order. MIPS32/MIPS64 CPUs have optional support for EJTAG, which introduces a "Debug" mode of execution which is similar to, but not identical to, Kernel mode. The only way into Debug mode is to take a Debug exception - not to be confused with a breakpoint or watchpoint exception. These are caused either by EJTAG hardware breakpoints being hit, or by an external assertion on the EJTAG interface. When the CPU enters Debug mode, it transfers either to a location in the EJTAG pseudo memory (an overlay of high physical memory that maps to packet transactions on the JTAG interface) or to the boot ROM vector area. They can never vector directly to the 0x80000000 page! Now, since the hardware breakpoint channels are potentially a cool feature to be able to exploit from an OS - they allow breakpoints in ROM code, for example - I once prototyped and debugged the necessary code in OpenBSD to allow the kernel to be invoked from a Debug exception, and to allow the kernel to "call down" into the Debug mode code to set breakpoints, etc.. To do this, one *must* have support in the boot ROM of the platform. The boot ROM exception vector can take advantage of the EJTAG scratch register to save enough context to transfer control, intact, to a pseudo-vector in the OS vector page (one of those rare occasions where the jump delay slot is a lifesaver). The location of that pseudo-vector is purely a software convention, and should be chosen to be beyond *any* hardware vectors, including those for the MIPS32/64 and Nevada dedicated hardware interrupt vectors. I've been meaning for some time now to re-implement the OpenBSD EJTAG hooks in Linux, but have simply never had the time. It sounds like someone else has started down that path without having looked at all the issues. I'll try to dig out my old example ROM vector code and post it to the newsgroup (it's only a few lines), along with the EJTAG kernel interface code from OpenBSD to serve as an example. Kevin K. ----- Original Message ----- From: "Tommy S. Christensen" <tommy.christensen@eicon.com> To: <linux-mips@oss.sgi.com> Sent: Wednesday, May 16, 2001 12:11 AM Subject: Exception handlers get overwritten > With LOADADDR set to 0x80000000, except_vec0_r4600 and > except_vec0_nevada are overwritten in trap_init() before they > get installed at KSEG0. > > The fix is easy: > > diff -u -r1.53 traps.c > --- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53 > +++ arch/mips/kernel/traps.c 2001/05/15 21:39:56 > @@ -837,7 +837,9 @@ > * Copy the EJTAG debug exception vector handler code to it's > final > * destination. > */ > +#ifdef WHONEEDSTLB > memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80); > +#endif > > /* > * Only some CPUs have the watch exceptions or a dedicated > > > OK, a kinder fix would be something like: > > diff -u -r1.25 head.S > --- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25 > +++ arch/mips/kernel/head.S 2001/05/15 21:39:40 > @@ -44,7 +44,7 @@ > * FIXME: Use the initcode feature to get rid of unused handler > * variants. > */ > - .fill 0x280 > + .fill 0x380 > /* > * This is space for the interrupt handlers. > * After trap_init() they are located at virtual address KSEG0. > > > I wonder why this never hit anybody else ... > > Regards, > Tommy Christensen ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Exception handlers get overwritten 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-15 23:48 ` Kevin D. Kissell @ 2001-05-16 6:56 ` Carsten Langgaard 1 sibling, 0 replies; 6+ messages in thread From: Carsten Langgaard @ 2001-05-16 6:56 UTC (permalink / raw) To: Kevin D. Kissell; +Cc: Tommy S. Christensen, linux-mips I added the EJTAG stuff, what is does is simply to return to the place where the EJTAG break point was taken. It doesn't do anything, but simply report that a EJTAG exception has been taken and then returns. The EJTAG handler has been added to avoid user application, such as crashme, will crash the kernel. I don't think there are anything wrong with the handler, except that you need the fix that Tommy suggest if you are linking your code to address 0x80000000, which only very few does. I believe this has been reported before, so I actually thought it was fixed. /Carsten "Kevin D. Kissell" wrote: > I don't know who checked in the EJTAG vector stuff, > but a few words of explanation and advice are in order. > MIPS32/MIPS64 CPUs have optional support for > EJTAG, which introduces a "Debug" mode of > execution which is similar to, but not identical to, > Kernel mode. The only way into Debug mode is > to take a Debug exception - not to be confused with > a breakpoint or watchpoint exception. These are > caused either by EJTAG hardware breakpoints > being hit, or by an external assertion on the EJTAG > interface. When the CPU enters Debug mode, it > transfers either to a location in the EJTAG pseudo > memory (an overlay of high physical memory that > maps to packet transactions on the JTAG interface) > or to the boot ROM vector area. They can never > vector directly to the 0x80000000 page! > > Now, since the hardware breakpoint channels are > potentially a cool feature to be able to exploit from > an OS - they allow breakpoints in ROM code, for > example - I once prototyped and debugged the necessary > code in OpenBSD to allow the kernel to be invoked > from a Debug exception, and to allow the kernel to > "call down" into the Debug mode code to set breakpoints, > etc.. To do this, one *must* have support in the boot > ROM of the platform. The boot ROM exception vector > can take advantage of the EJTAG scratch register to > save enough context to transfer control, intact, to > a pseudo-vector in the OS vector page (one of those > rare occasions where the jump delay slot is a lifesaver). > The location of that pseudo-vector is purely a software > convention, and should be chosen to be beyond *any* > hardware vectors, including those for the MIPS32/64 > and Nevada dedicated hardware interrupt vectors. > > I've been meaning for some time now to re-implement > the OpenBSD EJTAG hooks in Linux, but have simply > never had the time. It sounds like someone else has > started down that path without having looked at all the > issues. I'll try to dig out my old example ROM vector code > and post it to the newsgroup (it's only a few lines), along > with the EJTAG kernel interface code from OpenBSD > to serve as an example. > > Kevin K. > > ----- Original Message ----- > From: "Tommy S. Christensen" <tommy.christensen@eicon.com> > To: <linux-mips@oss.sgi.com> > Sent: Wednesday, May 16, 2001 12:11 AM > Subject: Exception handlers get overwritten > > > With LOADADDR set to 0x80000000, except_vec0_r4600 and > > except_vec0_nevada are overwritten in trap_init() before they > > get installed at KSEG0. > > > > The fix is easy: > > > > diff -u -r1.53 traps.c > > --- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53 > > +++ arch/mips/kernel/traps.c 2001/05/15 21:39:56 > > @@ -837,7 +837,9 @@ > > * Copy the EJTAG debug exception vector handler code to it's > > final > > * destination. > > */ > > +#ifdef WHONEEDSTLB > > memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80); > > +#endif > > > > /* > > * Only some CPUs have the watch exceptions or a dedicated > > > > > > OK, a kinder fix would be something like: > > > > diff -u -r1.25 head.S > > --- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25 > > +++ arch/mips/kernel/head.S 2001/05/15 21:39:40 > > @@ -44,7 +44,7 @@ > > * FIXME: Use the initcode feature to get rid of unused handler > > * variants. > > */ > > - .fill 0x280 > > + .fill 0x380 > > /* > > * This is space for the interrupt handlers. > > * After trap_init() they are located at virtual address KSEG0. > > > > > > I wonder why this never hit anybody else ... > > > > Regards, > > Tommy Christensen -- _ _ ____ ___ Carsten Langgaard Mailto:carstenl@mips.com |\ /|||___)(___ MIPS Denmark Direct: +45 4486 5527 | \/ ||| ____) Lautrupvang 4B Switch: +45 4486 5555 TECHNOLOGIES 2750 Ballerup Fax...: +45 4486 5556 Denmark http://www.mips.com ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Exception handlers get overwritten, and more than you ever wanted to know about EJTAG 2001-05-15 22:11 Exception handlers get overwritten Tommy S. Christensen 2001-05-15 23:48 ` Kevin D. Kissell @ 2001-05-16 12:08 ` Kevin D. Kissell 2001-05-16 12:08 ` Kevin D. Kissell 1 sibling, 1 reply; 6+ messages in thread From: Kevin D. Kissell @ 2001-05-16 12:08 UTC (permalink / raw) To: Tommy S. Christensen, linux-mips My previous response was written at almost 2AM local time, and I was too tired to go find my archives from May 1999 before responding. I was also too tired to fully understand the nature of the bug Tommy was describing. I took it to mean that the installation of the EJTAG KSEG0 vector was overwriting other installed vectors - which seems not to be the case. By the light of day, I take it that the problem is in fact that the *templates* for the exception vectors are linked into the kernel image starting at location 0x80000280, and that therefore the installation of the EJTAG pseudo-vector was overwriting them *before* they could be installed. In any case, Carsten had of course correctly installed the pseudo-vector at the location that we adoped at MIPS, 0x80000300. The fix is not to get rid of it, but as noted, to make an allowance for it in the .fill directive at the beginning of the module. I would actually recommend that EJTAG support be a configure-able option, and in that case the .fill selected could be a function of wheter EJTAG support will be provided. It seems to me, however, that the problem could also be solved by installing the vectors in the right order - if the EJTAG vector had been installed at 0x80000300 *after* the excep_vec0 had been copied into place, it wouldn't have mattered. So long as the vectors are both assembled and installed in order of ascending vector addresses, one should be able to pack them in the linked binary with a .fill just big enough to allow for the largest excep_vec0. I don't know that the increased risk of miscalculation is worth the savings of a few hundred bytes, though. To get back to the issue of EJTAG support, for those of you who are interested (and who are building platforms around chips that support EJTAG), the actual hardware vector used for Debug exceptions when there is no probe attached is 0xbfc00480. The code to transfer control to a pseudo-vector at 0x80000300 looks like this (the choice of temporary register is arbitrary, but I actually recommend against using k0 or k1). .noreorder (!) 0xbfc00480 mtc0 t0,COP_O_DESAVE 0xbfc00484 lui t0,0x8000 0xbfc00488 ori t0,0x0300 0xbfc0048c jr t0 0xbfc00490 mfc0 t0,COP_0_DESAVE One important thing to understand about Debug exceptions is that, while there are restrictions on how they can nest, they can otherwise occur at *any* time. Which is to say, even if EXL is set in the Status register. Which is to say, even in the middle of a TLB miss or interrupt handler. So the Debug exception handler cannot use the kernel stack, nor should it be premitted to modify any kernel data structure directly. The pre-exception context must be saved and restored from *somewhere*, and there is the further subtlety that, depending on whether or not a probe is attached, the context save RAM may be on-board or on-probe. Now, the Debug exception handler can know whether it was entered via a probe memory vector or a ROM vector, so in the OpenBSD code, I created a convention whereby the word immediately preceding the hardware vector (0xbfc0047c in the case of the ROM vector) contains a pointer to a pointer to a context save block. Why a pointer-to-a-pointer? Because a Debug exception handler can explicitly allow itself to nest, and it is far more efficient to update a pointer in RAM to the next block than it would be to copy the saved contexts around. While the pointer to the context save block is modifiable, the pointer-to-the-pointer in ROM is not, and requires yet another software convention. For OpenBSD, I chose to put the RAM pointer in the word immediately preceding the RAM pseudo-vector, wich is to say 0xbfc0047c contains the value 0x800002fc, and the startup code (or even the kernel linkage, if one wanted to be EJTAG-sane from the moment the image is loaded) needs to see to it that 0x800002fc points to a reserved block of RAM big enough to hold the register set, etc. The debug handler, if it wants to allow for reentrancy, must update 0x800002fc to point to a clean save block before allowing any further exceptions. 0xbfc00480 is fixed by hardware, but the other conventions - pseudo-vector at 0x80000300, pointer-to-pointer at 0xbfc0047c, pointer-to-context at 0x800002fc - are software conventions. If anyone on this list sees problems, or a better way to do things, speak now "or forever hold your peace". Regards, Kevin K. ----- Original Message ----- From: "Tommy S. Christensen" <tommy.christensen@eicon.com> To: <linux-mips@oss.sgi.com> Sent: Wednesday, May 16, 2001 12:11 AM Subject: Exception handlers get overwritten > With LOADADDR set to 0x80000000, except_vec0_r4600 and > except_vec0_nevada are overwritten in trap_init() before they > get installed at KSEG0. > > The fix is easy: > > diff -u -r1.53 traps.c > --- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53 > +++ arch/mips/kernel/traps.c 2001/05/15 21:39:56 > @@ -837,7 +837,9 @@ > * Copy the EJTAG debug exception vector handler code to it's > final > * destination. > */ > +#ifdef WHONEEDSTLB > memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80); > +#endif > > /* > * Only some CPUs have the watch exceptions or a dedicated > > > OK, a kinder fix would be something like: > > diff -u -r1.25 head.S > --- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25 > +++ arch/mips/kernel/head.S 2001/05/15 21:39:40 > @@ -44,7 +44,7 @@ > * FIXME: Use the initcode feature to get rid of unused handler > * variants. > */ > - .fill 0x280 > + .fill 0x380 > /* > * This is space for the interrupt handlers. > * After trap_init() they are located at virtual address KSEG0. > > > I wonder why this never hit anybody else ... > > Regards, > Tommy Christensen ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Exception handlers get overwritten, and more than you ever wanted to know about EJTAG 2001-05-16 12:08 ` Exception handlers get overwritten, and more than you ever wanted to know about EJTAG Kevin D. Kissell @ 2001-05-16 12:08 ` Kevin D. Kissell 0 siblings, 0 replies; 6+ messages in thread From: Kevin D. Kissell @ 2001-05-16 12:08 UTC (permalink / raw) To: Tommy S. Christensen, linux-mips My previous response was written at almost 2AM local time, and I was too tired to go find my archives from May 1999 before responding. I was also too tired to fully understand the nature of the bug Tommy was describing. I took it to mean that the installation of the EJTAG KSEG0 vector was overwriting other installed vectors - which seems not to be the case. By the light of day, I take it that the problem is in fact that the *templates* for the exception vectors are linked into the kernel image starting at location 0x80000280, and that therefore the installation of the EJTAG pseudo-vector was overwriting them *before* they could be installed. In any case, Carsten had of course correctly installed the pseudo-vector at the location that we adoped at MIPS, 0x80000300. The fix is not to get rid of it, but as noted, to make an allowance for it in the .fill directive at the beginning of the module. I would actually recommend that EJTAG support be a configure-able option, and in that case the .fill selected could be a function of wheter EJTAG support will be provided. It seems to me, however, that the problem could also be solved by installing the vectors in the right order - if the EJTAG vector had been installed at 0x80000300 *after* the excep_vec0 had been copied into place, it wouldn't have mattered. So long as the vectors are both assembled and installed in order of ascending vector addresses, one should be able to pack them in the linked binary with a .fill just big enough to allow for the largest excep_vec0. I don't know that the increased risk of miscalculation is worth the savings of a few hundred bytes, though. To get back to the issue of EJTAG support, for those of you who are interested (and who are building platforms around chips that support EJTAG), the actual hardware vector used for Debug exceptions when there is no probe attached is 0xbfc00480. The code to transfer control to a pseudo-vector at 0x80000300 looks like this (the choice of temporary register is arbitrary, but I actually recommend against using k0 or k1). .noreorder (!) 0xbfc00480 mtc0 t0,COP_O_DESAVE 0xbfc00484 lui t0,0x8000 0xbfc00488 ori t0,0x0300 0xbfc0048c jr t0 0xbfc00490 mfc0 t0,COP_0_DESAVE One important thing to understand about Debug exceptions is that, while there are restrictions on how they can nest, they can otherwise occur at *any* time. Which is to say, even if EXL is set in the Status register. Which is to say, even in the middle of a TLB miss or interrupt handler. So the Debug exception handler cannot use the kernel stack, nor should it be premitted to modify any kernel data structure directly. The pre-exception context must be saved and restored from *somewhere*, and there is the further subtlety that, depending on whether or not a probe is attached, the context save RAM may be on-board or on-probe. Now, the Debug exception handler can know whether it was entered via a probe memory vector or a ROM vector, so in the OpenBSD code, I created a convention whereby the word immediately preceding the hardware vector (0xbfc0047c in the case of the ROM vector) contains a pointer to a pointer to a context save block. Why a pointer-to-a-pointer? Because a Debug exception handler can explicitly allow itself to nest, and it is far more efficient to update a pointer in RAM to the next block than it would be to copy the saved contexts around. While the pointer to the context save block is modifiable, the pointer-to-the-pointer in ROM is not, and requires yet another software convention. For OpenBSD, I chose to put the RAM pointer in the word immediately preceding the RAM pseudo-vector, wich is to say 0xbfc0047c contains the value 0x800002fc, and the startup code (or even the kernel linkage, if one wanted to be EJTAG-sane from the moment the image is loaded) needs to see to it that 0x800002fc points to a reserved block of RAM big enough to hold the register set, etc. The debug handler, if it wants to allow for reentrancy, must update 0x800002fc to point to a clean save block before allowing any further exceptions. 0xbfc00480 is fixed by hardware, but the other conventions - pseudo-vector at 0x80000300, pointer-to-pointer at 0xbfc0047c, pointer-to-context at 0x800002fc - are software conventions. If anyone on this list sees problems, or a better way to do things, speak now "or forever hold your peace". Regards, Kevin K. ----- Original Message ----- From: "Tommy S. Christensen" <tommy.christensen@eicon.com> To: <linux-mips@oss.sgi.com> Sent: Wednesday, May 16, 2001 12:11 AM Subject: Exception handlers get overwritten > With LOADADDR set to 0x80000000, except_vec0_r4600 and > except_vec0_nevada are overwritten in trap_init() before they > get installed at KSEG0. > > The fix is easy: > > diff -u -r1.53 traps.c > --- arch/mips/kernel/traps.c 2001/04/08 13:24:27 1.53 > +++ arch/mips/kernel/traps.c 2001/05/15 21:39:56 > @@ -837,7 +837,9 @@ > * Copy the EJTAG debug exception vector handler code to it's > final > * destination. > */ > +#ifdef WHONEEDSTLB > memcpy((void *)(KSEG0 + 0x300), &except_vec_ejtag_debug, 0x80); > +#endif > > /* > * Only some CPUs have the watch exceptions or a dedicated > > > OK, a kinder fix would be something like: > > diff -u -r1.25 head.S > --- arch/mips/kernel/head.S 2001/05/04 20:43:25 1.25 > +++ arch/mips/kernel/head.S 2001/05/15 21:39:40 > @@ -44,7 +44,7 @@ > * FIXME: Use the initcode feature to get rid of unused handler > * variants. > */ > - .fill 0x280 > + .fill 0x380 > /* > * This is space for the interrupt handlers. > * After trap_init() they are located at virtual address KSEG0. > > > I wonder why this never hit anybody else ... > > Regards, > Tommy Christensen ^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2001-05-16 12:08 UTC | newest] Thread overview: 6+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2001-05-15 22:11 Exception handlers get overwritten Tommy S. Christensen 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-15 23:48 ` Kevin D. Kissell 2001-05-16 6:56 ` Carsten Langgaard 2001-05-16 12:08 ` Exception handlers get overwritten, and more than you ever wanted to know about EJTAG Kevin D. Kissell 2001-05-16 12:08 ` Kevin D. Kissell
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox