From 65a87239eea1cd2d3e5c5ffad60b6060a4a25996 Mon Sep 17 00:00:00 2001 From: midipix Date: Thu, 6 Jun 2019 06:14:39 +0000 Subject: debug interfaces: provide dbg_* interfaces as wrappers around struct __db_vtbl. --- arch/nt32/psxdbg.h | 28 ++++++++++++++++++++++++++++ arch/nt32/psxglue.h | 3 ++- arch/nt64/psxdbg.h | 28 ++++++++++++++++++++++++++++ arch/nt64/psxglue.h | 3 ++- 4 files changed, 60 insertions(+), 2 deletions(-) create mode 100644 arch/nt32/psxdbg.h create mode 100644 arch/nt64/psxdbg.h (limited to 'arch') diff --git a/arch/nt32/psxdbg.h b/arch/nt32/psxdbg.h new file mode 100644 index 0000000..38c9fcd --- /dev/null +++ b/arch/nt32/psxdbg.h @@ -0,0 +1,28 @@ +#ifndef _PSXDBG_H_ +#define _PSXDBG_H_ + +struct __dbg_event; + +struct __dbg_vtbl { + int (*dbg_attach)(pid_t); + int (*dbg_detach)(int); + + int (*dbg_spawn)(const char *, char **, char **); + int (*dbg_fork)(void); + int (*dbg_suspend)(int); + int (*dbg_kill)(int); + + int (*dbg_event_query_one)(int, struct __dbg_event *); + int (*dbg_event_query_all)(int, struct __dbg_event[], int); + + int (*dbg_event_acquire)(int, struct __dbg_event *); + int (*dbg_event_respond)(int, struct __dbg_event *); + + int (*dbg_query_cpid)(int); + int (*dbg_query_syspid)(int); + + int (*dbg_common_error)(void); + int (*dbg_native_error)(void); +}; + +#endif diff --git a/arch/nt32/psxglue.h b/arch/nt32/psxglue.h index 37a2109..d8e653a 100644 --- a/arch/nt32/psxglue.h +++ b/arch/nt32/psxglue.h @@ -46,9 +46,10 @@ struct __psx_context { void * ldsoaddr; const unsigned short * ctty; void ** sys_vtbl; + const struct __psx_vtbl * psx_vtbl; const struct __seh_vtbl * seh_vtbl; + const struct __dbg_vtbl * dbg_vtbl; const struct __ldso_vtbl * ldso_vtbl; - const struct __psx_vtbl * psx_vtbl; unsigned int teb_sys_idx; unsigned int teb_libc_idx; void * pthread_surrogate_fn; diff --git a/arch/nt64/psxdbg.h b/arch/nt64/psxdbg.h new file mode 100644 index 0000000..38c9fcd --- /dev/null +++ b/arch/nt64/psxdbg.h @@ -0,0 +1,28 @@ +#ifndef _PSXDBG_H_ +#define _PSXDBG_H_ + +struct __dbg_event; + +struct __dbg_vtbl { + int (*dbg_attach)(pid_t); + int (*dbg_detach)(int); + + int (*dbg_spawn)(const char *, char **, char **); + int (*dbg_fork)(void); + int (*dbg_suspend)(int); + int (*dbg_kill)(int); + + int (*dbg_event_query_one)(int, struct __dbg_event *); + int (*dbg_event_query_all)(int, struct __dbg_event[], int); + + int (*dbg_event_acquire)(int, struct __dbg_event *); + int (*dbg_event_respond)(int, struct __dbg_event *); + + int (*dbg_query_cpid)(int); + int (*dbg_query_syspid)(int); + + int (*dbg_common_error)(void); + int (*dbg_native_error)(void); +}; + +#endif diff --git a/arch/nt64/psxglue.h b/arch/nt64/psxglue.h index 37a2109..d8e653a 100644 --- a/arch/nt64/psxglue.h +++ b/arch/nt64/psxglue.h @@ -46,9 +46,10 @@ struct __psx_context { void * ldsoaddr; const unsigned short * ctty; void ** sys_vtbl; + const struct __psx_vtbl * psx_vtbl; const struct __seh_vtbl * seh_vtbl; + const struct __dbg_vtbl * dbg_vtbl; const struct __ldso_vtbl * ldso_vtbl; - const struct __psx_vtbl * psx_vtbl; unsigned int teb_sys_idx; unsigned int teb_libc_idx; void * pthread_surrogate_fn; -- cgit v1.2.3