‎12-23-2007
08:37 AM
2,591 Views
data:image/s3,"s3://crabby-images/8d6ed/8d6ed1649be792663013f3f71e25c79a8deb6d03" alt="Vickyg Vickyg"
Vickyg
Contributor II
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi, I'm a newbie to assembler. I've been tracing through my code trying to discover what is happening, and I've found that my RTS is returning to the wrong place. Can anybody shed any light on a situation like this?
Thanks
Solved! Go to Solution.
1 Solution
‎12-23-2007
02:17 PM
985 Views
data:image/s3,"s3://crabby-images/8d6ed/8d6ed1649be792663013f3f71e25c79a8deb6d03" alt="Vickyg Vickyg"
Vickyg
Contributor II
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thank you both for your time and effort. Just knowing that there were people out there on my side (me against the chip) was what I needed to get past my problem. It turned out that I had changed chip sets and had missed that the add hx to a routines had moved and I was jumping in one point past where the stack pointer was incremented. Stupid error on my part, but as a complete novice I was sure it was something like an overrun of the stack bounderies.
Thanks, your being there was very important to me.
3 Replies
‎12-23-2007
10:06 AM
985 Views
data:image/s3,"s3://crabby-images/e02da/e02dafc0c66c976c301ac07a32042183482e501a" alt="kef kef"
kef
Specialist I
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Is stack pointer (SP) pointing to RAM?
‎12-23-2007
12:41 PM
985 Views
data:image/s3,"s3://crabby-images/c5895/c5895d790e748398948481ab1360fb62db3b8f24" alt="CompilerGuru CompilerGuru"
data:image/s3,"s3://crabby-images/72fa5/72fa5de460d45350614b41f29f2ed6392d307191" alt="NXP Employee NXP Employee"
NXP Employee
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
other things to check too
- stack is aligned, all the bytes added in the function have been removed before the RTS
- nothing in the function overwrites the return address
- the caller is using a JSR/BSR (and not CALL, for example)
- the stack is in RAM (as kef noted)
- the stack is allocated large enough.
Daniel
- stack is aligned, all the bytes added in the function have been removed before the RTS
- nothing in the function overwrites the return address
- the caller is using a JSR/BSR (and not CALL, for example)
- the stack is in RAM (as kef noted)
- the stack is allocated large enough.
Daniel
‎12-23-2007
02:17 PM
986 Views
data:image/s3,"s3://crabby-images/8d6ed/8d6ed1649be792663013f3f71e25c79a8deb6d03" alt="Vickyg Vickyg"
Vickyg
Contributor II
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thank you both for your time and effort. Just knowing that there were people out there on my side (me against the chip) was what I needed to get past my problem. It turned out that I had changed chip sets and had missed that the add hx to a routines had moved and I was jumping in one point past where the stack pointer was incremented. Stupid error on my part, but as a complete novice I was sure it was something like an overrun of the stack bounderies.
Thanks, your being there was very important to me.
data:image/s3,"s3://crabby-images/361ab/361abfe9a4bacb17cc3e5e9ffc104dadb3af9f0f" alt=""