S12X: Does Reset Change the Stack Pointer?

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

S12X: Does Reset Change the Stack Pointer?

跳至解决方案
1,591 次查看
davekellogg
Contributor II

Using S12XE processor, and trying to track down the source of an infrequent COP time-out.

 

I know that the COP timeout forces a reset.  What I'd like to do in the COP ISR is look back at the stack frame when the COP occured, particularly the PC.  Of course, this will work only if the SP 's value is not changed by the reset.

 

So, is the stack pointer unchanged across a COP-induced reset?

 

Thanks!!

Dave Kellogg

标签 (1)
0 项奖励
回复
1 解答
1,322 次查看
GordonD
Contributor IV

Dave,

I checked with design and unfortunately, the stack pointer is reset (cleared) for any reset. This it a difficult problem and one that can generally only be solved with the use of a full in-circuit Emulator with external trace memory. However, the on-chip debug module (S12XDBG) could help you. It can be set up for "Pure PC mode" where all program counter addresses are stored in the trace buffer. Since a reset, other than a POR, does not affect the contents of the trace buffer or the DBGCNT register, the COP reset routine could look at the DBGCNT register and read the appropriate number of entries from the trace buffer.

This should allow you to determine where the code was executing when the COP reset occurred.

Best Regards,

Gordon

在原帖中查看解决方案

0 项奖励
回复
2 回复数
1,323 次查看
GordonD
Contributor IV

Dave,

I checked with design and unfortunately, the stack pointer is reset (cleared) for any reset. This it a difficult problem and one that can generally only be solved with the use of a full in-circuit Emulator with external trace memory. However, the on-chip debug module (S12XDBG) could help you. It can be set up for "Pure PC mode" where all program counter addresses are stored in the trace buffer. Since a reset, other than a POR, does not affect the contents of the trace buffer or the DBGCNT register, the COP reset routine could look at the DBGCNT register and read the appropriate number of entries from the trace buffer.

This should allow you to determine where the code was executing when the COP reset occurred.

Best Regards,

Gordon

0 项奖励
回复
1,322 次查看
davekellogg
Contributor II

Hi Gordon,

Thanks for your response and insight.  I had totally forgotten about the trace buffer.  The approach makes sense.  When I dragged out my old hard copy of the manual, I found a note I had written several years ago about this possiblity.

Dave Kellogg

0 项奖励
回复