ia64/xen-unstable

diff xen/include/asm-x86/debugreg.h @ 16428:69b56d3289f5

x86: emulate I/O port access breakpoints

Emulate the trapping on I/O port accesses when emulating IN/OUT.

Also allow 8-byte breakpoints on x86-64 (and on i686 if the hardware
supports them), and tighten the condition for loading debug registers
during context switch.

Signed-off-by: Jan Beulich <jbeulich@novell.com>
Signed-off-by: Keir Fraser <keir.fraser@eu.citrix.com>
author Keir Fraser <keir.fraser@citrix.com>
date Thu Nov 22 19:23:40 2007 +0000 (2007-11-22)
parents 92b8e1efa784
children
line diff
     1.1 --- a/xen/include/asm-x86/debugreg.h	Thu Nov 22 18:28:47 2007 +0000
     1.2 +++ b/xen/include/asm-x86/debugreg.h	Thu Nov 22 19:23:40 2007 +0000
     1.3 @@ -4,23 +4,22 @@
     1.4  
     1.5  /* Indicate the register numbers for a number of the specific
     1.6     debug registers.  Registers 0-3 contain the addresses we wish to trap on */
     1.7 -#define DR_FIRSTADDR 0        /* u_debugreg[DR_FIRSTADDR] */
     1.8 -#define DR_LASTADDR 3         /* u_debugreg[DR_LASTADDR]  */
     1.9  
    1.10 -#define DR_STATUS 6           /* u_debugreg[DR_STATUS]     */
    1.11 -#define DR_CONTROL 7          /* u_debugreg[DR_CONTROL] */
    1.12 +#define DR_FIRSTADDR 0
    1.13 +#define DR_LASTADDR  3
    1.14 +#define DR_STATUS    6
    1.15 +#define DR_CONTROL   7
    1.16  
    1.17  /* Define a few things for the status register.  We can use this to determine
    1.18     which debugging register was responsible for the trap.  The other bits
    1.19     are either reserved or not of interest to us. */
    1.20  
    1.21 -#define DR_TRAP0	(0x1)		/* db0 */
    1.22 -#define DR_TRAP1	(0x2)		/* db1 */
    1.23 -#define DR_TRAP2	(0x4)		/* db2 */
    1.24 -#define DR_TRAP3	(0x8)		/* db3 */
    1.25 -
    1.26 -#define DR_STEP		(0x4000)	/* single-step */
    1.27 -#define DR_SWITCH	(0x8000)	/* task switch */
    1.28 +#define DR_TRAP0        (0x1)           /* db0 */
    1.29 +#define DR_TRAP1        (0x2)           /* db1 */
    1.30 +#define DR_TRAP2        (0x4)           /* db2 */
    1.31 +#define DR_TRAP3        (0x8)           /* db3 */
    1.32 +#define DR_STEP         (0x4000)        /* single-step */
    1.33 +#define DR_SWITCH       (0x8000)        /* task switch */
    1.34  
    1.35  /* Now define a bunch of things for manipulating the control register.
    1.36     The top two bytes of the control register consist of 4 fields of 4
    1.37 @@ -29,36 +28,40 @@
    1.38     field is that we are looking at */
    1.39  
    1.40  #define DR_CONTROL_SHIFT 16 /* Skip this many bits in ctl register */
    1.41 -#define DR_CONTROL_SIZE 4   /* 4 control bits per register */
    1.42 +#define DR_CONTROL_SIZE   4 /* 4 control bits per register */
    1.43  
    1.44 -#define DR_RW_EXECUTE (0x0)   /* Settings for the access types to trap on */
    1.45 -#define DR_RW_WRITE (0x1)
    1.46 -#define DR_RW_READ (0x3)
    1.47 +#define DR_RW_EXECUTE (0x0) /* Settings for the access types to trap on */
    1.48 +#define DR_RW_WRITE   (0x1)
    1.49 +#define DR_IO         (0x2)
    1.50 +#define DR_RW_READ    (0x3)
    1.51  
    1.52 -#define DR_LEN_1 (0x0) /* Settings for data length to trap on */
    1.53 -#define DR_LEN_2 (0x4)
    1.54 -#define DR_LEN_4 (0xC)
    1.55 +#define DR_LEN_1      (0x0) /* Settings for data length to trap on */
    1.56 +#define DR_LEN_2      (0x4)
    1.57 +#define DR_LEN_4      (0xC)
    1.58 +#define DR_LEN_8      (0x8)
    1.59  
    1.60  /* The low byte to the control register determine which registers are
    1.61     enabled.  There are 4 fields of two bits.  One bit is "local", meaning
    1.62     that the processor will reset the bit after a task switch and the other
    1.63 -   is global meaning that we have to explicitly reset the bit.  With linux,
    1.64 -   you can use either one, since we explicitly zero the register when we enter
    1.65 -   kernel mode. */
    1.66 +   is global meaning that we have to explicitly reset the bit. */
    1.67  
    1.68 -#define DR_LOCAL_ENABLE_SHIFT 0    /* Extra shift to the local enable bit */
    1.69 +#define DR_LOCAL_ENABLE_SHIFT  0   /* Extra shift to the local enable bit */
    1.70  #define DR_GLOBAL_ENABLE_SHIFT 1   /* Extra shift to the global enable bit */
    1.71 -#define DR_ENABLE_SIZE 2           /* 2 enable bits per register */
    1.72 +#define DR_ENABLE_SIZE         2   /* 2 enable bits per register */
    1.73  
    1.74  #define DR_LOCAL_ENABLE_MASK (0x55)  /* Set  local bits for all 4 regs */
    1.75  #define DR_GLOBAL_ENABLE_MASK (0xAA) /* Set global bits for all 4 regs */
    1.76  
    1.77 +#define DR7_ACTIVE_MASK (DR_LOCAL_ENABLE_MASK|DR_GLOBAL_ENABLE_MASK)
    1.78 +
    1.79  /* The second byte to the control register has a few special things.
    1.80     We can slow the instruction pipeline for instructions coming via the
    1.81     gdt or the ldt if we want to.  I am not sure why this is an advantage */
    1.82  
    1.83 -#define DR_CONTROL_RESERVED (~0xFFFF03FFUL) /* Reserved by Intel */
    1.84 -#define DR_LOCAL_SLOWDOWN (0x100)   /* Local slow the pipeline */
    1.85 -#define DR_GLOBAL_SLOWDOWN (0x200)  /* Global slow the pipeline */
    1.86 +#define DR_CONTROL_RESERVED_ZERO (0x0000d800ul) /* Reserved, read as zero */
    1.87 +#define DR_CONTROL_RESERVED_ONE  (0x00000400ul) /* Reserved, read as one */
    1.88 +#define DR_LOCAL_EXACT_ENABLE    (0x00000100ul) /* Local exact enable */
    1.89 +#define DR_GLOBAL_EXACT_ENABLE   (0x00000200ul) /* Global exact enable */
    1.90 +#define DR_GENERAL_DETECT        (0x00002000ul) /* General detect enable */
    1.91  
    1.92  #endif /* _X86_DEBUGREG_H */