blob: b4e210d633c288bc57ad2659f95c8b37cab3b964 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jason Wessel88547002008-07-29 15:58:53 -05002#ifndef __ASM_KGDB_H_
3#define __ASM_KGDB_H_
4
5#ifdef __KERNEL__
6
7#include <asm/sgidefs.h>
8
9#if (_MIPS_ISA == _MIPS_ISA_MIPS1) || (_MIPS_ISA == _MIPS_ISA_MIPS2) || \
10 (_MIPS_ISA == _MIPS_ISA_MIPS32)
11
Jason Wessel0896a9b2010-08-05 09:22:21 -050012#define KGDB_GDB_REG_SIZE 32
13#define GDB_SIZEOF_REG sizeof(u32)
Jason Wessel88547002008-07-29 15:58:53 -050014
15#elif (_MIPS_ISA == _MIPS_ISA_MIPS3) || (_MIPS_ISA == _MIPS_ISA_MIPS4) || \
16 (_MIPS_ISA == _MIPS_ISA_MIPS64)
17
18#ifdef CONFIG_32BIT
Jason Wessel0896a9b2010-08-05 09:22:21 -050019#define KGDB_GDB_REG_SIZE 32
20#define GDB_SIZEOF_REG sizeof(u32)
Lukas Bulwahn301e4992021-12-13 12:16:38 +010021#else /* CONFIG_32BIT */
Jason Wessel0896a9b2010-08-05 09:22:21 -050022#define KGDB_GDB_REG_SIZE 64
23#define GDB_SIZEOF_REG sizeof(u64)
Jason Wessel88547002008-07-29 15:58:53 -050024#endif
25#else
26#error "Need to set KGDB_GDB_REG_SIZE for MIPS ISA"
27#endif /* _MIPS_ISA */
28
29#define BUFMAX 2048
Jason Wessel0896a9b2010-08-05 09:22:21 -050030#define DBG_MAX_REG_NUM 72
31#define NUMREGBYTES (DBG_MAX_REG_NUM * sizeof(GDB_SIZEOF_REG))
32#define NUMCRITREGBYTES (12 * sizeof(GDB_SIZEOF_REG))
Jason Wessel88547002008-07-29 15:58:53 -050033#define BREAK_INSTR_SIZE 4
34#define CACHE_FLUSH_IS_SAFE 0
35
36extern void arch_kgdb_breakpoint(void);
Jason Wessel88547002008-07-29 15:58:53 -050037extern void *saved_vectors[32];
38extern void handle_exception(struct pt_regs *regs);
39extern void breakinst(void);
Jason Wessel5dd11d52010-05-20 21:04:26 -050040extern int kgdb_ll_trap(int cmd, const char *str,
41 struct pt_regs *regs, long err, int trap, int sig);
Jason Wessel88547002008-07-29 15:58:53 -050042
43#endif /* __KERNEL__ */
44
45#endif /* __ASM_KGDB_H_ */