Top Qs
Timeline
Chat
Perspective
X86 debug register
From Wikipedia, the free encyclopedia
Remove ads
On the x86 architecture, a debug register is a register used by a processor for program debugging. There are six debug registers, named DR0...DR7, with DR4 and DR5 as obsolete synonyms for DR6 and DR7. The debug registers allow programmers to selectively enable various debug conditions associated with a set of four debug addresses. Two of these registers are used to control debug features. These registers are accessed by variants of the MOV instruction. A debug register may be either the source operand or destination operand. The debug registers are privileged resources; the MOV instructions that access them can only be executed at privilege level zero. An attempt to read or write the debug registers when executing at any other privilege level causes a general protection fault.
Remove ads
DR0 to DR3
Each of these registers contains the linear address associated with one of four breakpoint conditions. Each breakpoint condition is further defined by bits in DR7.
The debug address registers are effective whether or not paging is enabled. The addresses in these registers are linear addresses. If paging is enabled, the linear addresses are translated into physical addresses by the processor's paging mechanism. If paging is not enabled, these linear addresses are the same as physical addresses.
Note that when paging is enabled, different tasks may have different linear-to-physical address mappings. When this is the case, an address in a debug address register may be relevant to one task but not to another. For this reason the x86 has both global and local enable bits in DR7. These bits indicate whether a given debug address has a global (all tasks) or local (current task only) relevance.
Remove ads
DR6 - Debug status
Summarize
Perspective
The debug status register permits the debugger to determine which debug conditions have occurred. When the processor detects an enabled debug exception, it will set the corresponding bits of this register before entering the debug exception handler.
- B0-B3 are set for each breakpoint condition that was met at the time that a debug exception was generated.
In some implementations, B0-B3 can be set for breakpoints that match but are not enabled[1] - therefore, the debug handler should only check bits that correspond to enabled breakpoints.
Also, it is implementation-dependent whether hardware will clear B0-B3 for non-matching breakpoint conditions - therefore, debug handlers are recommended to manually clear these bits before returning to the interrupted task.[2]
- When Bus Lock Trap is enabled using bit 2 of
DEBUGCTL
(MSR1D9h
), any instruction that causes a Bus Lock (mainly instructions that use theLOCK
prefix to perform memory atomics that straddle cache-line boundaries or operate on uncacheable memory) will clear bit 11 of DR6 and cause a trap-type #DB exception. This bit is not otherwise set or cleared by the processors - debug handlers are recommended to set this bit to 1 before returning to the interrupted task. - The BD bit indicates that the next instruction in the instruction stream is one that accesses a debug register.
In some implementations, this bit may be set even if DR7.GD is not set.[1]
- Bit 13 of DR6 is reserved on all Cyrix processors.
- If a debug exception condition is detected inside a transaction, then the processor will abort the transaction. If advanced debugging of RTM transactions is enabled, it will then raise the debug exception as a fault-type exception on the
XBEGIN
instruction that started the transaction, otherwise the transaction is aborted with no exceptions raised.
Remove ads
DR7 - Debug control
Summarize
Perspective
The debug control register is used to selectively enable the four address breakpoint conditions, and to specify the type and size of each of the four breakpoints. There are two levels of enabling: the local (0,2,4,6) and global (1,3,5,7) levels. The local enable bits are automatically reset by the processor at every task switch to avoid unwanted breakpoint conditions in the new task. The global enable bits are not reset by a task switch; therefore, they can be used for conditions that are global to all tasks.
- On 80386 processors, enabling exact breakpoints causes data breakpoint exceptions to be raised as trap-type exceptions for the instruction that performed the data access. If exact breakpoints are not enabled, then data breakpoint exceptions may be delayed by one or more instructions.[5] Enabling exact breakpoints comes at a significant performance cost on the 80386.[1]
On later processors, breakpoints are always exact - bits 9:8 of DR7 are still present as writable bits and are recommended to be set, but are ignored by the CPU.
- Setting bit 12 of DR7 to 1 modifies the action of breakpoints, single-stepping, general-detect (see bit 13), and behavior of the
F1h
("ICEBP"
/"INT01"
) opcode to:- On Intel 386/486 processors, break to In-circuit emulation.[6] (This will cause a system hang if an ICE is not connected.)
- On AMD and IBM 386/486 processors, break to System Management Mode.[7][3]
- On some 386/486 processors, bit 14 of DR7 is reported to enable branch trace messages[8] and bit 15 to enable task trace messages.[3] These messages are intended for use with In-circuit emulation and may cause system instability if an ICE is not connected.
- The supported breakpoint conditions are: The behavior of using breakpoint type
10b
on processors where the CR4.DE bit is missing or set to zero is undefined.For instruction execution breakpoints, the breakpoint length must be set to
00b
(1 byte) or else behavior is undefined.
Remove ads
DR4 and DR5
Not real registers. On processors that support the CR4.DE bit (Intel Pentium and later), their behaviour is controlled by CR4.DE:
- CR4.DE=0 : DR4 and DR5 alias to DR6 and DR7, respectively.
- CR4.DE=1 : accessing DR4/5 results in #UD (invalid opcode) exception.
On processors without CR4.DE, the behaviour is officially undefined - usually, DR4/5 are aliased to DR6/7, but exceptions exist and have been used for CPU detection.[10]
Remove ads
See also
References
External links
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads