mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-12 00:34:43 +08:00
92b3de3f8a
Architecture-specific documentation is being moved into Documentation/arch/ as a way of cleaning up the top-level documentation directory and making the docs hierarchy more closely match the source hierarchy. Move Documentation/parisc into arch/ and fix all in-tree references. Cc: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com> Cc: Helge Deller <deller@gmx.de> Cc: Alex Shi <alexs@kernel.org> Reviewed-by: Yanteng Si <siyanteng@loongson.cn> Signed-off-by: Jonathan Corbet <corbet@lwn.net>
47 lines
1.7 KiB
ReStructuredText
47 lines
1.7 KiB
ReStructuredText
=================
|
|
PA-RISC Debugging
|
|
=================
|
|
|
|
okay, here are some hints for debugging the lower-level parts of
|
|
linux/parisc.
|
|
|
|
|
|
1. Absolute addresses
|
|
=====================
|
|
|
|
A lot of the assembly code currently runs in real mode, which means
|
|
absolute addresses are used instead of virtual addresses as in the
|
|
rest of the kernel. To translate an absolute address to a virtual
|
|
address you can lookup in System.map, add __PAGE_OFFSET (0x10000000
|
|
currently).
|
|
|
|
|
|
2. HPMCs
|
|
========
|
|
|
|
When real-mode code tries to access non-existent memory, you'll get
|
|
an HPMC instead of a kernel oops. To debug an HPMC, try to find
|
|
the System Responder/Requestor addresses. The System Requestor
|
|
address should match (one of the) processor HPAs (high addresses in
|
|
the I/O range); the System Responder address is the address real-mode
|
|
code tried to access.
|
|
|
|
Typical values for the System Responder address are addresses larger
|
|
than __PAGE_OFFSET (0x10000000) which mean a virtual address didn't
|
|
get translated to a physical address before real-mode code tried to
|
|
access it.
|
|
|
|
|
|
3. Q bit fun
|
|
============
|
|
|
|
Certain, very critical code has to clear the Q bit in the PSW. What
|
|
happens when the Q bit is cleared is the CPU does not update the
|
|
registers interruption handlers read to find out where the machine
|
|
was interrupted - so if you get an interruption between the instruction
|
|
that clears the Q bit and the RFI that sets it again you don't know
|
|
where exactly it happened. If you're lucky the IAOQ will point to the
|
|
instruction that cleared the Q bit, if you're not it points anywhere
|
|
at all. Usually Q bit problems will show themselves in unexplainable
|
|
system hangs or running off the end of physical memory.
|