#ifdef SHx
#undef SH4
-#define SH4 /* Just to get all of the CONTEXT defines. */
+#define SH4 /* Just to get all of the CONTEXT defines. */
#endif
#include "defs.h"
-#include "frame.h" /* required by inferior.h */
+#include "frame.h" /* required by inferior.h */
#include "inferior.h"
#include "target.h"
#include "exceptions.h"
/* If we're not using the old Cygwin header file set, define the
following which never should have been in the generic Win32 API
- headers in the first place since they were our own invention... */
+ headers in the first place since they were our own invention... */
#ifndef _GNU_H_WINDOWS_H
#define FLAG_TRACE_BIT 0x100
#ifdef CONTEXT_FLOATING_POINT
#define CONTEXT_DEBUGGER CONTEXT_DEBUGGER0
#endif
/* The string sent by cygwin when it processes a signal.
- FIXME: This should be in a cygwin include file. */
+ FIXME: This should be in a cygwin include file. */
#define CYGWIN_SIGNAL_STRING "cygwin: signal"
#define CHECK(x) check (x, __FILE__,__LINE__)
#define DEBUG_MEM(x) if (debug_memory) printf x
#define DEBUG_EXCEPT(x) if (debug_exceptions) printf x
-static int connection_initialized = 0; /* True if we've initialized a RAPI session. */
+static int connection_initialized = 0; /* True if we've initialized a
+ RAPI session. */
-/* The directory where the stub and executable files are uploaded. */
+/* The directory where the stub and executable files are uploaded. */
static const char *remote_directory = "\\gdb";
-/* The types automatic upload available. */
+/* The types automatic upload available. */
static enum
{
UPLOAD_ALWAYS = 0,
upload_when = UPLOAD_NEWER;
/* Valid options for 'set remoteupload'. Note that options
- must track upload_when enum. */
+ must track upload_when enum. */
static struct opts
{
const char *name;
}
};
-static char *remote_upload = NULL; /* Set by set remoteupload */
+static char *remote_upload = NULL; /* Set by set remoteupload. */
static int remote_add_host = 0;
static int win32_child_thread_alive (ptid_t);
void child_kill_inferior (void);
-static int last_sig = 0; /* Set if a signal was received from the
- debugged process */
+static int last_sig = 0; /* Set if a signal was received from
+ the debugged process. */
/* Thread information structure used to track information that is
- not available in gdb's thread structure. */
+ not available in gdb's thread structure. */
typedef struct thread_info_struct
{
struct thread_info_struct *next;
HANDLE h;
char *name;
int suspend_count;
- int stepped; /* True if stepped. */
+ int stepped; /* True if stepped. */
CORE_ADDR step_pc;
unsigned long step_prev;
CONTEXT context;
{NULL};
static thread_info * thread_rec (DWORD id, int get_context);
-/* The process and thread handles for the above context. */
+/* The process and thread handles for the above context. */
static DEBUG_EVENT current_event; /* The current debug event from
- WaitForDebugEvent */
-static HANDLE current_process_handle; /* Currently executing process */
-static thread_info *current_thread; /* Info on currently selected thread */
-static thread_info *this_thread; /* Info on thread returned by wait_for_debug_event */
-static DWORD main_thread_id; /* Thread ID of the main thread */
-
-/* Counts of things. */
+ WaitForDebugEvent. */
+static HANDLE current_process_handle; /* Currently executing process. */
+static thread_info *current_thread; /* Info on currently selected
+ thread. */
+static thread_info *this_thread; /* Info on thread returned by
+ wait_for_debug_event. */
+static DWORD main_thread_id; /* Thread ID of the main thread. */
+
+/* Counts of things. */
static int exception_count = 0;
static int event_count = 0;
-/* User options. */
-static int debug_exec = 0; /* show execution */
-static int debug_events = 0; /* show events from kernel */
-static int debug_memory = 0; /* show target memory accesses */
+/* User options. */
+static int debug_exec = 0; /* show execution */
+static int debug_events = 0; /* show events from kernel */
+static int debug_memory = 0; /* show target memory accesses */
static int debug_exceptions = 0; /* show target exceptions */
/* An array of offset mappings into a Win32 Context structure.
register in it's CONTEXT structure. regptr will return zero for this
register.
- This is used by the regptr function. */
+ This is used by the regptr function. */
#define context_offset(x) ((int)&(((PCONTEXT)NULL)->x))
static const int mappings[NUM_REGS + 1] =
{
byte 1-2: length
byte 3-n: arbitrary memory.
- The interface is deterministic, i.e., if the stub expects a DWORD then
- the gdb server should send a DWORD.
+ The interface is deterministic, i.e., if the stub expects a DWORD
+ then the gdb server should send a DWORD.
*/
-/* Note: In the functions below, the `huh' parameter is a string passed from the
- function containing a descriptive string concerning the current operation.
- This is used for error reporting.
+/* Note: In the functions below, the `huh' parameter is a string
+ passed from the function containing a descriptive string concerning
+ the current operation. This is used for error reporting.
The 'what' parameter is a command id as found in wince-stub.h.
/* v-style interface for handling varying argyment list error messages.
Displays the error message in a dialog box and exits when user clicks
- on OK. */
+ on OK. */
static void
vstub_error (LPCSTR fmt, va_list * args)
{
error ("%s", buf);
}
-/* The standard way to display an error message and exit. */
+/* The standard way to display an error message and exit. */
static void
stub_error (LPCSTR fmt,...)
{
vstub_error (fmt, args);
}
-/* Standard "oh well" can't communicate error. Someday this might attempt
- synchronization. */
+/* Standard "oh well" can't communicate error. Someday this might
+ attempt synchronization. */
static void
attempt_resync (LPCSTR huh, int s)
{
stub_error ("lost synchronization with target attempting %s", huh);
}
-/* Read arbitrary stuff from a socket. */
+/* Read arbitrary stuff from a socket. */
static int
sockread (LPCSTR huh, int s, void *str, size_t n)
{
}
}
-/* Write arbitrary stuff to a socket. */
+/* Write arbitrary stuff to a socket. */
static int
sockwrite (LPCSTR huh, const void *str, size_t n)
{
}
}
-/* Output an id/dword to the host */
+/* Output an id/dword to the host. */
static void
putdword (LPCSTR huh, gdb_wince_id what, DWORD n)
{
stub_error ("error writing %s to host.", huh);
}
-/* Output an id/word to the host */
+/* Output an id/word to the host. */
static void
putword (LPCSTR huh, gdb_wince_id what, WORD n)
{
stub_error ("error writing %s host.", huh);
}
-/* Convenience define for outputting a "gdb_wince_len" type. */
+/* Convenience define for outputting a "gdb_wince_len" type. */
#define putlen(huh, what, n) putword((huh), (what), (gdb_wince_len) (n))
/* Put an arbitrary block of memory to the gdb host. This comes in
- two chunks an id/dword representing the length and the stream of memory
- itself. */
+ two chunks an id/dword representing the length and the stream of
+ memory itself. */
static void
-putmemory (LPCSTR huh, gdb_wince_id what, const void *mem, gdb_wince_len len)
+putmemory (LPCSTR huh, gdb_wince_id what,
+ const void *mem, gdb_wince_len len)
{
putlen (huh, what, len);
if (((short) len > 0) && sockwrite (huh, mem, len) != len)
stub_error ("error writing %s to host.", huh);
}
-/* Output the result of an operation to the host. If res != 0, sends a block of
- memory starting at mem of len bytes. If res == 0, sends -GetLastError () and
- avoids sending the mem. */
+/* Output the result of an operation to the host. If res != 0, sends
+ a block of memory starting at mem of len bytes. If res == 0, sends
+ -GetLastError () and avoids sending the mem. */
static DWORD
getdword (LPCSTR huh, gdb_wince_id what_this)
{
/* Get a an ID (possibly) and a WORD from the host gdb.
Don't bother with the id if the main loop has already
- read it. */
+ read it. */
static WORD
getword (LPCSTR huh, gdb_wince_id what_this)
{
return n;
}
-/* Handy defines for getting/putting various types of values. */
+/* Handy defines for getting/putting various types of values. */
#define gethandle(huh, what) (HANDLE) getdword ((huh), (what))
#define getpvoid(huh, what) (LPVOID) getdword ((huh), (what))
#define getlen(huh, what) (gdb_wince_len) getword ((huh), (what))
#define puthandle(huh, what, h) putdword ((huh), (what), (DWORD) (h))
#define putpvoid(huh, what, p) putdword ((huh), (what), (DWORD) (p))
-/* Retrieve the result of an operation from the stub. If nbytes < 0) then nbytes
- is actually an error and nothing else follows. Use SetLastError to remember this.
- if nbytes > 0, retrieve a block of *nbytes into buf.
+/* Retrieve the result of an operation from the stub. If nbytes < 0)
+ then nbytes is actually an error and nothing else follows. Use
+ SetLastError to remember this. if nbytes > 0, retrieve a block of
+ *nbytes into buf.
*/
int
-getresult (LPCSTR huh, gdb_wince_id what, LPVOID buf, gdb_wince_len * nbytes)
+getresult (LPCSTR huh, gdb_wince_id what, LPVOID buf,
+ gdb_wince_len * nbytes)
{
gdb_wince_len dummy;
if (nbytes == NULL)
{
static int n = -1;
static LPWSTR outs[8] =
- {NULL /*, NULL, etc. */ };
+ {NULL /*, NULL, etc. */ };
gdb_wince_len dummy;
if (!out_len)
out_len = &dummy;
- /* First determine the length required to hold the converted string. */
- *out_len = sizeof (WCHAR) * MultiByteToWideChar (CP_ACP, 0, s, -1, NULL, 0);
+ /* First determine the length required to hold the converted string. */
+ *out_len = sizeof (WCHAR) * MultiByteToWideChar (CP_ACP, 0, s,
+ -1, NULL, 0);
if (!*out_len)
- return NULL; /* The conversion failed */
+ return NULL; /* The conversion failed. */
if (++n >= (sizeof (outs) / sizeof (outs[0])))
n = 0; /* wrap */
- /* Allocate space for the converted string, reusing any previously allocated
- space, if applicable. Note that if outs[n] is NULL, xrealloc will act as
- a malloc (under cygwin, at least).
+ /* Allocate space for the converted string, reusing any previously
+ allocated space, if applicable. Note that if outs[n] is NULL,
+ xrealloc will act as a malloc (under cygwin, at least).
*/
outs[n] = (LPWSTR) xrealloc (outs[n], *out_len);
memset (outs[n], 0, *out_len);
/******************** Emulation routines start here. ********************
- The functions below are modelled after their Win32 counterparts. They are named
- similarly to Win32 and take exactly the same arguments except where otherwise noted.
- They communicate with the stub on the hand-held device by sending their arguments
- over the socket and waiting for results from the socket.
-
- There is one universal change. In cases where a length is expected to be returned
- in a DWORD, we use a gdb_wince_len type instead. Currently this is an unsigned short
- which is smaller than the standard Win32 DWORD. This is done to minimize unnecessary
- traffic since the connection to Windows CE can be slow. To change this, modify the
- typedef in wince-stub.h and change the putlen/getlen macros in this file and in
- the stub.
+ The functions below are modelled after their Win32 counterparts.
+ They are named similarly to Win32 and take exactly the same
+ arguments except where otherwise noted. They communicate with the
+ stub on the hand-held device by sending their arguments over the
+ socket and waiting for results from the socket.
+
+ There is one universal change. In cases where a length is expected
+ to be returned in a DWORD, we use a gdb_wince_len type instead.
+ Currently this is an unsigned short which is smaller than the
+ standard Win32 DWORD. This is done to minimize unnecessary traffic
+ since the connection to Windows CE can be slow. To change this,
+ modify the typedef in wince-stub.h and change the putlen/getlen
+ macros in this file and in the stub.
*/
static int
-create_process (LPSTR exec_file, LPSTR args, DWORD flags, PROCESS_INFORMATION * pi)
+create_process (LPSTR exec_file, LPSTR args, DWORD flags,
+ PROCESS_INFORMATION * pi)
{
gdb_wince_len len;
LPWSTR buf;
return getresult ("CreateProcess result", GDB_CREATEPROCESS, pi, NULL);
}
-/* Emulate TerminateProcess. Don't bother with the second argument since CE
- ignores it.
+/* Emulate TerminateProcess.
+ Don't bother with the second argument since CE ignores it.
*/
static int
terminate_process (HANDLE h)
if (s < 0)
return 1;
puthandle ("TerminateProcess handle", GDB_TERMINATEPROCESS, h);
- return getresult ("TerminateProcess result", GDB_TERMINATEPROCESS, &res, NULL);
+
+ return getresult ("TerminateProcess result",
+ GDB_TERMINATEPROCESS, &res, NULL);
}
static int
if (s < 0)
return 1;
putdword ("WaitForDebugEvent ms", GDB_WAITFORDEBUGEVENT, ms);
- return getresult ("WaitForDebugEvent event", GDB_WAITFORDEBUGEVENT, ev, NULL);
+
+ return getresult ("WaitForDebugEvent event",
+ GDB_WAITFORDEBUGEVENT, ev, NULL);
}
static int
if (s < 0)
return 1;
puthandle ("GetThreadContext handle", GDB_GETTHREADCONTEXT, h);
- putdword ("GetThreadContext flags", GDB_GETTHREADCONTEXT, c->ContextFlags);
- return getresult ("GetThreadContext context", GDB_GETTHREADCONTEXT, c, NULL);
+ putdword ("GetThreadContext flags", GDB_GETTHREADCONTEXT,
+ c->ContextFlags);
+
+ return getresult ("GetThreadContext context",
+ GDB_GETTHREADCONTEXT, c, NULL);
}
static int
if (s < 0)
return 1;
puthandle ("SetThreadContext handle", GDB_SETTHREADCONTEXT, h);
- putmemory ("SetThreadContext context", GDB_SETTHREADCONTEXT, c, sizeof (*c));
- return getresult ("SetThreadContext context", GDB_SETTHREADCONTEXT, &res, NULL);
+ putmemory ("SetThreadContext context", GDB_SETTHREADCONTEXT,
+ c, sizeof (*c));
+
+ return getresult ("SetThreadContext context",
+ GDB_SETTHREADCONTEXT, &res, NULL);
}
static int
-read_process_memory (HANDLE h, LPCVOID where, LPVOID buf, gdb_wince_len len, gdb_wince_len * nbytes)
+read_process_memory (HANDLE h, LPCVOID where,
+ LPVOID buf, gdb_wince_len len,
+ gdb_wince_len * nbytes)
{
if (s < 0)
return 1;
putpvoid ("ReadProcessMemory location", GDB_READPROCESSMEMORY, where);
putlen ("ReadProcessMemory size", GDB_READPROCESSMEMORY, len);
- return getresult ("ReadProcessMemory buf", GDB_READPROCESSMEMORY, buf, nbytes);
+ return getresult ("ReadProcessMemory buf",
+ GDB_READPROCESSMEMORY, buf, nbytes);
}
static int
-write_process_memory (HANDLE h, LPCVOID where, LPCVOID buf, gdb_wince_len len, gdb_wince_len * nbytes)
+write_process_memory (HANDLE h, LPCVOID where,
+ LPCVOID buf, gdb_wince_len len,
+ gdb_wince_len * nbytes)
{
if (s < 0)
return 1;
putpvoid ("WriteProcessMemory location", GDB_WRITEPROCESSMEMORY, where);
putmemory ("WriteProcProcessMemory buf", GDB_WRITEPROCESSMEMORY, buf, len);
- return getresult ("WriteProcessMemory result", GDB_WRITEPROCESSMEMORY, nbytes, NULL);
+ return getresult ("WriteProcessMemory result",
+ GDB_WRITEPROCESSMEMORY, nbytes, NULL);
}
static int
remote_read_bytes (CORE_ADDR memaddr, char *myaddr, int len)
{
gdb_wince_len nbytes;
- if (!read_process_memory (current_process_handle, (LPCVOID) memaddr,
- (LPVOID) myaddr, len, &nbytes))
+ if (!read_process_memory (current_process_handle,
+ (LPCVOID) memaddr,
+ (LPVOID) myaddr,
+ len, &nbytes))
return -1;
return nbytes;
}
remote_write_bytes (CORE_ADDR memaddr, char *myaddr, int len)
{
gdb_wince_len nbytes;
- if (!write_process_memory (current_process_handle, (LPCVOID) memaddr,
- (LPCVOID) myaddr, len, &nbytes))
+ if (!write_process_memory (current_process_handle,
+ (LPCVOID) memaddr,
+ (LPCVOID) myaddr,
+ len, &nbytes))
return -1;
return nbytes;
}
-/* This is not a standard Win32 function. It instructs the stub to return TRUE
- if the thread referenced by HANDLE h is alive.
+/* This is not a standard Win32 function. It instructs the stub to
+ return TRUE if the thread referenced by HANDLE h is alive.
*/
static int
thread_alive (HANDLE h)
putdword ("ContinueDebugEvent pid", GDB_CONTINUEDEBUGEVENT, pid);
putdword ("ContinueDebugEvent tid", GDB_CONTINUEDEBUGEVENT, tid);
putdword ("ContinueDebugEvent status", GDB_CONTINUEDEBUGEVENT, status);
- return getresult ("ContinueDebugEvent result", GDB_CONTINUEDEBUGEVENT, &res, NULL);
+ return getresult ("ContinueDebugEvent result",
+ GDB_CONTINUEDEBUGEVENT, &res, NULL);
}
static int
if (s < 0)
return 1;
puthandle ("CloseHandle handle", GDB_CLOSEHANDLE, h);
- return (int) getresult ("CloseHandle result", GDB_CLOSEHANDLE, &res, NULL);
+ return (int) getresult ("CloseHandle result",
+ GDB_CLOSEHANDLE, &res, NULL);
}
-/* This is not a standard Win32 interface. This function tells the stub
- to terminate.
+/* This is not a standard Win32 interface. This function tells the
+ stub to terminate.
*/
static void
stop_stub (void)
int insert_breakpoints_p)
{
unsigned long pc;
- thread_info *th = current_thread; /* Info on currently selected thread */
+ /* Info on currently selected thread. */
+ thread_info *th = current_thread;
CORE_ADDR mips_next_pc (CORE_ADDR pc);
if (!insert_breakpoints_p)
wince_software_single_step (enum target_signal ignore,
int insert_breakpoints_p)
{
- thread_info *th = current_thread; /* Info on currently selected thread */
+ /* Info on currently selected thread. */
+ thread_info *th = current_thread;
if (!insert_breakpoints_p)
{
int insert_breakpoints_p)
{
unsigned long pc;
- thread_info *th = current_thread; /* Info on currently selected thread */
+ /* Info on currently selected thread. */
+ thread_info *th = current_thread;
CORE_ADDR mips_next_pc (CORE_ADDR pc);
if (!insert_breakpoints_p)
#endif
/* Find a thread record given a thread id.
- If get_context then also retrieve the context for this
- thread. */
+ If get_context then also retrieve the context for this thread. */
+
static thread_info *
thread_rec (DWORD id, int get_context)
{
}
return th;
}
-
return NULL;
}
-/* Add a thread to the thread list */
+/* Add a thread to the thread list. */
static thread_info *
child_add_thread (DWORD id, HANDLE h)
{
}
/* Clear out any old thread list and reintialize it to a
- pristine state. */
+ pristine state. */
static void
child_init_thread_list (void)
{
}
}
-/* Delete a thread from the list of threads */
+/* Delete a thread from the list of threads. */
static void
child_delete_thread (DWORD id)
{
check (BOOL ok, const char *file, int line)
{
if (!ok)
- printf_filtered ("error return %s:%d was %d\n", file, line, GetLastError ());
+ printf_filtered ("error return %s:%d was %d\n",
+ file, line, GetLastError ());
}
static void
}
}
-/* Store a new register value into the current thread context */
+/* Store a new register value into the current thread context. */
static void
child_store_inferior_registers (int r)
{
if (!event->fUnicode)
memcpy (dll_name, dll_buf, len);
else
- WideCharToMultiByte (CP_ACP, 0, (LPCWSTR) dll_buf, len,
- dll_name, len, 0, 0);
+ WideCharToMultiByte (CP_ACP, 0, (LPCWSTR) dll_buf,
+ len, dll_name, len, 0, 0);
while ((p = strchr (dll_name, '\\')))
*p = '/';
- /* FIXME!! It would be nice to define one symbol which pointed to the
- front of the dll if we can't find any symbols. */
+ /* FIXME!! It would be nice to define one symbol which pointed to
+ the front of the dll if we can't find any symbols. */
if (!(dll_basename = strrchr (dll_name, '/')))
dll_basename = dll_name;
return 1;
}
-/* Handle DEBUG_STRING output from child process. */
+/* Handle DEBUG_STRING output from child process. */
static void
handle_output_debug_string (struct target_waitstatus *ourstatus)
{
return;
memset (s, 0, sizeof (s));
- WideCharToMultiByte (CP_ACP, 0, (LPCWSTR) p, (int) nbytes_read, s,
- sizeof (s) - 1, NULL, NULL);
+ WideCharToMultiByte (CP_ACP, 0, (LPCWSTR) p, (int) nbytes_read,
+ s, sizeof (s) - 1, NULL, NULL);
q = strchr (s, '\n');
if (q != NULL)
{
return;
}
-/* Handle target exceptions. */
+/* Handle target exceptions. */
static int
handle_exception (struct target_waitstatus *ourstatus)
{
DEBUG_EXCEPT (("gdb: Target exception CONTROL_C at 0x%08x\n",
(unsigned) current_event.u.Exception.ExceptionRecord.ExceptionAddress));
ourstatus->value.sig = TARGET_SIGNAL_INT;
- /* User typed CTRL-C. Continue with this status */
- last_sig = SIGINT; /* FIXME - should check pass state */
+ /* User typed CTRL-C. Continue with this status. */
+ last_sig = SIGINT; /* FIXME - should check pass state. */
break;
case EXCEPTION_SINGLE_STEP:
DEBUG_EXCEPT (("gdb: Target exception SINGLE_STEP at 0x%08x\n",
break;
case EXCEPTION_ILLEGAL_INSTRUCTION:
DEBUG_EXCEPT (("gdb: Target exception SINGLE_ILL at 0x%08x\n",
- current_event.u.Exception.ExceptionRecord.ExceptionAddress));
- ourstatus->value.sig = check_for_step (¤t_event, TARGET_SIGNAL_ILL);
+ /* (unsigned)? */ current_event.u.Exception.ExceptionRecord.ExceptionAddress));
+ ourstatus->value.sig = check_for_step (¤t_event,
+ TARGET_SIGNAL_ILL);
break;
default:
/* This may be a structured exception handling exception. In
that case, we want to let the program try to handle it, and
only break if we see the exception a second time. */
- printf_unfiltered ("gdb: unknown target exception 0x%08x at 0x%08x\n",
- current_event.u.Exception.ExceptionRecord.ExceptionCode,
- current_event.u.Exception.ExceptionRecord.ExceptionAddress);
+ printf_unfiltered
+ ("gdb: unknown target exception 0x%08x at 0x%08x\n",
+ current_event.u.Exception.ExceptionRecord.ExceptionCode,
+ current_event.u.Exception.ExceptionRecord.ExceptionAddress);
ourstatus->value.sig = TARGET_SIGNAL_UNKNOWN;
break;
}
}
/* Resume all artificially suspended threads if we are continuing
- execution */
+ execution. */
static BOOL
child_continue (DWORD continue_status, int id)
{
BOOL res;
DEBUG_EVENTS (("ContinueDebugEvent (cpid=%d, ctid=%d, DBG_CONTINUE);\n",
- (unsigned) current_event.dwProcessId, (unsigned) current_event.dwThreadId));
+ (unsigned) current_event.dwProcessId,
+ (unsigned) current_event.dwThreadId));
res = continue_debug_event (current_event.dwProcessId,
current_event.dwThreadId,
continue_status);
(unsigned) current_event.dwProcessId,
(unsigned) current_event.dwThreadId,
"LOAD_DLL_DEBUG_EVENT"));
- catch_errors (handle_load_dll, NULL, (char *) "", RETURN_MASK_ALL);
+ catch_errors (handle_load_dll, NULL,
+ (char *) "", RETURN_MASK_ALL);
registers_changed (); /* mark all regs invalid */
break;
}
if (breakout)
- this_thread = current_thread = th ?: thread_rec (current_event.dwThreadId, TRUE);
+ this_thread = current_thread = th ?: thread_rec (current_event.dwThreadId,
+ TRUE);
else
CHECK (child_continue (continue_status, -1));
return breakout;
}
-/* Wait for interesting events to occur in the target process. */
+/* Wait for interesting events to occur in the target process. */
static ptid_t
child_wait (ptid_t ptid, struct target_waitstatus *ourstatus)
{
with a SPURIOUS because resume can try and step or modify things,
which needs a current_thread->h. But some of these exceptions mark
the birth or death of threads, which mean that the current thread
- isn't necessarily what you think it is. */
+ isn't necessarily what you think it is. */
while (1)
- if (get_child_debug_event (pid, ourstatus, EXCEPTION_DEBUG_EVENT, &retval))
+ if (get_child_debug_event (pid, ourstatus,
+ EXCEPTION_DEBUG_EVENT, &retval))
return pid_to_ptid (retval);
else
{
#define FACTOR (0x19db1ded53ea710LL)
#define NSPERSEC 10000000
-/* Convert a Win32 time to "UNIX" format. */
+/* Convert a Win32 time to "UNIX" format. */
long
to_time_t (FILETIME * ptr)
{
long rem;
long long x = ((long long) ptr->dwHighDateTime << 32) + ((unsigned) ptr->dwLowDateTime);
- x -= FACTOR; /* number of 100ns between 1601 and 1970 */
+ x -= FACTOR; /* Number of 100ns between 1601 and 1970. */
rem = x % ((long long) NSPERSEC);
rem += (NSPERSEC / 2);
- x /= (long long) NSPERSEC; /* number of 100ns in a second */
+ x /= (long long) NSPERSEC; /* Number of 100ns in a second. */
x += (long long) (rem / NSPERSEC);
return x;
}
/* Upload a file to the remote device depending on the user's
- 'set remoteupload' specification. */
+ 'set remoteupload' specification. */
char *
upload_to_device (const char *to, const char *from)
{
struct stat st;
int fd;
- /* Look for a path separator and only use trailing part. */
+ /* Look for a path separator and only use trailing part. */
while ((p = strpbrk (to, "/\\")) != NULL)
to = p + 1;
strcat (remotefile, to);
if (upload_when == UPLOAD_NEVER)
- return remotefile; /* Don't bother uploading. */
+ return remotefile; /* Don't bother uploading. */
- /* Open the source. */
- if ((fd = openp (getenv ("PATH"), OPF_TRY_CWD_FIRST, (char *) from, O_RDONLY,
- 0, NULL)) < 0)
+ /* Open the source. */
+ if ((fd = openp (getenv ("PATH"), OPF_TRY_CWD_FIRST, (char *) from,
+ O_RDONLY, 0, NULL)) < 0)
error ("couldn't open %s", from);
- /* Get the time for later comparison. */
+ /* Get the time for later comparison. */
if (fstat (fd, &st))
st.st_mtime = (time_t) - 1;
- /* Always attempt to create the directory on the remote system. */
+ /* Always attempt to create the directory on the remote system. */
wstr = towide (dir, NULL);
(void) CeCreateDirectory (wstr, NULL);
- /* Attempt to open the remote file, creating it if it doesn't exist. */
+ /* Attempt to open the remote file, creating it if it doesn't exist. */
wstr = towide (remotefile, NULL);
h = CeCreateFile (wstr, GENERIC_READ | GENERIC_WRITE, 0, NULL,
OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
- /* Some kind of problem? */
+ /* Some kind of problem? */
err = CeGetLastError ();
if (h == NULL || h == INVALID_HANDLE_VALUE)
error ("error opening file \"%s\". Windows error %d.",
printf ("%s < %s\n", buf, ctime(&st.st_mtime));
}
#endif
- /* See if we need to upload the file. */
+ /* See if we need to upload the file. */
if (upload_when == UPLOAD_ALWAYS ||
err != ERROR_ALREADY_EXISTS ||
!CeGetFileTime (h, &crtime, &actime, &wrtime) ||
char buf[4096];
int n;
- /* Upload the file. */
+ /* Upload the file. */
while ((n = read (fd, buf, sizeof (buf))) > 0)
if (!CeWriteFile (h, buf, (DWORD) n, &nbytes, NULL))
error ("error writing to remote device - %d.",
return remotefile;
}
-/* Initialize the connection to the remote device. */
+/* Initialize the connection to the remote device. */
static void
wince_initialize (void)
{
break;
}
- /* Upload the stub to the handheld device. */
+ /* Upload the stub to the handheld device. */
stub_file_name = upload_to_device ("wince-stub.exe", WINCE_STUB);
strcpy (args, stub_file_name);
error ("couldn't get hostname of this system.");
}
- /* Get a socket. */
+ /* Get a socket. */
if ((s0 = socket (AF_INET, SOCK_STREAM, 0)) < 0)
stub_error ("Couldn't connect to host system.");
- /* Allow rapid reuse of the port. */
+ /* Allow rapid reuse of the port. */
tmp = 1;
- (void) setsockopt (s0, SOL_SOCKET, SO_REUSEADDR, (char *) &tmp, sizeof (tmp));
+ (void) setsockopt (s0, SOL_SOCKET, SO_REUSEADDR,
+ (char *) &tmp, sizeof (tmp));
- /* Set up the information for connecting to the host gdb process. */
+ /* Set up the information for connecting to the host gdb process. */
memset (&sin, 0, sizeof (sin));
sin.sin_family = AF_INET;
- sin.sin_port = htons (7000); /* FIXME: This should be configurable */
+ sin.sin_port = htons (7000); /* FIXME: This should be configurable. */
if (bind (s0, (struct sockaddr *) &sin, sizeof (sin)))
error ("couldn't bind socket");
if (listen (s0, 1))
error ("Couldn't open socket for listening.\n");
- /* Start up the stub on the remote device. */
- if (!CeCreateProcess (towide (stub_file_name, NULL), towide (args, NULL),
- NULL, NULL, 0, 0, NULL, NULL, NULL, &pi))
+ /* Start up the stub on the remote device. */
+ if (!CeCreateProcess (towide (stub_file_name, NULL),
+ towide (args, NULL),
+ NULL, NULL, 0, 0,
+ NULL, NULL, NULL, &pi))
error ("Unable to start remote stub '%s'. Windows CE error %d.",
stub_file_name, CeGetLastError ());
/* Start an inferior win32 child process and sets inferior_ptid to its pid.
EXEC_FILE is the file to run.
ALLARGS is a string containing the arguments to the program.
- ENV is the environment vector to pass. Errors reported with error(). */
+ ENV is the environment vector to pass.
+ Errors reported with error(). */
static void
child_create_inferior (char *exec_file, char *args, char **env,
int from_tty)
flags = DEBUG_PROCESS;
- wince_initialize (); /* Make sure we've got a connection. */
+ wince_initialize (); /* Make sure we've got a connection. */
exec_file = upload_to_device (exec_file, exec_file);
}
memset (&pi, 0, sizeof (pi));
- /* Execute the process */
+ /* Execute the process. */
if (!create_process (exec_file, exec_and_args, flags, &pi))
- error ("Error creating process %s, (error %d)\n", exec_file, GetLastError ());
+ error ("Error creating process %s, (error %d)\n",
+ exec_file, GetLastError ());
exception_count = 0;
event_count = 0;
proceed ((CORE_ADDR) -1, TARGET_SIGNAL_0, 0);
}
-/* Chile has gone bye-bye. */
+/* Chile has gone bye-bye. */
static void
child_mourn_inferior (void)
{
generic_mourn_inferior ();
}
-/* Move memory from child to/from gdb. */
+/* Move memory from child to/from gdb. */
int
-child_xfer_memory (CORE_ADDR memaddr, char *our, int len, int write,
+child_xfer_memory (CORE_ADDR memaddr, char *our,
+ int len, int write,
struct mem_attrib *attrib,
struct target_ops *target)
{
return res;
}
-/* Terminate the process and wait for child to tell us it has completed. */
+/* Terminate the process and wait for child to tell us it has
+ completed. */
void
child_kill_inferior (void)
{
CHECK (close_handle (current_process_handle));
close_handle (current_thread->h);
- target_mourn_inferior (); /* or just child_mourn_inferior? */
+ target_mourn_inferior (); /* or just child_mourn_inferior? */
}
-/* Resume the child after an exception. */
+/* Resume the child after an exception. */
void
child_resume (ptid_t ptid, int step, enum target_signal sig)
{
thread_info *th;
DWORD continue_status = last_sig > 0 && last_sig < NSIG ?
- DBG_EXCEPTION_NOT_HANDLED : DBG_CONTINUE;
+ DBG_EXCEPTION_NOT_HANDLED : DBG_CONTINUE;
int pid = PIDGET (ptid);
DEBUG_EXEC (("gdb: child_resume (pid=%d, step=%d, sig=%d);\n",
}
/* Allow continuing with the same signal that interrupted us.
- Otherwise complain. */
+ Otherwise complain. */
if (sig && sig != last_sig)
- fprintf_unfiltered (gdb_stderr, "Can't send signals to the child. signal %d\n", sig);
+ fprintf_unfiltered (gdb_stderr,
+ "Can't send signals to the child. signal %d\n",
+ sig);
last_sig = 0;
child_continue (continue_status, pid);
child_close (void)
{
DEBUG_EVENTS (("gdb: child_close, inferior_ptid=%d\n",
- PIDGET (inferior_ptid)));
+ PIDGET (inferior_ptid)));
}
/* Explicitly upload file to remotedir */
}
-/* Handle 'set remoteupload' parameter. */
+/* Handle 'set remoteupload' parameter. */
#define replace_upload(what) \
- upload_when = what; \
- remote_upload = xrealloc (remote_upload, strlen (upload_options[upload_when].name) + 1); \
- strcpy (remote_upload, upload_options[upload_when].name);
+ upload_when = what; \
+ remote_upload = xrealloc (remote_upload, \
+ strlen (upload_options[upload_when].name) + 1); \
+ strcpy (remote_upload, upload_options[upload_when].name);
static void
set_upload_type (char *ignore, int from_tty)
}
len = strlen (remote_upload);
- for (i = 0; i < (sizeof (upload_options) / sizeof (upload_options[0])); i++)
+ for (i = 0;
+ i < (sizeof (upload_options) / sizeof (upload_options[0]));
+ i++)
if (len >= upload_options[i].abbrev &&
strncasecmp (remote_upload, upload_options[i].name, len) == 0)
{
set = add_set_cmd ((char *) "remoteupload", no_class,
var_string_noescape, (char *) &remote_upload,
- (char *) "Set how to upload executables to remote device.\n",
+ (char *) "\
+Set how to upload executables to remote device.\n",
&setlist);
+
deprecated_add_show_from_set (set, &showlist);
set_cmd_cfunc (set, set_upload_type);
set_upload_type (NULL, 0);
deprecated_add_show_from_set
- (add_set_cmd ((char *) "debugexec", class_support, var_boolean,
+ (add_set_cmd ((char *) "debugexec",
+ class_support, var_boolean,
(char *) &debug_exec,
- (char *) "Set whether to display execution in child process.",
+ (char *) "\
+Set whether to display execution in child process.",
&setlist),
&showlist);
deprecated_add_show_from_set
- (add_set_cmd ((char *) "remoteaddhost", class_support, var_boolean,
+ (add_set_cmd ((char *) "remoteaddhost",
+ class_support, var_boolean,
(char *) &remote_add_host,
(char *) "\
Set whether to add this host to remote stub arguments for\n\
-debugging over a network.", &setlist),
+debugging over a network.",
+ &setlist),
&showlist);
deprecated_add_show_from_set
- (add_set_cmd ((char *) "debugevents", class_support, var_boolean,
+ (add_set_cmd ((char *) "debugevents",
+ class_support, var_boolean,
(char *) &debug_events,
- (char *) "Set whether to display kernel events in child process.",
+ (char *) "\
+Set whether to display kernel events in child process.",
&setlist),
&showlist);
deprecated_add_show_from_set
- (add_set_cmd ((char *) "debugmemory", class_support, var_boolean,
+ (add_set_cmd ((char *) "debugmemory",
+ class_support, var_boolean,
(char *) &debug_memory,
- (char *) "Set whether to display memory accesses in child process.",
+ (char *) "\
+Set whether to display memory accesses in child process.",
&setlist),
&showlist);
- deprecated_add_show_from_set
- (add_set_cmd ((char *) "debugexceptions", class_support, var_boolean,
+ deprecated_add_show_from_set
+ (add_set_cmd ((char *) "debugexceptions",
+ class_support, var_boolean,
(char *) &debug_exceptions,
- (char *) "Set whether to display kernel exceptions in child process.",
+ (char *) "\
+Set whether to display kernel exceptions in child process.",
&setlist),
&showlist);
add_target (&deprecated_child_ops);
}
-/* Determine if the thread referenced by "pid" is alive
- by "polling" it. If WaitForSingleObject returns WAIT_OBJECT_0
- it means that the pid has died. Otherwise it is assumed to be alive. */
+/* Determine if the thread referenced by "pid" is alive by "polling"
+ it. If WaitForSingleObject returns WAIT_OBJECT_0 it means that the
+ pid has died. Otherwise it is assumed to be alive. */
static int
win32_child_thread_alive (ptid_t ptid)
{
return thread_alive (thread_rec (pid, FALSE)->h);
}
-/* Convert pid to printable format. */
+/* Convert pid to printable format. */
char *
cygwin_pid_to_str (int pid)
{
if (pid == current_event.dwProcessId)
sprintf (buf, "process %d", pid);
else
- sprintf (buf, "thread %d.0x%x", (unsigned) current_event.dwProcessId, pid);
+ sprintf (buf, "thread %d.0x%x",
+ (unsigned) current_event.dwProcessId, pid);
return buf;
}