S12X stack pointer

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

S12X stack pointer

2,777 次查看
JohnBarber
Contributor II

Hi,

I would like to read the current value of the stack pointer from within my C-code. Is this possible?

 

I can't find the SP register in the S12X manual.

 

Regards

J

标签 (1)
5 回复数

2,042 次查看
kef
Specialist I

 

foo() 

{

  short stkptr;

 

    asm{  STS  stkptr }

}

 

If you want to check if SP isn't lower than some critical threshold, then just take address of function scope auto variable (on stack) and compare it.

 

foo() 

{

 void *stk;

 

   stk = &stk;

 

   if(stk < (void*)0x2000)

   {

      ...

   }

}

 

2,042 次查看
Lundin
Senior Contributor IV

Isn't there a risk that the optimizer will put "stk" into an index register? I'm not quite sure what would happen in that case, but I guess that you'd get the current content of the index register in return, ie rubbish.

 

I'd declare that pointer as volatile just to be on the safe side.

 

Also, I don't think C allows the cast from void** to void*. I would do like this instead:

 

foo() 
{
  volatile uint16_t stack;

 

  stack = (uint16_t) &stack;
 
  if(stack < 0x2000)
...

 

 

To be even more sure one can use a uint32_t as that will never fit into the D acc of the S12, and thereby can't be optimized.

0 项奖励
回复

2,042 次查看
kef
Specialist I

Unlike register variables, auto variables have the address. I don't think compiler has the right to replace real address of variable with something meaningless. I don't mind allocating auto variables in registers, I don't mind if stk isn't allocated on stack, but compare expression has to compare something meaningful, not random data because of too smart optimization.

 

Even with volatile, it is still rubbish, because C doesn't require stack at all. Compiler can allocate stk not in the stack space, like it is done in C compilers for PIC (PIC16, PIC18).

 

uint32_t doesn't help, because there are at least 3 16bits CPU registers, more than enough for uint32_t. Also optimizer may be too smart and ignore not used high order bits.

0 项奖励
回复

2,042 次查看
Lundin
Senior Contributor IV

Out of curiousity I disassembled the two examples. Both translate into the same code,

 

; with void*

LEAX 2,-SP
STX 0,SP
CPX #8192

 

; with integer
LEAX 2,-SP
STX 0,SP
LDX 0,SP
CPX #8192

 

 

After a  bit of research I also found out that the pointer cast is valid, just because it is a void pointer. Though to be picky, stk < (void*)0x2000) is undefined behavior in the C language, as the pointers don't point at the same aggregate.

0 项奖励
回复

2,044 次查看
JohnBarber
Contributor II

Thanks!

0 项奖励
回复