debugging 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. okay, here are some hints for debugging the lower-level parts of
  2. linux/parisc.
  3. 1. Absolute addresses
  4. A lot of the assembly code currently runs in real mode, which means
  5. absolute addresses are used instead of virtual addresses as in the
  6. rest of the kernel. To translate an absolute address to a virtual
  7. address you can lookup in System.map, add __PAGE_OFFSET (0x10000000
  8. currently).
  9. 2. HPMCs
  10. When real-mode code tries to access non-existent memory, you'll get
  11. an HPMC instead of a kernel oops. To debug an HPMC, try to find
  12. the System Responder/Requestor addresses. The System Requestor
  13. address should match (one of the) processor HPAs (high addresses in
  14. the I/O range); the System Responder address is the address real-mode
  15. code tried to access.
  16. Typical values for the System Responder address are addresses larger
  17. than __PAGE_OFFSET (0x10000000) which mean a virtual address didn't
  18. get translated to a physical address before real-mode code tried to
  19. access it.
  20. 3. Q bit fun
  21. Certain, very critical code has to clear the Q bit in the PSW. What
  22. happens when the Q bit is cleared is the CPU does not update the
  23. registers interruption handlers read to find out where the machine
  24. was interrupted - so if you get an interruption between the instruction
  25. that clears the Q bit and the RFI that sets it again you don't know
  26. where exactly it happened. If you're lucky the IAOQ will point to the
  27. instrucion that cleared the Q bit, if you're not it points anywhere
  28. at all. Usually Q bit problems will show themselves in unexplainable
  29. system hangs or running off the end of physical memory.