common.h revision f728123bd75a65a6a1536e198c3c30719e494e71
1#ifndef _HCK_LTRACE_H
2#define _HCK_LTRACE_H
3
4#include <sys/types.h>
5#include <sys/time.h>
6#include <stdio.h>
7
8#include "defs.h"
9#include "dict.h"
10
11/* BREAKPOINT_LENGTH is defined in "sysdep.h" */
12#include "sysdep.h"
13
14#define MAX_LIBRARY 30
15
16#if defined HAVE_LIBIBERTY || defined HAVE_LIBSUPC__
17# define USE_DEMANGLE
18#endif
19
20extern char *command;
21
22extern int exiting;  /* =1 if we have to exit ASAP */
23
24typedef struct Breakpoint Breakpoint;
25struct Breakpoint {
26	void *addr;
27	unsigned char orig_value[BREAKPOINT_LENGTH];
28	int enabled;
29	struct library_symbol *libsym;
30#ifdef __arm__
31	int thumb_mode;
32#endif
33};
34
35enum arg_type {
36	ARGTYPE_UNKNOWN = -1,
37	ARGTYPE_VOID,
38	ARGTYPE_INT,
39	ARGTYPE_UINT,
40	ARGTYPE_LONG,
41	ARGTYPE_ULONG,
42	ARGTYPE_OCTAL,
43	ARGTYPE_CHAR,
44	ARGTYPE_SHORT,
45	ARGTYPE_USHORT,
46	ARGTYPE_FLOAT,		/* float value, may require index */
47	ARGTYPE_DOUBLE,		/* double value, may require index */
48	ARGTYPE_ADDR,
49	ARGTYPE_FILE,
50	ARGTYPE_FORMAT,		/* printf-like format */
51	ARGTYPE_STRING,		/* NUL-terminated string */
52	ARGTYPE_STRING_N,	/* String of known maxlen */
53	ARGTYPE_ARRAY,		/* Series of values in memory */
54	ARGTYPE_ENUM,		/* Enumeration */
55	ARGTYPE_STRUCT,		/* Structure of values */
56	ARGTYPE_POINTER,	/* Pointer to some other type */
57	ARGTYPE_COUNT		/* number of ARGTYPE_* values */
58};
59
60typedef struct arg_type_info_t {
61	enum arg_type type;
62	union {
63		/* ARGTYPE_ENUM */
64		struct {
65			size_t entries;
66			char **keys;
67			int *values;
68		} enum_info;
69
70		/* ARGTYPE_ARRAY */
71		struct {
72			struct arg_type_info_t *elt_type;
73			size_t elt_size;
74			int len_spec;
75		} array_info;
76
77		/* ARGTYPE_STRING_N */
78		struct {
79			int size_spec;
80		} string_n_info;
81
82		/* ARGTYPE_STRUCT */
83		struct {
84			struct arg_type_info_t **fields;	/* NULL-terminated */
85			size_t *offset;
86			size_t size;
87		} struct_info;
88
89		/* ARGTYPE_POINTER */
90		struct {
91			struct arg_type_info_t *info;
92		} ptr_info;
93
94		/* ARGTYPE_FLOAT */
95		struct {
96			size_t float_index;
97		} float_info;
98
99		/* ARGTYPE_DOUBLE */
100		struct {
101			size_t float_index;
102		} double_info;
103	} u;
104} arg_type_info;
105
106enum tof {
107	LT_TOF_NONE = 0,
108	LT_TOF_FUNCTION,	/* A real library function */
109	LT_TOF_FUNCTIONR,	/* Return from a real library function */
110	LT_TOF_SYSCALL,		/* A syscall */
111	LT_TOF_SYSCALLR,	/* Return from a syscall */
112	LT_TOF_STRUCT		/* Not a function; read args from struct */
113};
114
115typedef struct Function Function;
116struct Function {
117	const char *name;
118	arg_type_info *return_info;
119	int num_params;
120	arg_type_info *arg_info[MAX_ARGS];
121	int params_right;
122	Function *next;
123};
124
125enum toplt {
126	LS_TOPLT_NONE = 0,	/* PLT not used for this symbol. */
127	LS_TOPLT_EXEC,		/* PLT for this symbol is executable. */
128	LS_TOPLT_POINT		/* PLT for this symbol is a non-executable. */
129};
130
131extern Function *list_of_functions;
132extern char *PLTs_initialized_by_here;
133
134struct library_symbol {
135	char *name;
136	void *enter_addr;
137	char needs_init;
138	enum toplt plt_type;
139	char is_weak;
140	struct library_symbol *next;
141};
142
143struct callstack_element {
144	union {
145		int syscall;
146		struct library_symbol *libfunc;
147	} c_un;
148	int is_syscall;
149	void *return_addr;
150	struct timeval time_spent;
151};
152
153#define MAX_CALLDEPTH 64
154
155typedef enum Process_State Process_State;
156enum Process_State {
157	STATE_ATTACHED = 0,
158	STATE_BEING_CREATED,
159	STATE_IGNORED  /* ignore this process (it's a fork and no -f was used) */
160};
161
162typedef struct Process Process;
163struct Process {
164	Process_State state;
165	Process *parent;          /* needed by STATE_BEING_CREATED */
166	char *filename;
167	pid_t pid;
168	struct dict *breakpoints;
169	int breakpoints_enabled;  /* -1:not enabled yet, 0:disabled, 1:enabled */
170	int mask_32bit;           /* 1 if 64-bit ltrace is tracing 32-bit process */
171	unsigned int personality;
172	int tracesysgood;         /* signal indicating a PTRACE_SYSCALL trap */
173
174	int callstack_depth;
175	struct callstack_element callstack[MAX_CALLDEPTH];
176	struct library_symbol *list_of_symbols;
177
178	/* Arch-dependent: */
179	void *instruction_pointer;
180	void *stack_pointer;      /* To get return addr, args... */
181	void *return_addr;
182	Breakpoint *breakpoint_being_enabled;
183	void *arch_ptr;
184	short e_machine;
185	short need_to_reinitialize_breakpoints;
186#ifdef __arm__
187	int thumb_mode;           /* ARM execution mode: 0: ARM, 1: Thumb */
188#endif
189
190	/* output: */
191	enum tof type_being_displayed;
192
193	Process *next;
194};
195
196typedef struct Event Event;
197struct Event {
198	Process *proc;
199	enum {
200		EVENT_NONE,
201		EVENT_SIGNAL,
202		EVENT_EXIT,
203		EVENT_EXIT_SIGNAL,
204		EVENT_SYSCALL,
205		EVENT_SYSRET,
206		EVENT_ARCH_SYSCALL,
207		EVENT_ARCH_SYSRET,
208		EVENT_CLONE,
209		EVENT_EXEC,
210		EVENT_BREAKPOINT,
211		EVENT_NEW       /* in this case, proc is NULL */
212	} type;
213	union {
214		int ret_val;    /* EVENT_EXIT */
215		int signum;     /* EVENT_SIGNAL, EVENT_EXIT_SIGNAL */
216		int sysnum;     /* EVENT_SYSCALL, EVENT_SYSRET */
217		void *brk_addr; /* EVENT_BREAKPOINT */
218		int newpid;     /* EVENT_CLONE, EVENT_NEW */
219	} e_un;
220};
221
222struct opt_c_struct {
223	int count;
224	struct timeval tv;
225};
226extern struct dict *dict_opt_c;
227
228extern Process *list_of_processes;
229
230extern void *instruction_pointer;
231
232extern Event *next_event(void);
233extern Process * pid2proc(pid_t pid);
234extern void process_event(Event *event);
235extern void execute_program(Process *, char **);
236extern int display_arg(enum tof type, Process *proc, int arg_num, arg_type_info *info);
237extern Breakpoint *address2bpstruct(Process *proc, void *addr);
238extern void breakpoints_init(Process *proc);
239extern void insert_breakpoint(Process *proc, void *addr, struct library_symbol *libsym);
240extern void delete_breakpoint(Process *proc, void *addr);
241extern void enable_all_breakpoints(Process *proc);
242extern void disable_all_breakpoints(Process *proc);
243extern void reinitialize_breakpoints(Process *);
244
245extern Process *open_program(char *filename, pid_t pid);
246extern void open_pid(pid_t pid, int verbose);
247extern void show_summary(void);
248extern arg_type_info *lookup_prototype(enum arg_type at);
249
250/* Arch-dependent stuff: */
251extern char *pid2name(pid_t pid);
252extern void trace_set_options(Process *proc, pid_t pid);
253extern void trace_me(void);
254extern int trace_pid(pid_t pid);
255extern void untrace_pid(pid_t pid);
256extern void get_arch_dep(Process *proc);
257extern void *get_instruction_pointer(Process *proc);
258extern void set_instruction_pointer(Process *proc, void *addr);
259extern void *get_stack_pointer(Process *proc);
260extern void *get_return_addr(Process *proc, void *stack_pointer);
261extern void enable_breakpoint(pid_t pid, Breakpoint *sbp);
262extern void disable_breakpoint(pid_t pid, const Breakpoint *sbp);
263extern int syscall_p(Process *proc, int status, int *sysnum);
264extern void continue_process(pid_t pid);
265extern void continue_after_signal(pid_t pid, int signum);
266extern void continue_after_breakpoint(Process *proc, Breakpoint *sbp);
267extern void continue_enabling_breakpoint(pid_t pid, Breakpoint *sbp);
268extern long gimme_arg(enum tof type, Process *proc, int arg_num, arg_type_info *info);
269extern void save_register_args(enum tof type, Process *proc);
270extern int umovestr(Process *proc, void *addr, int len, void *laddr);
271extern int umovelong (Process *proc, void *addr, long *result, arg_type_info *info);
272extern int ffcheck(void *maddr);
273extern void *sym2addr(Process *, struct library_symbol *);
274
275#if 0				/* not yet */
276extern int umoven(Process *proc, void *addr, int len, void *laddr);
277#endif
278
279#endif
280