URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [librdbg/] [src/] [powerpc/] [mcp750/] [remdeb.h] - Rev 312
Go to most recent revision | Compare with Previous | Blame | View Log
/* * Please do not edit this file. * It was generated using rpcgen. */ #ifndef _REMDEB_H_RPCGEN #define _REMDEB_H_RPCGEN #include <rpc/rpc.h> #ifdef __cplusplus extern "C" { #endif #define RTEMS_PORT 2071 #define RTEMS_BACK_PORT 2073 #ifndef REMDEB_H #define RPCGENSRVNAME(a) a enum rpc_type { SUNRPC = 0, BADRPCTYPE = 25, }; typedef enum rpc_type rpc_type; #define NET_SAFE 1400 struct UDP_MSG { u_char type; u_char msg_num; u_short spec; long pid; u_long context; }; typedef struct UDP_MSG UDP_MSG; /* * Sun request values for the remote ptrace system call */ enum ptracereq { RPT_TRACEME = 0, RPT_CHILDDONE = 0, RPT_PEEKTEXT = 0 + 1, RPT_PEEKDATA = 0 + 2, RPT_PEEKUSER = 0 + 3, RPT_POKETEXT = 0 + 4, RPT_POKEDATA = 0 + 5, RPT_POKEUSER = 0 + 6, RPT_CONT = 0 + 7, RPT_KILL = 0 + 8, RPT_SINGLESTEP = 0 + 9, RPT_ATTACH = 0 + 10, RPT_DETACH = 0 + 11, RPT_GETREGS = 0 + 12, RPT_SETREGS = 0 + 13, RPT_GETFPREGS = 0 + 14, RPT_SETFPREGS = 0 + 15, RPT_READDATA = 0 + 16, RPT_WRITEDATA = 0 + 17, RPT_READTEXT = 0 + 18, RPT_WRITETEXT = 0 + 19, RPT_GETFPAREGS = 0 + 20, RPT_SETFPAREGS = 0 + 21, RPT_22 = 0 + 22, RPT_23 = 0 + 23, RPT_SYSCALL = 0 + 24, RPT_DUMPCORE = 0 + 25, RPT_26 = 0 + 26, RPT_27 = 0 + 27, RPT_28 = 0 + 28, RPT_GETUCODE = 0 + 29, RPT_GETTARGETTHREAD = 50, RPT_SETTARGETTHREAD = 51, RPT_THREADSUSPEND = 52, RPT_THREADRESUME = 53, RPT_THREADLIST = 54, RPT_GETTHREADNAME = 55, RPT_SETTHREADNAME = 56, RPT_SETTHREADREGS = 57, RPT_GETTHREADREGS = 58, RPT_STEPRANGE = 75, RPT_CONTTO = 76, RPT_SETBREAK = 77, RPT_CLRBREAK = 78, RPT_GETBREAK = 79, RPT_GETNAME = 80, RPT_STOP = 81, RPT_PGETREGS = 82, RPT_PSETREGS = 83, RPT_PSETTHREADREGS = 84, RPT_PGETTHREADREGS = 85, }; typedef enum ptracereq ptracereq; struct xdr_regs { u_int tabreg[40]; }; typedef struct xdr_regs xdr_regs; /* now define register macros to apply to xdr_regs struct */ #define R_PC 0 #define R_MSR 1 #define R_EXCEPNB 2 #define R_R0 3 #define R_R1 (R_R0 + 1) #define R_R2 (R_R0 + 2) #define R_R3 (R_R0 + 3) #define R_R4 (R_R0 + 4) #define R_R5 (R_R0 + 5) #define R_R6 (R_R0 + 6) #define R_R7 (R_R0 + 7) #define R_R8 (R_R0 + 8) #define R_R9 (R_R0 + 9) #define R_R10 (R_R0 + 10) #define R_R11 (R_R0 + 11) #define R_R12 (R_R0 + 12) #define R_R13 (R_R0 + 13) #define R_R14 (R_R0 + 14) #define R_R15 (R_R0 + 15) #define R_R16 (R_R0 + 16) #define R_R17 (R_R0 + 17) #define R_R18 (R_R0 + 18) #define R_R19 (R_R0 + 19) #define R_R20 (R_R0 + 20) #define R_R21 (R_R0 + 21) #define R_R22 (R_R0 + 22) #define R_R23 (R_R0 + 23) #define R_R24 (R_R0 + 24) #define R_R25 (R_R0 + 25) #define R_R26 (R_R0 + 26) #define R_R27 (R_R0 + 27) #define R_R28 (R_R0 + 28) #define R_R29 (R_R0 + 29) #define R_R30 (R_R0 + 30) #define R_R31 (R_R0 + 31) #define R_CR 35 #define R_CTR 36 #define R_XER 37 #define R_LR 38 #define R_MQ 39 #include <libcpu/raw_exception.h> #define REG_PC tabreg[R_PC] /* PC register offset */ #define REG_SP tabreg[R_R1] /* SP register offset */ #define REG_FP tabreg[R_R1] /* SP register offset (no FP on PPC) */ #define BREAK_SIZE 4 /* Breakpoint occupies 4 bytes */ #define BREAK_ADJ 0 /* Nothing to subtract from address after bp */ #define IS_BREAK(l) ((l) == 0x7d8d6808) #define SET_BREAK(l) (0x7d8d6808) #define ORG_BREAK(c,p) (p) #define IS_STEP(regs) (regs.tabreg[R_EXCEPNB] == ASM_TRACE_VECTOR) /* Was step and not break */ #define TARGET_PROC_TYPE 3 #define MAXDEBUGGEE 150 #define NAMEMAX 17 /* * Memory data for read/write text or data. The size is in data. The target * addr is in the addr field. * Be careful before modifying because this value goes into internal * pipes and is allocated on stack too. Pipes and/or the stack could * become too small if this value gets incremented. */ #define MEM_DATA_MAX 256 struct xdr_mem { u_long addr; u_int dataNb; u_char data[MEM_DATA_MAX]; }; typedef struct xdr_mem xdr_mem; enum break_type { BRKT_NONE = 0, BRKT_INSTR = 1, BRKT_READ = 2, BRKT_WRITE = 3, BRKT_ACCESS = 4, BRKT_EXEC = 5, BRKT_OS_CALL = 6, BRKT_OS_SWITCH = 7, BRKT_STEPEMUL = 8, }; typedef enum break_type break_type; #define MAX_THRD_BRK 4 struct xdr_break { u_char type; u_char thread_spec; u_short handle; u_long ee_loc; u_long ee_type; u_short length; u_char pass_count; u_char curr_pass; u_long thread_list[MAX_THRD_BRK]; }; typedef struct xdr_break xdr_break; #define UTHREAD_MAX 64 #define THREADNAMEMAX 16 typedef char *thread_name; struct KernThread { u_int threadLi; }; typedef struct KernThread KernThread; typedef KernThread *ptThreadList; struct thread_list { u_int nbThread; ptThreadList threads; }; typedef struct thread_list thread_list; struct ptrace_addr_data_in { ptracereq req; union { xdr_regs regs; struct { u_int pregs_len; u_int *pregs_val; } pregs; thread_name name; xdr_mem mem; xdr_break breakp; u_int address; } ptrace_addr_data_in_u; }; typedef struct ptrace_addr_data_in ptrace_addr_data_in; struct ptrace_addr_data_out { ptracereq req; union { xdr_regs regs; struct { u_int pregs_len; u_int *pregs_val; } pregs; thread_list threads; thread_name name; xdr_mem mem; xdr_break breakp; u_int addr; } ptrace_addr_data_out_u; }; typedef struct ptrace_addr_data_out ptrace_addr_data_out; typedef struct { u_int CHAR_DATA_len; char *CHAR_DATA_val; } CHAR_DATA; #define XRY_MAX_INST_BUFF 128 #define XRY_MAX_INSTANCES 16 #ifndef XRY_MAX_CMD_STR #define XRY_MAX_CMD_STR 320 #endif /* REMDEB_H */ struct xry_inst { u_char flags; u_char type; u_char sub_type; u_char res_type; u_long value; u_long value2; }; typedef struct xry_inst xry_inst; struct instance { struct xry_inst instances[XRY_MAX_INSTANCES]; u_char buffer[XRY_MAX_INST_BUFF]; }; typedef struct instance instance; struct instance_union { bool_t instances; union { instance inst; char *buffer; } instance_union_u; }; typedef struct instance_union instance_union; typedef char *one_arg; #define XRY_MAX_OBJ_NAME 32 /* now open_connex() routine which establishes a connection to server */ enum debug_type { DEBTYP_PROCESS = 0, DEBTYP_C_ACTOR = 1, DEBTYP_KERNEL = 2, DEBTYP_OTHER = 3, }; typedef enum debug_type debug_type; #define DEBUGGER_IS_GDB 0x2 /* */ struct open_in { u_char back_port[16]; u_short debug_type; u_short flags; u_char destination[16]; one_arg user_name; }; typedef struct open_in open_in; struct open_out { u_long port; u_int pad[4]; u_int fp; u_char cmd_table_num; u_char cmd_table_vers; u_short server_vers; }; typedef struct open_out open_out; /* now close_connex() routine which detaches from server */ enum close_control { CLOSE_IGNORE = 0, CLOSE_KILL = 1, CLOSE_DETACH = 2, }; typedef enum close_control close_control; struct close_in { close_control control; }; typedef struct close_in close_in; /* now send_signal() routine which sends signals to processes like kill(2) */ struct signal_in { int pid; int sig; }; typedef struct signal_in signal_in; struct signal_out { int kill_return; int errNo; }; typedef struct signal_out signal_out; /* now wait_info() routine which returns results of polling the wait status of a process/actor. It may return 0 if running, else pid or -1 */ enum stop_code { STOP_ERROR = 0, STOP_NONE = 1, STOP_UNKNOWN = 2, STOP_BREAK = 3, STOP_STEP = 4, STOP_SIGNAL = 5, STOP_TERM_EXIT = 6, STOP_TERM_SIG = 7, STOP_DETACHED = 8, STOP_KILLED = 9, STOP_SPAWN_FAILED = 10, }; typedef enum stop_code stop_code; struct wait_in { int pid; }; typedef struct wait_in wait_in; struct wait_out { int wait_return; int errNo; int status; stop_code reason; int handle; u_long PC; u_long SP; u_long FP; u_long thread; }; typedef struct wait_out wait_out; /* now ptrace() routine. This matches the Sun UNIX ptrace as well as some additions */ #define PTRFLG_FORCE 1 #define PTRFLG_NON_OWNER 2 #define PTRFLG_FREE 4 #define PTRDET_UNOWN 0x100 struct ptrace_in { int pid; ptrace_addr_data_in addr; u_int data; u_int flags; }; typedef struct ptrace_in ptrace_in; struct ptrace_out { ptrace_addr_data_out addr; int result; int errNo; }; typedef struct ptrace_out ptrace_out; struct one_symbol { char *symbolName; long symbolValue; }; typedef struct one_symbol one_symbol; typedef struct { u_int all_symbols_len; one_symbol *all_symbols_val; } all_symbols; struct get_global_symbols_out { all_symbols symbols; }; typedef struct get_global_symbols_out get_global_symbols_out; struct get_text_data_in { int pid; char *actorName; }; typedef struct get_text_data_in get_text_data_in; struct get_text_data_out { int result; int errNo; u_long textStart; u_long textSize; u_long dataStart; u_long dataSize; }; typedef struct get_text_data_out get_text_data_out; struct one_signal { u_int number; char *name; }; typedef struct one_signal one_signal; typedef struct { u_int all_signals_len; one_signal *all_signals_val; } all_signals; struct get_signal_names_out { all_signals signals; }; typedef struct get_signal_names_out get_signal_names_out; /* now define the actual calls we support */ #define REMDEB_H #endif #define REMOTEDEB 0x20000fff #define REMOTEVERS 2 #if defined(__STDC__) || defined(__cplusplus) #define OPEN_CONNEX 1 extern open_out * open_connex_2(open_in *, CLIENT *); extern open_out * open_connex_2_svc(open_in *, struct svc_req *); #define SEND_SIGNAL 2 extern signal_out * send_signal_2(signal_in *, CLIENT *); extern signal_out * send_signal_2_svc(signal_in *, struct svc_req *); #define CLOSE_CONNEX 10 extern void * close_connex_2(close_in *, CLIENT *); extern void * close_connex_2_svc(close_in *, struct svc_req *); #define PTRACE 11 extern ptrace_out * ptrace_2(ptrace_in *, CLIENT *); extern ptrace_out * ptrace_2_svc(ptrace_in *, struct svc_req *); #define WAIT_INFO 13 extern wait_out * wait_info_2(wait_in *, CLIENT *); extern wait_out * wait_info_2_svc(wait_in *, struct svc_req *); #define GET_SIGNAL_NAMES 17 extern get_signal_names_out * get_signal_names_2(void *, CLIENT *); extern get_signal_names_out * get_signal_names_2_svc(void *, struct svc_req *); extern int remotedeb_2_freeresult (SVCXPRT *, xdrproc_t, caddr_t); #else /* K&R C */ #define OPEN_CONNEX 1 extern open_out * open_connex_2(); extern open_out * open_connex_2_svc(); #define SEND_SIGNAL 2 extern signal_out * send_signal_2(); extern signal_out * send_signal_2_svc(); #define CLOSE_CONNEX 10 extern void * close_connex_2(); extern void * close_connex_2_svc(); #define PTRACE 11 extern ptrace_out * ptrace_2(); extern ptrace_out * ptrace_2_svc(); #define WAIT_INFO 13 extern wait_out * wait_info_2(); extern wait_out * wait_info_2_svc(); #define GET_SIGNAL_NAMES 17 extern get_signal_names_out * get_signal_names_2(); extern get_signal_names_out * get_signal_names_2_svc(); extern int remotedeb_2_freeresult (); #endif /* K&R C */ /* the xdr functions */ #if defined(__STDC__) || defined(__cplusplus) extern bool_t xdr_rpc_type (XDR *, rpc_type*); extern bool_t xdr_UDP_MSG (XDR *, UDP_MSG*); extern bool_t xdr_ptracereq (XDR *, ptracereq*); extern bool_t xdr_xdr_regs (XDR *, xdr_regs*); extern bool_t xdr_xdr_mem (XDR *, xdr_mem*); extern bool_t xdr_break_type (XDR *, break_type*); extern bool_t xdr_xdr_break (XDR *, xdr_break*); extern bool_t xdr_thread_name (XDR *, thread_name*); extern bool_t xdr_KernThread (XDR *, KernThread*); extern bool_t xdr_thread_list (XDR *, thread_list*); extern bool_t xdr_ptrace_addr_data_in (XDR *, ptrace_addr_data_in*); extern bool_t xdr_ptrace_addr_data_out (XDR *, ptrace_addr_data_out*); extern bool_t xdr_CHAR_DATA (XDR *, CHAR_DATA*); extern bool_t xdr_xry_inst (XDR *, xry_inst*); extern bool_t xdr_instance (XDR *, instance*); extern bool_t xdr_instance_union (XDR *, instance_union*); extern bool_t xdr_one_arg (XDR *, one_arg*); extern bool_t xdr_debug_type (XDR *, debug_type*); extern bool_t xdr_open_in (XDR *, open_in*); extern bool_t xdr_open_out (XDR *, open_out*); extern bool_t xdr_close_control (XDR *, close_control*); extern bool_t xdr_close_in (XDR *, close_in*); extern bool_t xdr_signal_in (XDR *, signal_in*); extern bool_t xdr_signal_out (XDR *, signal_out*); extern bool_t xdr_stop_code (XDR *, stop_code*); extern bool_t xdr_wait_in (XDR *, wait_in*); extern bool_t xdr_wait_out (XDR *, wait_out*); extern bool_t xdr_ptrace_in (XDR *, ptrace_in*); extern bool_t xdr_ptrace_out (XDR *, ptrace_out*); extern bool_t xdr_one_symbol (XDR *, one_symbol*); extern bool_t xdr_all_symbols (XDR *, all_symbols*); extern bool_t xdr_get_global_symbols_out (XDR *, get_global_symbols_out*); extern bool_t xdr_get_text_data_in (XDR *, get_text_data_in*); extern bool_t xdr_get_text_data_out (XDR *, get_text_data_out*); extern bool_t xdr_one_signal (XDR *, one_signal*); extern bool_t xdr_all_signals (XDR *, all_signals*); extern bool_t xdr_get_signal_names_out (XDR *, get_signal_names_out*); #else /* K&R C */ extern bool_t xdr_rpc_type (); extern bool_t xdr_UDP_MSG (); extern bool_t xdr_ptracereq (); extern bool_t xdr_xdr_regs (); extern bool_t xdr_xdr_mem (); extern bool_t xdr_break_type (); extern bool_t xdr_xdr_break (); extern bool_t xdr_thread_name (); extern bool_t xdr_KernThread (); extern bool_t xdr_thread_list (); extern bool_t xdr_ptrace_addr_data_in (); extern bool_t xdr_ptrace_addr_data_out (); extern bool_t xdr_CHAR_DATA (); extern bool_t xdr_xry_inst (); extern bool_t xdr_instance (); extern bool_t xdr_instance_union (); extern bool_t xdr_one_arg (); extern bool_t xdr_debug_type (); extern bool_t xdr_open_in (); extern bool_t xdr_open_out (); extern bool_t xdr_close_control (); extern bool_t xdr_close_in (); extern bool_t xdr_signal_in (); extern bool_t xdr_signal_out (); extern bool_t xdr_stop_code (); extern bool_t xdr_wait_in (); extern bool_t xdr_wait_out (); extern bool_t xdr_ptrace_in (); extern bool_t xdr_ptrace_out (); extern bool_t xdr_one_symbol (); extern bool_t xdr_all_symbols (); extern bool_t xdr_get_global_symbols_out (); extern bool_t xdr_get_text_data_in (); extern bool_t xdr_get_text_data_out (); extern bool_t xdr_one_signal (); extern bool_t xdr_all_signals (); extern bool_t xdr_get_signal_names_out (); #endif /* K&R C */ #ifdef __cplusplus } #endif #endif /* !_REMDEB_H_RPCGEN */
Go to most recent revision | Compare with Previous | Blame | View Log