[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@3.15.145.156: ~ $
#ifndef _ASM_X86_DEBUGREG_H
#define _ASM_X86_DEBUGREG_H


/* Indicate the register numbers for a number of the specific
   debug registers.  Registers 0-3 contain the addresses we wish to trap on */
#define DR_FIRSTADDR 0        /* u_debugreg[DR_FIRSTADDR] */
#define DR_LASTADDR 3         /* u_debugreg[DR_LASTADDR]  */

#define DR_STATUS 6           /* u_debugreg[DR_STATUS]     */
#define DR_CONTROL 7          /* u_debugreg[DR_CONTROL] */

/* Define a few things for the status register.  We can use this to determine
   which debugging register was responsible for the trap.  The other bits
   are either reserved or not of interest to us. */

/* Define reserved bits in DR6 which are always set to 1 */
#define DR6_RESERVED	(0xFFFF0FF0)

#define DR_TRAP0	(0x1)		/* db0 */
#define DR_TRAP1	(0x2)		/* db1 */
#define DR_TRAP2	(0x4)		/* db2 */
#define DR_TRAP3	(0x8)		/* db3 */
#define DR_TRAP_BITS	(DR_TRAP0|DR_TRAP1|DR_TRAP2|DR_TRAP3)

#define DR_STEP		(0x4000)	/* single-step */
#define DR_SWITCH	(0x8000)	/* task switch */

/* Now define a bunch of things for manipulating the control register.
   The top two bytes of the control register consist of 4 fields of 4
   bits - each field corresponds to one of the four debug registers,
   and indicates what types of access we trap on, and how large the data
   field is that we are looking at */

#define DR_CONTROL_SHIFT 16 /* Skip this many bits in ctl register */
#define DR_CONTROL_SIZE 4   /* 4 control bits per register */

#define DR_RW_EXECUTE (0x0)   /* Settings for the access types to trap on */
#define DR_RW_WRITE (0x1)
#define DR_RW_READ (0x3)

#define DR_LEN_1 (0x0) /* Settings for data length to trap on */
#define DR_LEN_2 (0x4)
#define DR_LEN_4 (0xC)
#define DR_LEN_8 (0x8)

/* The low byte to the control register determine which registers are
   enabled.  There are 4 fields of two bits.  One bit is "local", meaning
   that the processor will reset the bit after a task switch and the other
   is global meaning that we have to explicitly reset the bit.  With linux,
   you can use either one, since we explicitly zero the register when we enter
   kernel mode. */

#define DR_LOCAL_ENABLE_SHIFT 0    /* Extra shift to the local enable bit */
#define DR_GLOBAL_ENABLE_SHIFT 1   /* Extra shift to the global enable bit */
#define DR_LOCAL_ENABLE (0x1)      /* Local enable for reg 0 */
#define DR_GLOBAL_ENABLE (0x2)     /* Global enable for reg 0 */
#define DR_ENABLE_SIZE 2           /* 2 enable bits per register */

#define DR_LOCAL_ENABLE_MASK (0x55)  /* Set  local bits for all 4 regs */
#define DR_GLOBAL_ENABLE_MASK (0xAA) /* Set global bits for all 4 regs */

/* The second byte to the control register has a few special things.
   We can slow the instruction pipeline for instructions coming via the
   gdt or the ldt if we want to.  I am not sure why this is an advantage */

#ifdef __i386__
#define DR_CONTROL_RESERVED (0xFC00) /* Reserved by Intel */
#else
#define DR_CONTROL_RESERVED (0xFFFFFFFF0000FC00UL) /* Reserved */
#endif

#define DR_LOCAL_SLOWDOWN (0x100)   /* Local slow the pipeline */
#define DR_GLOBAL_SLOWDOWN (0x200)  /* Global slow the pipeline */

/*
 * HW breakpoint additions
 */

#endif /* _ASM_X86_DEBUGREG_H */

Filemanager

Name Type Size Permission Actions
a.out.h File 693 B 0644
auxvec.h File 483 B 0644
bitsperlong.h File 229 B 0644
boot.h File 260 B 0644
bootparam.h File 4.39 KB 0644
bpf_perf_event.h File 40 B 0644
byteorder.h File 137 B 0644
debugreg.h File 3.15 KB 0644
e820.h File 2.63 KB 0644
errno.h File 31 B 0644
fcntl.h File 31 B 0644
hw_breakpoint.h File 6 B 0644
hyperv.h File 12.98 KB 0644
ioctl.h File 31 B 0644
ioctls.h File 32 B 0644
ipcbuf.h File 32 B 0644
ist.h File 790 B 0644
kvm.h File 6.81 KB 0644
kvm_para.h File 2.8 KB 0644
kvm_perf.h File 325 B 0644
ldt.h File 963 B 0644
mce.h File 1.22 KB 0644
mman.h File 1.01 KB 0644
msgbuf.h File 32 B 0644
msr-index.h File 29.04 KB 0644
msr.h File 283 B 0644
mtrr.h File 4.06 KB 0644
param.h File 31 B 0644
perf_regs.h File 1.24 KB 0644
poll.h File 30 B 0644
posix_types.h File 161 B 0644
posix_types_32.h File 702 B 0644
posix_types_64.h File 546 B 0644
posix_types_x32.h File 518 B 0644
prctl.h File 190 B 0644
processor-flags.h File 6.32 KB 0644
ptrace-abi.h File 1.76 KB 0644
ptrace.h File 1.17 KB 0644
resource.h File 34 B 0644
sembuf.h File 699 B 0644
setup.h File 6 B 0644
shmbuf.h File 32 B 0644
sigcontext.h File 5.11 KB 0644
sigcontext32.h File 1.64 KB 0644
siginfo.h File 431 B 0644
signal.h File 2.77 KB 0644
socket.h File 32 B 0644
sockios.h File 33 B 0644
stat.h File 2.89 KB 0644
statfs.h File 353 B 0644
svm.h File 5.09 KB 0644
swab.h File 661 B 0644
termbits.h File 34 B 0644
termios.h File 33 B 0644
types.h File 113 B 0644
ucontext.h File 339 B 0644
unistd.h File 296 B 0644
unistd_32.h File 9.37 KB 0644
unistd_64.h File 8.59 KB 0644
unistd_x32.h File 15.12 KB 0644
vm86.h File 2.98 KB 0644
vmx.h File 6.53 KB 0644
vsyscall.h File 375 B 0644