Commit 7777746c authored by Richard Kuo's avatar Richard Kuo

Hexagon: add support for single-stepping (v4+)

Hardware single-step is only available on v4 and later
architectures.
Signed-off-by: default avatarRichard Kuo <rkuo@codeaurora.org>
parent f8722a4d
...@@ -36,4 +36,9 @@ extern const char *regs_query_register_name(unsigned int offset); ...@@ -36,4 +36,9 @@ extern const char *regs_query_register_name(unsigned int offset);
((struct pt_regs *) \ ((struct pt_regs *) \
((unsigned long)current_thread_info() + THREAD_SIZE) - 1) ((unsigned long)current_thread_info() + THREAD_SIZE) - 1)
#if CONFIG_HEXAGON_ARCH_VERSION >= 4
#define arch_has_single_step() (1)
#endif
#endif #endif
...@@ -211,6 +211,9 @@ struct pt_regs { ...@@ -211,6 +211,9 @@ struct pt_regs {
#define pt_psp(regs) ((regs)->hvmer.vmpsp) #define pt_psp(regs) ((regs)->hvmer.vmpsp)
#define pt_badva(regs) ((regs)->hvmer.vmbadva) #define pt_badva(regs) ((regs)->hvmer.vmbadva)
#define pt_set_singlestep(regs) ((regs)->hvmer.vmest |= (1<<HVM_VMEST_SS_SFT))
#define pt_clr_singlestep(regs) ((regs)->hvmer.vmest &= ~(1<<HVM_VMEST_SS_SFT))
#define pt_set_rte_sp(regs, sp) do {\ #define pt_set_rte_sp(regs, sp) do {\
pt_psp(regs) = (sp);\ pt_psp(regs) = (sp);\
(regs)->SP = (unsigned long) &((regs)->hvmer);\ (regs)->SP = (unsigned long) &((regs)->hvmer);\
......
...@@ -32,6 +32,21 @@ ...@@ -32,6 +32,21 @@
#include <asm/user.h> #include <asm/user.h>
#if arch_has_single_step()
/* Both called from ptrace_resume */
void user_enable_single_step(struct task_struct *child)
{
pt_set_singlestep(task_pt_regs(child));
set_tsk_thread_flag(child, TIF_SINGLESTEP);
}
void user_disable_single_step(struct task_struct *child)
{
pt_clr_singlestep(task_pt_regs(child));
clear_tsk_thread_flag(child, TIF_SINGLESTEP);
}
#endif
static int genregs_get(struct task_struct *target, static int genregs_get(struct task_struct *target,
const struct user_regset *regset, const struct user_regset *regset,
unsigned int pos, unsigned int count, unsigned int pos, unsigned int count,
......
...@@ -451,3 +451,14 @@ void do_machcheck(struct pt_regs *regs) ...@@ -451,3 +451,14 @@ void do_machcheck(struct pt_regs *regs)
/* Halt and catch fire */ /* Halt and catch fire */
__vmstop(); __vmstop();
} }
/*
* Treat this like the old 0xdb trap.
*/
void do_debug_exception(struct pt_regs *regs)
{
regs->hvmer.vmest &= ~HVM_VMEST_CAUSE_MSK;
regs->hvmer.vmest |= (TRAP_DEBUG << HVM_VMEST_CAUSE_SFT);
do_trap0(regs);
}
...@@ -367,6 +367,9 @@ _K_enter_trap0: ...@@ -367,6 +367,9 @@ _K_enter_trap0:
_K_enter_machcheck: _K_enter_machcheck:
vm_event_entry(do_machcheck) vm_event_entry(do_machcheck)
.globl _K_enter_debug
_K_enter_debug:
vm_event_entry(do_debug_exception)
.globl ret_from_fork .globl ret_from_fork
ret_from_fork: ret_from_fork:
......
...@@ -41,7 +41,7 @@ _K_VM_event_vector: ...@@ -41,7 +41,7 @@ _K_VM_event_vector:
jump 1b; /* Reset */ jump 1b; /* Reset */
jump _K_enter_machcheck; jump _K_enter_machcheck;
jump _K_enter_genex; jump _K_enter_genex;
jump 1b; /* 3 Rsvd */ jump _K_enter_debug;
jump 1b; /* 4 Rsvd */ jump 1b; /* 4 Rsvd */
jump _K_enter_trap0; jump _K_enter_trap0;
jump 1b; /* 6 Rsvd */ jump 1b; /* 6 Rsvd */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment