blob: 22a8537eb780b231f24cdec6b2b1797cd7cd5868 [file] [log] [blame]
H. Peter Anvin1965aae2008-10-22 22:26:29 -07001#ifndef _ASM_X86_KGDB_H
2#define _ASM_X86_KGDB_H
Ingo Molnar82da3ff2008-04-17 20:05:37 +02003
4/*
5 * Copyright (C) 2001-2004 Amit S. Kale
6 * Copyright (C) 2008 Wind River Systems, Inc.
7 */
8
Andy Lutomirski35de5b02016-04-26 12:23:24 -07009#include <asm/ptrace.h>
10
Ingo Molnar82da3ff2008-04-17 20:05:37 +020011/*
12 * BUFMAX defines the maximum number of characters in inbound/outbound
13 * buffers at least NUMREGBYTES*2 are needed for register packets
14 * Longer buffer is needed to list all threads
15 */
16#define BUFMAX 1024
17
18/*
19 * Note that this register image is in a different order than
20 * the register image that Linux produces at interrupt time.
21 *
22 * Linux's register image is defined by struct pt_regs in ptrace.h.
23 * Just why GDB uses a different order is a historical mystery.
24 */
25#ifdef CONFIG_X86_32
26enum regnames {
27 GDB_AX, /* 0 */
28 GDB_CX, /* 1 */
29 GDB_DX, /* 2 */
30 GDB_BX, /* 3 */
31 GDB_SP, /* 4 */
32 GDB_BP, /* 5 */
33 GDB_SI, /* 6 */
34 GDB_DI, /* 7 */
35 GDB_PC, /* 8 also known as eip */
36 GDB_PS, /* 9 also known as eflags */
37 GDB_CS, /* 10 */
38 GDB_SS, /* 11 */
39 GDB_DS, /* 12 */
40 GDB_ES, /* 13 */
41 GDB_FS, /* 14 */
42 GDB_GS, /* 15 */
43};
Jason Wessel12bfa3d2010-08-05 09:22:20 -050044#define GDB_ORIG_AX 41
45#define DBG_MAX_REG_NUM 16
Jason Wessel703a1ed2008-09-26 10:36:42 -050046#define NUMREGBYTES ((GDB_GS+1)*4)
Ingo Molnar82da3ff2008-04-17 20:05:37 +020047#else /* ! CONFIG_X86_32 */
Jason Wessel12bfa3d2010-08-05 09:22:20 -050048enum regnames {
Ingo Molnar82da3ff2008-04-17 20:05:37 +020049 GDB_AX, /* 0 */
Jason Wessel95dbf1d2008-09-26 10:36:42 -050050 GDB_BX, /* 1 */
Ingo Molnar82da3ff2008-04-17 20:05:37 +020051 GDB_CX, /* 2 */
Jason Wessel95dbf1d2008-09-26 10:36:42 -050052 GDB_DX, /* 3 */
Ingo Molnar82da3ff2008-04-17 20:05:37 +020053 GDB_SI, /* 4 */
54 GDB_DI, /* 5 */
55 GDB_BP, /* 6 */
56 GDB_SP, /* 7 */
57 GDB_R8, /* 8 */
58 GDB_R9, /* 9 */
59 GDB_R10, /* 10 */
60 GDB_R11, /* 11 */
61 GDB_R12, /* 12 */
62 GDB_R13, /* 13 */
63 GDB_R14, /* 14 */
64 GDB_R15, /* 15 */
65 GDB_PC, /* 16 */
Jason Wessel12bfa3d2010-08-05 09:22:20 -050066 GDB_PS, /* 17 */
67 GDB_CS, /* 18 */
68 GDB_SS, /* 19 */
Jan Kiszka639077f2012-03-19 15:16:48 -050069 GDB_DS, /* 20 */
70 GDB_ES, /* 21 */
71 GDB_FS, /* 22 */
72 GDB_GS, /* 23 */
Ingo Molnar82da3ff2008-04-17 20:05:37 +020073};
Jason Wessel12bfa3d2010-08-05 09:22:20 -050074#define GDB_ORIG_AX 57
Jan Kiszka639077f2012-03-19 15:16:48 -050075#define DBG_MAX_REG_NUM 24
76/* 17 64 bit regs and 5 32 bit regs */
77#define NUMREGBYTES ((17 * 8) + (5 * 4))
Jason Wessel12bfa3d2010-08-05 09:22:20 -050078#endif /* ! CONFIG_X86_32 */
Ingo Molnar82da3ff2008-04-17 20:05:37 +020079
80static inline void arch_kgdb_breakpoint(void)
81{
82 asm(" int $3");
83}
84#define BREAK_INSTR_SIZE 1
85#define CACHE_FLUSH_IS_SAFE 1
Mike Frysinger63ab25e2011-05-26 16:25:45 -070086#define GDB_ADJUSTS_BREAK_OFFSET
Ingo Molnar82da3ff2008-04-17 20:05:37 +020087
Jason Wesself503b5a2010-05-20 21:04:25 -050088extern int kgdb_ll_trap(int cmd, const char *str,
89 struct pt_regs *regs, long err, int trap, int sig);
90
H. Peter Anvin1965aae2008-10-22 22:26:29 -070091#endif /* _ASM_X86_KGDB_H */