Hardfault handler - pointer pointing to an address

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

Hardfault handler - pointer pointing to an address

1,503 次查看
lpcware
NXP Employee
NXP Employee
Content originally posted in LPCWare by jonotree on Mon Oct 27 10:02:51 MST 2014
I've got some strange problems..

I am using an LPC1778, and running into the hard fault handler when I run though my program in debug mode, but not if I step through it. I'm using keil uvision v4)

If the program is run, the hard fault handler gets entered during this function (I can see from the 'call stack + locals' window):

/*Moves string pointer to next occurence of token */
UINT8 bytesUntilNext(UINT8_PTR ptr, char token, UINT8_PTR bufferStart)
{
UINT8 bytesToNextWantedChar = 0;
UINT8_PTR original = ptr;
while((*ptr != token) && (bytesToNextWantedChar < 100))
{
ptr = goThruCircleBuffer(bufferStart, ptr, 1);
bytesToNextWantedChar++;
        }
  }

Due to the argument ptr, coming in pointing to the address 0x1100 0044.
As far as I understand, this is most likely causing the hard fault error because that address is in the 'reserved' sector of memory according to the device user manual (UM10470, pg 879 figure 171 'Map of Lower Memory').
so its not really allowed to use a pointer pointing to it. 

As stated before, this doesn't happen when I step through the program rather than running it. If the program is stepped through, when I reach this function, the address to which ptr points is 
0x1000 4416, the correct starting address of the buffer I want to point to, and in the local static ram section of memory instead (see previously mentioned diagram).

Can anyone advise me on any or all of the following things?
1.why there's this difference of behaviour between debug running and stepping
2. why the address to which the pointer points is being changed to this reserved address without my consent?
3. Is my interpretation of the hard fault error correct?
4. General things/ useful documentation to read - if from reading this post it seems like I'm not entirely sure what I'm talking about you are correct.

Many thanks in advanced

标签 (1)
0 项奖励
回复
2 回复数

1,283 次查看
lpcware
NXP Employee
NXP Employee
Content originally posted in LPCWare by jonotree on Tue Oct 28 09:00:45 MST 2014
You are right about the interrupt, I figured out that was the difference here. Stack corruption due to overflow does seem to be the issue here aswell. The J Yiu books seems like a good idea, thanks for the recommendation!
0 项奖励
回复

1,283 次查看
lpcware
NXP Employee
NXP Employee
Content originally posted in LPCWare by TheFallGuy on Mon Oct 27 10:28:38 MST 2014

Quote:
1.why there's this difference of behaviour between debug running and stepping


At one level there is no difference. The code will execute identically, except, of course, for timing. However, when you are running, an interrupt could occur. Depending on how you have written your code, conceivably, it could corrupt your stack, which might well explain what you are seeing


Quote:
2. why the address to which the pointer points is being changed to this reserved address without my consent?


Stack corruption?

Quote:
3. Is my interpretation of the hard fault error correct?


I don't know. You haven't given us information about your hard fault.


Quote:
4. General things/ useful documentation to read - if from reading this post it seems like I'm not entirely sure what I'm talking about you are correct.


Get a good book... The Joseph Yiu book on Definitive guide to Cortex-M3/M4 is very good.
0 项奖励
回复