This article discusses about how we have done debugging of the Undefined Instruction Exception on Blackfin BF-707 Processor.
When debugging from CCES it is observed that the PC status is constantly showing the same address when this exception happens.
So, we tried to call the Compare Files function at the start of the function. We can see the corresponding C Code and Assembly code as shown below
Also before Undefined Instruction Exception is thrown, we can see in below picture how the disassembly code looks like
One of Analog Devices Expert suggested to keep a hardware break-point when the write happens at that address.
The hardware breakpoints can be added while debugging from the emulator.
It is available as shown in below figure
The address at which the Undefined Instruction was getting generated is from 0x080491CC
Hence we have added the Hardware Breakpoints as shown below
On this exception, when we see the CALL STACK it shows the code that is trying to alter this memory address, which is shown in below figure.
In this picture if we see the callstack on left hand side top, then it shows that TWI_Write is writing to the memory 0x080491CC. If we see all the pointers in pDevInfo in top right side one of the buffer pCommBuffer starting address is 0x0804918A. When we copy some data starting from this address, it can overwrite into 0x080491CC when the size to be copies is more than 66 bytes.
This is how we can use hardware breakpoints for finding memory area being read or written.
When debugging from CCES it is observed that the PC status is constantly showing the same address when this exception happens.
So, we tried to call the Compare Files function at the start of the function. We can see the corresponding C Code and Assembly code as shown below
Also before Undefined Instruction Exception is thrown, we can see in below picture how the disassembly code looks like
One of Analog Devices Expert suggested to keep a hardware break-point when the write happens at that address.
The hardware breakpoints can be added while debugging from the emulator.
It is available as shown in below figure
The address at which the Undefined Instruction was getting generated is from 0x080491CC
Hence we have added the Hardware Breakpoints as shown below
On this exception, when we see the CALL STACK it shows the code that is trying to alter this memory address, which is shown in below figure.
In this picture if we see the callstack on left hand side top, then it shows that TWI_Write is writing to the memory 0x080491CC. If we see all the pointers in pDevInfo in top right side one of the buffer pCommBuffer starting address is 0x0804918A. When we copy some data starting from this address, it can overwrite into 0x080491CC when the size to be copies is more than 66 bytes.
This is how we can use hardware breakpoints for finding memory area being read or written.