* infrun.c (wait_for_inferior): Add treat_exec_as_sigtrap parameter
[external/binutils.git] / gdb / windows-nat.c
1 /* Target-vector operations for controlling win32 child processes, for GDB.
2
3    Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
4    2005, 2006, 2007, 2008 Free Software Foundation, Inc.
5
6    Contributed by Cygnus Solutions, A Red Hat Company.
7
8    This file is part of GDB.
9
10    This program is free software; you can redistribute it and/or modify
11    it under the terms of the GNU General Public License as published by
12    the Free Software Foundation; either version 3 of the License, or
13    (at your option) any later version.
14
15    This program is distributed in the hope that it will be useful,
16    but WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18    GNU General Public License for more details.
19
20    You should have received a copy of the GNU General Public License
21    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
22
23 /* Originally by Steve Chamberlain, sac@cygnus.com */
24
25 #include "defs.h"
26 #include "frame.h"              /* required by inferior.h */
27 #include "inferior.h"
28 #include "target.h"
29 #include "exceptions.h"
30 #include "gdbcore.h"
31 #include "command.h"
32 #include "completer.h"
33 #include "regcache.h"
34 #include "top.h"
35 #include <signal.h>
36 #include <sys/types.h>
37 #include <fcntl.h>
38 #include <stdlib.h>
39 #include <windows.h>
40 #include <imagehlp.h>
41 #ifdef __CYGWIN__
42 #include <sys/cygwin.h>
43 #endif
44 #include <signal.h>
45
46 #include "buildsym.h"
47 #include "symfile.h"
48 #include "objfiles.h"
49 #include "gdb_obstack.h"
50 #include "gdb_string.h"
51 #include "gdb_stdint.h"
52 #include "gdbthread.h"
53 #include "gdbcmd.h"
54 #include <sys/param.h>
55 #include <unistd.h>
56 #include "exec.h"
57 #include "solist.h"
58 #include "solib.h"
59 #include "xml-support.h"
60
61 #include "i386-tdep.h"
62 #include "i387-tdep.h"
63
64 #include "i386-cygwin-tdep.h"
65
66 static struct target_ops win32_ops;
67
68 #ifdef __CYGWIN__
69 /* The starting and ending address of the cygwin1.dll text segment. */
70 static bfd_vma cygwin_load_start;
71 static bfd_vma cygwin_load_end;
72 #endif
73
74 static int have_saved_context;  /* True if we've saved context from a cygwin signal. */
75 static CONTEXT saved_context;   /* Containes the saved context from a cygwin signal. */
76
77 /* If we're not using the old Cygwin header file set, define the
78    following which never should have been in the generic Win32 API
79    headers in the first place since they were our own invention... */
80 #ifndef _GNU_H_WINDOWS_H
81 enum
82   {
83     FLAG_TRACE_BIT = 0x100,
84     CONTEXT_DEBUGGER = (CONTEXT_FULL | CONTEXT_FLOATING_POINT)
85   };
86 #endif
87 #include <psapi.h>
88
89 #define CONTEXT_DEBUGGER_DR CONTEXT_DEBUGGER | CONTEXT_DEBUG_REGISTERS \
90         | CONTEXT_EXTENDED_REGISTERS
91
92 static unsigned dr[8];
93 static int debug_registers_changed;
94 static int debug_registers_used;
95 #define DR6_CLEAR_VALUE 0xffff0ff0
96
97 /* The string sent by cygwin when it processes a signal.
98    FIXME: This should be in a cygwin include file. */
99 #ifndef _CYGWIN_SIGNAL_STRING
100 #define _CYGWIN_SIGNAL_STRING "cYgSiGw00f"
101 #endif
102
103 #define CHECK(x)        check (x, __FILE__,__LINE__)
104 #define DEBUG_EXEC(x)   if (debug_exec)         printf_unfiltered x
105 #define DEBUG_EVENTS(x) if (debug_events)       printf_unfiltered x
106 #define DEBUG_MEM(x)    if (debug_memory)       printf_unfiltered x
107 #define DEBUG_EXCEPT(x) if (debug_exceptions)   printf_unfiltered x
108
109 static void win32_stop (void);
110 static int win32_win32_thread_alive (ptid_t);
111 static void win32_kill_inferior (void);
112
113 static enum target_signal last_sig = TARGET_SIGNAL_0;
114 /* Set if a signal was received from the debugged process */
115
116 /* Thread information structure used to track information that is
117    not available in gdb's thread structure.  */
118 typedef struct thread_info_struct
119   {
120     struct thread_info_struct *next;
121     DWORD id;
122     HANDLE h;
123     char *name;
124     int suspended;
125     int reload_context;
126     CONTEXT context;
127     STACKFRAME sf;
128   }
129 thread_info;
130
131 static thread_info thread_head;
132
133 /* The process and thread handles for the above context. */
134
135 static DEBUG_EVENT current_event;       /* The current debug event from
136                                            WaitForDebugEvent */
137 static HANDLE current_process_handle;   /* Currently executing process */
138 static thread_info *current_thread;     /* Info on currently selected thread */
139 static DWORD main_thread_id;            /* Thread ID of the main thread */
140
141 /* Counts of things. */
142 static int exception_count = 0;
143 static int event_count = 0;
144 static int saw_create;
145 static int open_process_used = 0;
146
147 /* User options. */
148 static int new_console = 0;
149 #ifdef __CYGWIN__
150 static int cygwin_exceptions = 0;
151 #endif
152 static int new_group = 1;
153 static int debug_exec = 0;              /* show execution */
154 static int debug_events = 0;            /* show events from kernel */
155 static int debug_memory = 0;            /* show target memory accesses */
156 static int debug_exceptions = 0;        /* show target exceptions */
157 static int useshell = 0;                /* use shell for subprocesses */
158
159 /* This vector maps GDB's idea of a register's number into an address
160    in the win32 exception context vector.
161
162    It also contains the bit mask needed to load the register in question.
163
164    One day we could read a reg, we could inspect the context we
165    already have loaded, if it doesn't have the bit set that we need,
166    we read that set of registers in using GetThreadContext.  If the
167    context already contains what we need, we just unpack it. Then to
168    write a register, first we have to ensure that the context contains
169    the other regs of the group, and then we copy the info in and set
170    out bit. */
171
172 #define context_offset(x) ((int)&(((CONTEXT *)NULL)->x))
173 static const int mappings[] =
174 {
175   context_offset (Eax),
176   context_offset (Ecx),
177   context_offset (Edx),
178   context_offset (Ebx),
179   context_offset (Esp),
180   context_offset (Ebp),
181   context_offset (Esi),
182   context_offset (Edi),
183   context_offset (Eip),
184   context_offset (EFlags),
185   context_offset (SegCs),
186   context_offset (SegSs),
187   context_offset (SegDs),
188   context_offset (SegEs),
189   context_offset (SegFs),
190   context_offset (SegGs),
191   context_offset (FloatSave.RegisterArea[0 * 10]),
192   context_offset (FloatSave.RegisterArea[1 * 10]),
193   context_offset (FloatSave.RegisterArea[2 * 10]),
194   context_offset (FloatSave.RegisterArea[3 * 10]),
195   context_offset (FloatSave.RegisterArea[4 * 10]),
196   context_offset (FloatSave.RegisterArea[5 * 10]),
197   context_offset (FloatSave.RegisterArea[6 * 10]),
198   context_offset (FloatSave.RegisterArea[7 * 10]),
199   context_offset (FloatSave.ControlWord),
200   context_offset (FloatSave.StatusWord),
201   context_offset (FloatSave.TagWord),
202   context_offset (FloatSave.ErrorSelector),
203   context_offset (FloatSave.ErrorOffset),
204   context_offset (FloatSave.DataSelector),
205   context_offset (FloatSave.DataOffset),
206   context_offset (FloatSave.ErrorSelector)
207   /* XMM0-7 */ ,
208   context_offset (ExtendedRegisters[10*16]),
209   context_offset (ExtendedRegisters[11*16]),
210   context_offset (ExtendedRegisters[12*16]),
211   context_offset (ExtendedRegisters[13*16]),
212   context_offset (ExtendedRegisters[14*16]),
213   context_offset (ExtendedRegisters[15*16]),
214   context_offset (ExtendedRegisters[16*16]),
215   context_offset (ExtendedRegisters[17*16]),
216   /* MXCSR */
217   context_offset (ExtendedRegisters[24])
218 };
219
220 #undef context_offset
221
222 /* This vector maps the target's idea of an exception (extracted
223    from the DEBUG_EVENT structure) to GDB's idea. */
224
225 struct xlate_exception
226   {
227     int them;
228     enum target_signal us;
229   };
230
231 static const struct xlate_exception
232   xlate[] =
233 {
234   {EXCEPTION_ACCESS_VIOLATION, TARGET_SIGNAL_SEGV},
235   {STATUS_STACK_OVERFLOW, TARGET_SIGNAL_SEGV},
236   {EXCEPTION_BREAKPOINT, TARGET_SIGNAL_TRAP},
237   {DBG_CONTROL_C, TARGET_SIGNAL_INT},
238   {EXCEPTION_SINGLE_STEP, TARGET_SIGNAL_TRAP},
239   {STATUS_FLOAT_DIVIDE_BY_ZERO, TARGET_SIGNAL_FPE},
240   {-1, -1}};
241
242 static void
243 check (BOOL ok, const char *file, int line)
244 {
245   if (!ok)
246     printf_filtered ("error return %s:%d was %lu\n", file, line,
247                      GetLastError ());
248 }
249
250 /* Find a thread record given a thread id.  If GET_CONTEXT is not 0,
251    then also retrieve the context for this thread.  If GET_CONTEXT is
252    negative, then don't suspend the thread.  */
253 static thread_info *
254 thread_rec (DWORD id, int get_context)
255 {
256   thread_info *th;
257
258   for (th = &thread_head; (th = th->next) != NULL;)
259     if (th->id == id)
260       {
261         if (!th->suspended && get_context)
262           {
263             if (get_context > 0 && id != current_event.dwThreadId)
264               {
265                 if (SuspendThread (th->h) == (DWORD) -1)
266                   {
267                     DWORD err = GetLastError ();
268                     warning (_("SuspendThread failed. (winerr %d)"),
269                              (int) err);
270                     return NULL;
271                   }
272                 th->suspended = 1;
273               }
274             else if (get_context < 0)
275               th->suspended = -1;
276             th->reload_context = 1;
277           }
278         return th;
279       }
280
281   return NULL;
282 }
283
284 /* Add a thread to the thread list */
285 static thread_info *
286 win32_add_thread (DWORD id, HANDLE h)
287 {
288   thread_info *th;
289
290   if ((th = thread_rec (id, FALSE)))
291     return th;
292
293   th = XZALLOC (thread_info);
294   th->id = id;
295   th->h = h;
296   th->next = thread_head.next;
297   thread_head.next = th;
298   add_thread (pid_to_ptid (id));
299   /* Set the debug registers for the new thread in they are used.  */
300   if (debug_registers_used)
301     {
302       /* Only change the value of the debug registers.  */
303       th->context.ContextFlags = CONTEXT_DEBUG_REGISTERS;
304       CHECK (GetThreadContext (th->h, &th->context));
305       th->context.Dr0 = dr[0];
306       th->context.Dr1 = dr[1];
307       th->context.Dr2 = dr[2];
308       th->context.Dr3 = dr[3];
309       th->context.Dr6 = DR6_CLEAR_VALUE;
310       th->context.Dr7 = dr[7];
311       CHECK (SetThreadContext (th->h, &th->context));
312       th->context.ContextFlags = 0;
313     }
314   return th;
315 }
316
317 /* Clear out any old thread list and reintialize it to a
318    pristine state. */
319 static void
320 win32_init_thread_list (void)
321 {
322   thread_info *th = &thread_head;
323
324   DEBUG_EVENTS (("gdb: win32_init_thread_list\n"));
325   init_thread_list ();
326   while (th->next != NULL)
327     {
328       thread_info *here = th->next;
329       th->next = here->next;
330       xfree (here);
331     }
332   thread_head.next = NULL;
333 }
334
335 /* Delete a thread from the list of threads */
336 static void
337 win32_delete_thread (DWORD id)
338 {
339   thread_info *th;
340
341   if (info_verbose)
342     printf_unfiltered ("[Deleting %s]\n", target_pid_to_str (pid_to_ptid (id)));
343   delete_thread (pid_to_ptid (id));
344
345   for (th = &thread_head;
346        th->next != NULL && th->next->id != id;
347        th = th->next)
348     continue;
349
350   if (th->next != NULL)
351     {
352       thread_info *here = th->next;
353       th->next = here->next;
354       xfree (here);
355     }
356 }
357
358 static void
359 do_win32_fetch_inferior_registers (struct regcache *regcache, int r)
360 {
361   char *context_offset = ((char *) &current_thread->context) + mappings[r];
362   long l;
363
364   if (!current_thread)
365     return;     /* Windows sometimes uses a non-existent thread id in its
366                    events */
367
368   if (current_thread->reload_context)
369     {
370 #ifdef __COPY_CONTEXT_SIZE
371       if (have_saved_context)
372         {
373           /* Lie about where the program actually is stopped since cygwin has informed us that
374              we should consider the signal to have occurred at another location which is stored
375              in "saved_context. */
376           memcpy (&current_thread->context, &saved_context, __COPY_CONTEXT_SIZE);
377           have_saved_context = 0;
378         }
379       else
380 #endif
381         {
382           thread_info *th = current_thread;
383           th->context.ContextFlags = CONTEXT_DEBUGGER_DR;
384           GetThreadContext (th->h, &th->context);
385           /* Copy dr values from that thread. 
386              But only if there were not modified since last stop. PR gdb/2388 */
387           if (!debug_registers_changed)
388             {
389               dr[0] = th->context.Dr0;
390               dr[1] = th->context.Dr1;
391               dr[2] = th->context.Dr2;
392               dr[3] = th->context.Dr3;
393               dr[6] = th->context.Dr6;
394               dr[7] = th->context.Dr7;
395             }
396         }
397       current_thread->reload_context = 0;
398     }
399
400 #define I387_ST0_REGNUM I386_ST0_REGNUM
401
402   if (r == I387_FISEG_REGNUM)
403     {
404       l = *((long *) context_offset) & 0xffff;
405       regcache_raw_supply (regcache, r, (char *) &l);
406     }
407   else if (r == I387_FOP_REGNUM)
408     {
409       l = (*((long *) context_offset) >> 16) & ((1 << 11) - 1);
410       regcache_raw_supply (regcache, r, (char *) &l);
411     }
412   else if (r >= 0)
413     regcache_raw_supply (regcache, r, context_offset);
414   else
415     {
416       for (r = 0; r < gdbarch_num_regs (get_regcache_arch (regcache)); r++)
417         do_win32_fetch_inferior_registers (regcache, r);
418     }
419
420 #undef I387_ST0_REGNUM
421 }
422
423 static void
424 win32_fetch_inferior_registers (struct regcache *regcache, int r)
425 {
426   current_thread = thread_rec (PIDGET (inferior_ptid), TRUE);
427   /* Check if current_thread exists.  Windows sometimes uses a non-existent
428      thread id in its events */
429   if (current_thread)
430     do_win32_fetch_inferior_registers (regcache, r);
431 }
432
433 static void
434 do_win32_store_inferior_registers (const struct regcache *regcache, int r)
435 {
436   if (!current_thread)
437     /* Windows sometimes uses a non-existent thread id in its events */;
438   else if (r >= 0)
439     regcache_raw_collect (regcache, r,
440                           ((char *) &current_thread->context) + mappings[r]);
441   else
442     {
443       for (r = 0; r < gdbarch_num_regs (get_regcache_arch (regcache)); r++)
444         do_win32_store_inferior_registers (regcache, r);
445     }
446 }
447
448 /* Store a new register value into the current thread context */
449 static void
450 win32_store_inferior_registers (struct regcache *regcache, int r)
451 {
452   current_thread = thread_rec (PIDGET (inferior_ptid), TRUE);
453   /* Check if current_thread exists.  Windows sometimes uses a non-existent
454      thread id in its events */
455   if (current_thread)
456     do_win32_store_inferior_registers (regcache, r);
457 }
458
459 static int psapi_loaded = 0;
460 static BOOL WINAPI (*psapi_EnumProcessModules) (HANDLE, HMODULE *, DWORD,
461                                                 LPDWORD);
462 static BOOL WINAPI (*psapi_GetModuleInformation) (HANDLE, HMODULE, LPMODULEINFO,
463                                                   DWORD);
464 static DWORD WINAPI (*psapi_GetModuleFileNameExA) (HANDLE, HMODULE, LPSTR,
465                                                    DWORD);
466
467 /* Get the name of a given module at at given base address.  If base_address
468    is zero return the first loaded module (which is always the name of the
469    executable).  */
470 static int
471 get_module_name (DWORD base_address, char *dll_name_ret)
472 {
473   DWORD len;
474   MODULEINFO mi;
475   int i;
476   HMODULE dh_buf[1];
477   HMODULE *DllHandle = dh_buf;  /* Set to temporary storage for initial query */
478   DWORD cbNeeded;
479 #ifdef __CYGWIN__
480   char pathbuf[PATH_MAX + 1];   /* Temporary storage prior to converting to
481                                    posix form */
482 #else
483   char *pathbuf = dll_name_ret; /* Just copy directly to passed-in arg */
484 #endif
485
486   /* If psapi_loaded < 0 either psapi.dll is not available or it does not contain
487      the needed functions. */
488   if (psapi_loaded <= 0)
489     goto failed;
490
491   cbNeeded = 0;
492   /* Find size of buffer needed to handle list of modules loaded in inferior */
493   if (!psapi_EnumProcessModules (current_process_handle, DllHandle,
494                                  sizeof (HMODULE), &cbNeeded) || !cbNeeded)
495     goto failed;
496
497   /* Allocate correct amount of space for module list */
498   DllHandle = (HMODULE *) alloca (cbNeeded);
499   if (!DllHandle)
500     goto failed;
501
502   /* Get the list of modules */
503   if (!psapi_EnumProcessModules (current_process_handle, DllHandle, cbNeeded,
504                                  &cbNeeded))
505     goto failed;
506
507   for (i = 0; i < (int) (cbNeeded / sizeof (HMODULE)); i++)
508     {
509       /* Get information on this module */
510       if (!psapi_GetModuleInformation (current_process_handle, DllHandle[i],
511                                        &mi, sizeof (mi)))
512         error (_("Can't get module info"));
513
514       if (!base_address || (DWORD) (mi.lpBaseOfDll) == base_address)
515         {
516           /* Try to find the name of the given module */
517           len = psapi_GetModuleFileNameExA (current_process_handle,
518                                             DllHandle[i], pathbuf, MAX_PATH);
519           if (len == 0)
520             error (_("Error getting dll name: %u."), (unsigned) GetLastError ());
521 #ifdef __CYGWIN__
522           /* Cygwin prefers that the path be in /x/y/z format */
523           cygwin_conv_to_full_posix_path (pathbuf, dll_name_ret);
524 #endif
525           return 1;     /* success */
526         }
527     }
528
529 failed:
530   dll_name_ret[0] = '\0';
531   return 0;             /* failure */
532 }
533
534 /* Encapsulate the information required in a call to
535    symbol_file_add_args */
536 struct safe_symbol_file_add_args
537 {
538   char *name;
539   int from_tty;
540   struct section_addr_info *addrs;
541   int mainline;
542   int flags;
543   struct ui_file *err, *out;
544   struct objfile *ret;
545 };
546
547 /* Maintain a linked list of "so" information. */
548 struct lm_info
549 {
550   DWORD load_addr;
551 };
552
553 static struct so_list solib_start, *solib_end;
554
555 /* Call symbol_file_add with stderr redirected.  We don't care if there
556    are errors. */
557 static int
558 safe_symbol_file_add_stub (void *argv)
559 {
560 #define p ((struct safe_symbol_file_add_args *) argv)
561   struct so_list *so = &solib_start;
562
563   p->ret = symbol_file_add (p->name, p->from_tty, p->addrs, p->mainline, p->flags);
564   return !!p->ret;
565 #undef p
566 }
567
568 /* Restore gdb's stderr after calling symbol_file_add */
569 static void
570 safe_symbol_file_add_cleanup (void *p)
571 {
572 #define sp ((struct safe_symbol_file_add_args *)p)
573   gdb_flush (gdb_stderr);
574   gdb_flush (gdb_stdout);
575   ui_file_delete (gdb_stderr);
576   ui_file_delete (gdb_stdout);
577   gdb_stderr = sp->err;
578   gdb_stdout = sp->out;
579 #undef sp
580 }
581
582 /* symbol_file_add wrapper that prevents errors from being displayed. */
583 static struct objfile *
584 safe_symbol_file_add (char *name, int from_tty,
585                       struct section_addr_info *addrs,
586                       int mainline, int flags)
587 {
588   struct safe_symbol_file_add_args p;
589   struct cleanup *cleanup;
590
591   cleanup = make_cleanup (safe_symbol_file_add_cleanup, &p);
592
593   p.err = gdb_stderr;
594   p.out = gdb_stdout;
595   gdb_flush (gdb_stderr);
596   gdb_flush (gdb_stdout);
597   gdb_stderr = ui_file_new ();
598   gdb_stdout = ui_file_new ();
599   p.name = name;
600   p.from_tty = from_tty;
601   p.addrs = addrs;
602   p.mainline = mainline;
603   p.flags = flags;
604   catch_errors (safe_symbol_file_add_stub, &p, "", RETURN_MASK_ERROR);
605
606   do_cleanups (cleanup);
607   return p.ret;
608 }
609
610 static struct so_list *
611 win32_make_so (const char *name, DWORD load_addr)
612 {
613   struct so_list *so;
614   char buf[MAX_PATH + 1];
615   char cwd[MAX_PATH + 1];
616   char *p;
617   WIN32_FIND_DATA w32_fd;
618   HANDLE h = FindFirstFile(name, &w32_fd);
619   MEMORY_BASIC_INFORMATION m;
620
621   if (h == INVALID_HANDLE_VALUE)
622     strcpy (buf, name);
623   else
624     {
625       FindClose (h);
626       strcpy (buf, name);
627       if (GetCurrentDirectory (MAX_PATH + 1, cwd))
628         {
629           p = strrchr (buf, '\\');
630           if (p)
631             p[1] = '\0';
632           SetCurrentDirectory (buf);
633           GetFullPathName (w32_fd.cFileName, MAX_PATH, buf, &p);
634           SetCurrentDirectory (cwd);
635         }
636     }
637
638   if (strcasecmp (buf, "ntdll.dll") == 0)
639     {
640       GetSystemDirectory (buf, sizeof (buf));
641       strcat (buf, "\\ntdll.dll");
642     }
643   so = XZALLOC (struct so_list);
644   so->lm_info = (struct lm_info *) xmalloc (sizeof (struct lm_info));
645   so->lm_info->load_addr = load_addr;
646   strcpy (so->so_original_name, name);
647 #ifndef __CYGWIN__
648   strcpy (so->so_name, buf);
649 #else
650   cygwin_conv_to_posix_path (buf, so->so_name);
651   /* Record cygwin1.dll .text start/end.  */
652   p = strchr (so->so_name, '\0') - (sizeof ("/cygwin1.dll") - 1);
653   if (p >= so->so_name && strcasecmp (p, "/cygwin1.dll") == 0)
654     {
655       bfd *abfd;
656       asection *text = NULL;
657       CORE_ADDR text_vma;
658
659       abfd = bfd_openr (so->so_name, "pei-i386");
660
661       if (!abfd)
662         return so;
663
664       if (bfd_check_format (abfd, bfd_object))
665         text = bfd_get_section_by_name (abfd, ".text");
666
667       if (!text)
668         {
669           bfd_close (abfd);
670           return so;
671         }
672
673       /* The symbols in a dll are offset by 0x1000, which is the the
674          offset from 0 of the first byte in an image - because of the
675          file header and the section alignment. */
676       cygwin_load_start = load_addr + 0x1000;
677       cygwin_load_end = cygwin_load_start + bfd_section_size (abfd, text);
678
679       bfd_close (abfd);
680     }
681 #endif
682
683   return so;
684 }
685
686 static char *
687 get_image_name (HANDLE h, void *address, int unicode)
688 {
689   static char buf[(2 * MAX_PATH) + 1];
690   DWORD size = unicode ? sizeof (WCHAR) : sizeof (char);
691   char *address_ptr;
692   int len = 0;
693   char b[2];
694   DWORD done;
695
696   /* Attempt to read the name of the dll that was detected.
697      This is documented to work only when actively debugging
698      a program.  It will not work for attached processes. */
699   if (address == NULL)
700     return NULL;
701
702   /* See if we could read the address of a string, and that the
703      address isn't null. */
704   if (!ReadProcessMemory (h, address,  &address_ptr, sizeof (address_ptr), &done)
705       || done != sizeof (address_ptr) || !address_ptr)
706     return NULL;
707
708   /* Find the length of the string */
709   while (ReadProcessMemory (h, address_ptr + len++ * size, &b, size, &done)
710          && (b[0] != 0 || b[size - 1] != 0) && done == size)
711     continue;
712
713   if (!unicode)
714     ReadProcessMemory (h, address_ptr, buf, len, &done);
715   else
716     {
717       WCHAR *unicode_address = (WCHAR *) alloca (len * sizeof (WCHAR));
718       ReadProcessMemory (h, address_ptr, unicode_address, len * sizeof (WCHAR),
719                          &done);
720
721       WideCharToMultiByte (CP_ACP, 0, unicode_address, len, buf, len, 0, 0);
722     }
723
724   return buf;
725 }
726
727 /* Wait for child to do something.  Return pid of child, or -1 in case
728    of error; store status through argument pointer OURSTATUS.  */
729 static int
730 handle_load_dll (void *dummy)
731 {
732   LOAD_DLL_DEBUG_INFO *event = &current_event.u.LoadDll;
733   char dll_buf[MAX_PATH + 1];
734   char *dll_name = NULL;
735
736   dll_buf[0] = dll_buf[sizeof (dll_buf) - 1] = '\0';
737
738   if (!get_module_name ((DWORD) event->lpBaseOfDll, dll_buf))
739     dll_buf[0] = dll_buf[sizeof (dll_buf) - 1] = '\0';
740
741   dll_name = dll_buf;
742
743   if (*dll_name == '\0')
744     dll_name = get_image_name (current_process_handle,
745                                event->lpImageName, event->fUnicode);
746   if (!dll_name)
747     return 1;
748
749   solib_end->next = win32_make_so (dll_name, (DWORD) event->lpBaseOfDll);
750   solib_end = solib_end->next;
751
752   return 1;
753 }
754
755 static void
756 win32_free_so (struct so_list *so)
757 {
758   if (so->lm_info)
759     xfree (so->lm_info);
760   xfree (so);
761 }
762
763 static int
764 handle_unload_dll (void *dummy)
765 {
766   DWORD lpBaseOfDll = (DWORD) current_event.u.UnloadDll.lpBaseOfDll;
767   struct so_list *so;
768
769   for (so = &solib_start; so->next != NULL; so = so->next)
770     if (so->next->lm_info->load_addr == lpBaseOfDll)
771       {
772         struct so_list *sodel = so->next;
773         so->next = sodel->next;
774         if (!so->next)
775           solib_end = so;
776         win32_free_so (sodel);
777         solib_add (NULL, 0, NULL, auto_solib_add);
778         return 1;
779       }
780
781   error (_("Error: dll starting at 0x%lx not found."), (DWORD) lpBaseOfDll);
782
783   return 0;
784 }
785
786 /* Clear list of loaded DLLs. */
787 static void
788 win32_clear_solib (void)
789 {
790   solib_start.next = NULL;
791   solib_end = &solib_start;
792 }
793
794 /* Load DLL symbol info. */
795 void
796 dll_symbol_command (char *args, int from_tty)
797 {
798   int n;
799   dont_repeat ();
800
801   if (args == NULL)
802     error (_("dll-symbols requires a file name"));
803
804   n = strlen (args);
805   if (n > 4 && strcasecmp (args + n - 4, ".dll") != 0)
806     {
807       char *newargs = (char *) alloca (n + 4 + 1);
808       strcpy (newargs, args);
809       strcat (newargs, ".dll");
810       args = newargs;
811     }
812
813   safe_symbol_file_add (args, from_tty, NULL, 0, OBJF_SHARED | OBJF_USERLOADED);
814 }
815
816 /* Handle DEBUG_STRING output from child process.
817    Cygwin prepends its messages with a "cygwin:".  Interpret this as
818    a Cygwin signal.  Otherwise just print the string as a warning. */
819 static int
820 handle_output_debug_string (struct target_waitstatus *ourstatus)
821 {
822   char *s = NULL;
823   int retval = 0;
824
825   if (!target_read_string
826         ((CORE_ADDR) (uintptr_t) current_event.u.DebugString.lpDebugStringData,
827         &s, 1024, 0)
828       || !s || !*s)
829     /* nothing to do */;
830   else if (strncmp (s, _CYGWIN_SIGNAL_STRING, sizeof (_CYGWIN_SIGNAL_STRING) - 1) != 0)
831     {
832 #ifdef __CYGWIN__
833       if (strncmp (s, "cYg", 3) != 0)
834 #endif
835         warning (("%s"), s);
836     }
837 #ifdef __COPY_CONTEXT_SIZE
838   else
839     {
840       /* Got a cygwin signal marker.  A cygwin signal is followed by the signal number
841          itself and then optionally followed by the thread id and address to saved context
842          within the DLL.  If these are supplied, then the given thread is assumed to have
843          issued the signal and the context from the thread is assumed to be stored at the
844          given address in the inferior.  Tell gdb to treat this like a real signal.  */
845       char *p;
846       int sig = strtol (s + sizeof (_CYGWIN_SIGNAL_STRING) - 1, &p, 0);
847       int gotasig = target_signal_from_host (sig);
848       ourstatus->value.sig = gotasig;
849       if (gotasig)
850         {
851           LPCVOID x;
852           DWORD n;
853           ourstatus->kind = TARGET_WAITKIND_STOPPED;
854           retval = strtoul (p, &p, 0);
855           if (!retval)
856             retval = main_thread_id;
857           else if ((x = (LPCVOID) strtoul (p, &p, 0))
858                    && ReadProcessMemory (current_process_handle, x,
859                                          &saved_context, __COPY_CONTEXT_SIZE, &n)
860                    && n == __COPY_CONTEXT_SIZE)
861             have_saved_context = 1;
862           current_event.dwThreadId = retval;
863         }
864     }
865 #endif
866
867   if (s)
868     xfree (s);
869   return retval;
870 }
871
872 static int
873 display_selector (HANDLE thread, DWORD sel)
874 {
875   LDT_ENTRY info;
876   if (GetThreadSelectorEntry (thread, sel, &info))
877     {
878       int base, limit;
879       printf_filtered ("0x%03lx: ", sel);
880       if (!info.HighWord.Bits.Pres)
881         {
882           puts_filtered ("Segment not present\n");
883           return 0;
884         }
885       base = (info.HighWord.Bits.BaseHi << 24) +
886              (info.HighWord.Bits.BaseMid << 16)
887              + info.BaseLow;
888       limit = (info.HighWord.Bits.LimitHi << 16) + info.LimitLow;
889       if (info.HighWord.Bits.Granularity)
890         limit = (limit << 12) | 0xfff;
891       printf_filtered ("base=0x%08x limit=0x%08x", base, limit);
892       if (info.HighWord.Bits.Default_Big)
893         puts_filtered(" 32-bit ");
894       else
895         puts_filtered(" 16-bit ");
896       switch ((info.HighWord.Bits.Type & 0xf) >> 1)
897         {
898         case 0:
899           puts_filtered ("Data (Read-Only, Exp-up");
900           break;
901         case 1:
902           puts_filtered ("Data (Read/Write, Exp-up");
903           break;
904         case 2:
905           puts_filtered ("Unused segment (");
906           break;
907         case 3:
908           puts_filtered ("Data (Read/Write, Exp-down");
909           break;
910         case 4:
911           puts_filtered ("Code (Exec-Only, N.Conf");
912           break;
913         case 5:
914           puts_filtered ("Code (Exec/Read, N.Conf");
915           break;
916         case 6:
917           puts_filtered ("Code (Exec-Only, Conf");
918           break;
919         case 7:
920           puts_filtered ("Code (Exec/Read, Conf");
921           break;
922         default:
923           printf_filtered ("Unknown type 0x%x",info.HighWord.Bits.Type);
924         }
925       if ((info.HighWord.Bits.Type & 0x1) == 0)
926         puts_filtered(", N.Acc");
927       puts_filtered (")\n");
928       if ((info.HighWord.Bits.Type & 0x10) == 0)
929         puts_filtered("System selector ");
930       printf_filtered ("Priviledge level = %d. ", info.HighWord.Bits.Dpl);
931       if (info.HighWord.Bits.Granularity)
932         puts_filtered ("Page granular.\n");
933       else
934         puts_filtered ("Byte granular.\n");
935       return 1;
936     }
937   else
938     {
939       printf_filtered ("Invalid selector 0x%lx.\n",sel);
940       return 0;
941     }
942 }
943
944 static void
945 display_selectors (char * args, int from_tty)
946 {
947   if (!current_thread)
948     {
949       puts_filtered ("Impossible to display selectors now.\n");
950       return;
951     }
952   if (!args)
953     {
954
955       puts_filtered ("Selector $cs\n");
956       display_selector (current_thread->h,
957         current_thread->context.SegCs);
958       puts_filtered ("Selector $ds\n");
959       display_selector (current_thread->h,
960         current_thread->context.SegDs);
961       puts_filtered ("Selector $es\n");
962       display_selector (current_thread->h,
963         current_thread->context.SegEs);
964       puts_filtered ("Selector $ss\n");
965       display_selector (current_thread->h,
966         current_thread->context.SegSs);
967       puts_filtered ("Selector $fs\n");
968       display_selector (current_thread->h,
969         current_thread->context.SegFs);
970       puts_filtered ("Selector $gs\n");
971       display_selector (current_thread->h,
972         current_thread->context.SegGs);
973     }
974   else
975     {
976       int sel;
977       sel = parse_and_eval_long (args);
978       printf_filtered ("Selector \"%s\"\n",args);
979       display_selector (current_thread->h, sel);
980     }
981 }
982
983 static struct cmd_list_element *info_w32_cmdlist = NULL;
984
985 static void
986 info_w32_command (char *args, int from_tty)
987 {
988   help_list (info_w32_cmdlist, "info w32 ", class_info, gdb_stdout);
989 }
990
991
992 #define DEBUG_EXCEPTION_SIMPLE(x)       if (debug_exceptions) \
993   printf_unfiltered ("gdb: Target exception %s at 0x%08lx\n", x, \
994   (DWORD) current_event.u.Exception.ExceptionRecord.ExceptionAddress)
995
996 static int
997 handle_exception (struct target_waitstatus *ourstatus)
998 {
999   thread_info *th;
1000   DWORD code = current_event.u.Exception.ExceptionRecord.ExceptionCode;
1001
1002   ourstatus->kind = TARGET_WAITKIND_STOPPED;
1003
1004   /* Record the context of the current thread */
1005   th = thread_rec (current_event.dwThreadId, -1);
1006
1007   switch (code)
1008     {
1009     case EXCEPTION_ACCESS_VIOLATION:
1010       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_ACCESS_VIOLATION");
1011       ourstatus->value.sig = TARGET_SIGNAL_SEGV;
1012 #ifdef __CYGWIN__
1013       {
1014         /* See if the access violation happened within the cygwin DLL itself.  Cygwin uses
1015            a kind of exception handling to deal with passed-in invalid addresses. gdb
1016            should not treat these as real SEGVs since they will be silently handled by
1017            cygwin.  A real SEGV will (theoretically) be caught by cygwin later in the process
1018            and will be sent as a cygwin-specific-signal.  So, ignore SEGVs if they show up
1019            within the text segment of the DLL itself. */
1020         char *fn;
1021         bfd_vma addr = (bfd_vma) (uintptr_t) current_event.u.Exception.
1022                                              ExceptionRecord.ExceptionAddress;
1023         if ((!cygwin_exceptions && (addr >= cygwin_load_start && addr < cygwin_load_end))
1024             || (find_pc_partial_function (addr, &fn, NULL, NULL)
1025                 && strncmp (fn, "KERNEL32!IsBad", strlen ("KERNEL32!IsBad")) == 0))
1026           return 0;
1027       }
1028 #endif
1029       break;
1030     case STATUS_STACK_OVERFLOW:
1031       DEBUG_EXCEPTION_SIMPLE ("STATUS_STACK_OVERFLOW");
1032       ourstatus->value.sig = TARGET_SIGNAL_SEGV;
1033       break;
1034     case STATUS_FLOAT_DENORMAL_OPERAND:
1035       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_DENORMAL_OPERAND");
1036       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1037       break;
1038     case EXCEPTION_ARRAY_BOUNDS_EXCEEDED:
1039       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_ARRAY_BOUNDS_EXCEEDED");
1040       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1041       break;
1042     case STATUS_FLOAT_INEXACT_RESULT:
1043       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_INEXACT_RESULT");
1044       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1045       break;
1046     case STATUS_FLOAT_INVALID_OPERATION:
1047       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_INVALID_OPERATION");
1048       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1049       break;
1050     case STATUS_FLOAT_OVERFLOW:
1051       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_OVERFLOW");
1052       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1053       break;
1054     case STATUS_FLOAT_STACK_CHECK:
1055       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_STACK_CHECK");
1056       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1057       break;
1058     case STATUS_FLOAT_UNDERFLOW:
1059       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_UNDERFLOW");
1060       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1061       break;
1062     case STATUS_FLOAT_DIVIDE_BY_ZERO:
1063       DEBUG_EXCEPTION_SIMPLE ("STATUS_FLOAT_DIVIDE_BY_ZERO");
1064       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1065       break;
1066     case STATUS_INTEGER_DIVIDE_BY_ZERO:
1067       DEBUG_EXCEPTION_SIMPLE ("STATUS_INTEGER_DIVIDE_BY_ZERO");
1068       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1069       break;
1070     case STATUS_INTEGER_OVERFLOW:
1071       DEBUG_EXCEPTION_SIMPLE ("STATUS_INTEGER_OVERFLOW");
1072       ourstatus->value.sig = TARGET_SIGNAL_FPE;
1073       break;
1074     case EXCEPTION_BREAKPOINT:
1075       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_BREAKPOINT");
1076       ourstatus->value.sig = TARGET_SIGNAL_TRAP;
1077       break;
1078     case DBG_CONTROL_C:
1079       DEBUG_EXCEPTION_SIMPLE ("DBG_CONTROL_C");
1080       ourstatus->value.sig = TARGET_SIGNAL_INT;
1081       break;
1082     case DBG_CONTROL_BREAK:
1083       DEBUG_EXCEPTION_SIMPLE ("DBG_CONTROL_BREAK");
1084       ourstatus->value.sig = TARGET_SIGNAL_INT;
1085       break;
1086     case EXCEPTION_SINGLE_STEP:
1087       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_SINGLE_STEP");
1088       ourstatus->value.sig = TARGET_SIGNAL_TRAP;
1089       break;
1090     case EXCEPTION_ILLEGAL_INSTRUCTION:
1091       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_ILLEGAL_INSTRUCTION");
1092       ourstatus->value.sig = TARGET_SIGNAL_ILL;
1093       break;
1094     case EXCEPTION_PRIV_INSTRUCTION:
1095       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_PRIV_INSTRUCTION");
1096       ourstatus->value.sig = TARGET_SIGNAL_ILL;
1097       break;
1098     case EXCEPTION_NONCONTINUABLE_EXCEPTION:
1099       DEBUG_EXCEPTION_SIMPLE ("EXCEPTION_NONCONTINUABLE_EXCEPTION");
1100       ourstatus->value.sig = TARGET_SIGNAL_ILL;
1101       break;
1102     default:
1103       /* Treat unhandled first chance exceptions specially. */
1104       if (current_event.u.Exception.dwFirstChance)
1105         return -1;
1106       printf_unfiltered ("gdb: unknown target exception 0x%08lx at 0x%08lx\n",
1107                     current_event.u.Exception.ExceptionRecord.ExceptionCode,
1108         (DWORD) current_event.u.Exception.ExceptionRecord.ExceptionAddress);
1109       ourstatus->value.sig = TARGET_SIGNAL_UNKNOWN;
1110       break;
1111     }
1112   exception_count++;
1113   last_sig = ourstatus->value.sig;
1114   return 1;
1115 }
1116
1117 /* Resume all artificially suspended threads if we are continuing
1118    execution */
1119 static BOOL
1120 win32_continue (DWORD continue_status, int id)
1121 {
1122   int i;
1123   thread_info *th;
1124   BOOL res;
1125
1126   DEBUG_EVENTS (("ContinueDebugEvent (cpid=%ld, ctid=%ld, %s);\n",
1127                   current_event.dwProcessId, current_event.dwThreadId,
1128                   continue_status == DBG_CONTINUE ?
1129                   "DBG_CONTINUE" : "DBG_EXCEPTION_NOT_HANDLED"));
1130
1131   for (th = &thread_head; (th = th->next) != NULL;)
1132     if ((id == -1 || id == (int) th->id)
1133         && th->suspended)
1134       {
1135         if (debug_registers_changed)
1136           {
1137             th->context.ContextFlags |= CONTEXT_DEBUG_REGISTERS;
1138             th->context.Dr0 = dr[0];
1139             th->context.Dr1 = dr[1];
1140             th->context.Dr2 = dr[2];
1141             th->context.Dr3 = dr[3];
1142             th->context.Dr6 = DR6_CLEAR_VALUE;
1143             th->context.Dr7 = dr[7];
1144           }
1145         if (th->context.ContextFlags)
1146           {
1147             CHECK (SetThreadContext (th->h, &th->context));
1148             th->context.ContextFlags = 0;
1149           }
1150         if (th->suspended > 0)
1151           (void) ResumeThread (th->h);
1152         th->suspended = 0;
1153       }
1154
1155   res = ContinueDebugEvent (current_event.dwProcessId,
1156                             current_event.dwThreadId,
1157                             continue_status);
1158
1159   debug_registers_changed = 0;
1160   return res;
1161 }
1162
1163 /* Called in pathological case where Windows fails to send a
1164    CREATE_PROCESS_DEBUG_EVENT after an attach.  */
1165 static DWORD
1166 fake_create_process (void)
1167 {
1168   current_process_handle = OpenProcess (PROCESS_ALL_ACCESS, FALSE,
1169                                         current_event.dwProcessId);
1170   if (current_process_handle != NULL)
1171     open_process_used = 1;
1172   else
1173     {
1174       error (_("OpenProcess call failed, GetLastError = %lud\n"),
1175        GetLastError ());
1176       /*  We can not debug anything in that case.  */
1177     }
1178   main_thread_id = current_event.dwThreadId;
1179   current_thread = win32_add_thread (main_thread_id,
1180                                      current_event.u.CreateThread.hThread);
1181   return main_thread_id;
1182 }
1183
1184 static void
1185 win32_resume (ptid_t ptid, int step, enum target_signal sig)
1186 {
1187   thread_info *th;
1188   DWORD continue_status = DBG_CONTINUE;
1189
1190   int pid = PIDGET (ptid);
1191
1192   if (sig != TARGET_SIGNAL_0)
1193     {
1194       if (current_event.dwDebugEventCode != EXCEPTION_DEBUG_EVENT)
1195         {
1196           DEBUG_EXCEPT(("Cannot continue with signal %d here.\n",sig));
1197         }
1198       else if (sig == last_sig)
1199         continue_status = DBG_EXCEPTION_NOT_HANDLED;
1200       else
1201 #if 0
1202 /* This code does not seem to work, because
1203   the kernel does probably not consider changes in the ExceptionRecord
1204   structure when passing the exception to the inferior.
1205   Note that this seems possible in the exception handler itself.  */
1206         {
1207           int i;
1208           for (i = 0; xlate[i].them != -1; i++)
1209             if (xlate[i].us == sig)
1210               {
1211                 current_event.u.Exception.ExceptionRecord.ExceptionCode =
1212                   xlate[i].them;
1213                 continue_status = DBG_EXCEPTION_NOT_HANDLED;
1214                 break;
1215               }
1216           if (continue_status == DBG_CONTINUE)
1217             {
1218               DEBUG_EXCEPT(("Cannot continue with signal %d.\n",sig));
1219             }
1220         }
1221 #endif
1222         DEBUG_EXCEPT(("Can only continue with recieved signal %d.\n",
1223           last_sig));
1224     }
1225
1226   last_sig = TARGET_SIGNAL_0;
1227
1228   DEBUG_EXEC (("gdb: win32_resume (pid=%d, step=%d, sig=%d);\n",
1229                pid, step, sig));
1230
1231   /* Get context for currently selected thread */
1232   th = thread_rec (PIDGET (inferior_ptid), FALSE);
1233   if (th)
1234     {
1235       if (step)
1236         {
1237           /* Single step by setting t bit */
1238           win32_fetch_inferior_registers (get_current_regcache (),
1239                                           gdbarch_ps_regnum (current_gdbarch));
1240           th->context.EFlags |= FLAG_TRACE_BIT;
1241         }
1242
1243       if (th->context.ContextFlags)
1244         {
1245           if (debug_registers_changed)
1246             {
1247               th->context.Dr0 = dr[0];
1248               th->context.Dr1 = dr[1];
1249               th->context.Dr2 = dr[2];
1250               th->context.Dr3 = dr[3];
1251               th->context.Dr6 = DR6_CLEAR_VALUE;
1252               th->context.Dr7 = dr[7];
1253             }
1254           CHECK (SetThreadContext (th->h, &th->context));
1255           th->context.ContextFlags = 0;
1256         }
1257     }
1258
1259   /* Allow continuing with the same signal that interrupted us.
1260      Otherwise complain. */
1261
1262   win32_continue (continue_status, pid);
1263 }
1264
1265 /* Get the next event from the child.  Return 1 if the event requires
1266    handling by WFI (or whatever).
1267  */
1268 static int
1269 get_win32_debug_event (int pid, struct target_waitstatus *ourstatus)
1270 {
1271   BOOL debug_event;
1272   DWORD continue_status, event_code;
1273   thread_info *th;
1274   static thread_info dummy_thread_info;
1275   int retval = 0;
1276   ptid_t ptid = {-1};
1277
1278   last_sig = TARGET_SIGNAL_0;
1279
1280   if (!(debug_event = WaitForDebugEvent (&current_event, 1000)))
1281     goto out;
1282
1283   event_count++;
1284   continue_status = DBG_CONTINUE;
1285
1286   event_code = current_event.dwDebugEventCode;
1287   ourstatus->kind = TARGET_WAITKIND_SPURIOUS;
1288   th = NULL;
1289   have_saved_context = 0;
1290
1291   switch (event_code)
1292     {
1293     case CREATE_THREAD_DEBUG_EVENT:
1294       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%x code=%s)\n",
1295                      (unsigned) current_event.dwProcessId,
1296                      (unsigned) current_event.dwThreadId,
1297                      "CREATE_THREAD_DEBUG_EVENT"));
1298       if (saw_create != 1)
1299         {
1300           if (!saw_create && attach_flag)
1301             {
1302               /* Kludge around a Windows bug where first event is a create
1303                  thread event.  Caused when attached process does not have
1304                  a main thread. */
1305               retval = ourstatus->value.related_pid = fake_create_process ();
1306              if (retval)
1307                saw_create++;
1308             }
1309           break;
1310         }
1311       /* Record the existence of this thread */
1312       th = win32_add_thread (current_event.dwThreadId,
1313                              current_event.u.CreateThread.hThread);
1314       retval = current_event.dwThreadId;
1315       break;
1316
1317     case EXIT_THREAD_DEBUG_EVENT:
1318       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1319                      (unsigned) current_event.dwProcessId,
1320                      (unsigned) current_event.dwThreadId,
1321                      "EXIT_THREAD_DEBUG_EVENT"));
1322       if (current_event.dwThreadId != main_thread_id)
1323         {
1324           win32_delete_thread (current_event.dwThreadId);
1325           th = &dummy_thread_info;
1326         }
1327       break;
1328
1329     case CREATE_PROCESS_DEBUG_EVENT:
1330       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1331                      (unsigned) current_event.dwProcessId,
1332                      (unsigned) current_event.dwThreadId,
1333                      "CREATE_PROCESS_DEBUG_EVENT"));
1334       CloseHandle (current_event.u.CreateProcessInfo.hFile);
1335       if (++saw_create != 1)
1336         break;
1337
1338       current_process_handle = current_event.u.CreateProcessInfo.hProcess;
1339       if (main_thread_id)
1340         win32_delete_thread (main_thread_id);
1341       main_thread_id = current_event.dwThreadId;
1342       /* Add the main thread */
1343       th = win32_add_thread (main_thread_id,
1344                              current_event.u.CreateProcessInfo.hThread);
1345       retval = ourstatus->value.related_pid = current_event.dwThreadId;
1346       break;
1347
1348     case EXIT_PROCESS_DEBUG_EVENT:
1349       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1350                      (unsigned) current_event.dwProcessId,
1351                      (unsigned) current_event.dwThreadId,
1352                      "EXIT_PROCESS_DEBUG_EVENT"));
1353       if (saw_create != 1)
1354         break;
1355       ourstatus->kind = TARGET_WAITKIND_EXITED;
1356       ourstatus->value.integer = current_event.u.ExitProcess.dwExitCode;
1357       retval = main_thread_id;
1358       break;
1359
1360     case LOAD_DLL_DEBUG_EVENT:
1361       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1362                      (unsigned) current_event.dwProcessId,
1363                      (unsigned) current_event.dwThreadId,
1364                      "LOAD_DLL_DEBUG_EVENT"));
1365       CloseHandle (current_event.u.LoadDll.hFile);
1366       if (saw_create != 1)
1367         break;
1368       catch_errors (handle_load_dll, NULL, (char *) "", RETURN_MASK_ALL);
1369       ourstatus->kind = TARGET_WAITKIND_LOADED;
1370       ourstatus->value.integer = 0;
1371       retval = main_thread_id;
1372       break;
1373
1374     case UNLOAD_DLL_DEBUG_EVENT:
1375       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1376                      (unsigned) current_event.dwProcessId,
1377                      (unsigned) current_event.dwThreadId,
1378                      "UNLOAD_DLL_DEBUG_EVENT"));
1379       if (saw_create != 1)
1380         break;
1381       catch_errors (handle_unload_dll, NULL, (char *) "", RETURN_MASK_ALL);
1382       ourstatus->kind = TARGET_WAITKIND_LOADED;
1383       ourstatus->value.integer = 0;
1384       retval = main_thread_id;
1385       break;
1386
1387     case EXCEPTION_DEBUG_EVENT:
1388       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1389                      (unsigned) current_event.dwProcessId,
1390                      (unsigned) current_event.dwThreadId,
1391                      "EXCEPTION_DEBUG_EVENT"));
1392       if (saw_create != 1)
1393         break;
1394       switch (handle_exception (ourstatus))
1395         {
1396         case 0:
1397           continue_status = DBG_EXCEPTION_NOT_HANDLED;
1398           break;
1399         case 1:
1400           retval = current_event.dwThreadId;
1401           break;
1402         case -1:
1403           last_sig = 1;
1404           continue_status = -1;
1405           break;
1406         }
1407       break;
1408
1409     case OUTPUT_DEBUG_STRING_EVENT:     /* message from the kernel */
1410       DEBUG_EVENTS (("gdb: kernel event for pid=%d tid=%d code=%s)\n",
1411                      (unsigned) current_event.dwProcessId,
1412                      (unsigned) current_event.dwThreadId,
1413                      "OUTPUT_DEBUG_STRING_EVENT"));
1414       if (saw_create != 1)
1415         break;
1416       retval = handle_output_debug_string (ourstatus);
1417       break;
1418
1419     default:
1420       if (saw_create != 1)
1421         break;
1422       printf_unfiltered ("gdb: kernel event for pid=%ld tid=%ld\n",
1423                          (DWORD) current_event.dwProcessId,
1424                          (DWORD) current_event.dwThreadId);
1425       printf_unfiltered ("                 unknown event code %ld\n",
1426                          current_event.dwDebugEventCode);
1427       break;
1428     }
1429
1430   if (!retval || saw_create != 1)
1431     {
1432       if (continue_status == -1)
1433         win32_resume (ptid, 0, 1);
1434       else
1435         CHECK (win32_continue (continue_status, -1));
1436     }
1437   else
1438     {
1439       inferior_ptid = pid_to_ptid (retval);
1440       current_thread = th ?: thread_rec (current_event.dwThreadId, TRUE);
1441     }
1442
1443 out:
1444   return retval;
1445 }
1446
1447 /* Wait for interesting events to occur in the target process. */
1448 static ptid_t
1449 win32_wait (ptid_t ptid, struct target_waitstatus *ourstatus)
1450 {
1451   int pid = PIDGET (ptid);
1452
1453   target_terminal_ours ();
1454
1455   /* We loop when we get a non-standard exception rather than return
1456      with a SPURIOUS because resume can try and step or modify things,
1457      which needs a current_thread->h.  But some of these exceptions mark
1458      the birth or death of threads, which mean that the current thread
1459      isn't necessarily what you think it is. */
1460
1461   while (1)
1462     {
1463       int retval = get_win32_debug_event (pid, ourstatus);
1464       if (retval)
1465         return pid_to_ptid (retval);
1466       else
1467         {
1468           int detach = 0;
1469
1470           if (deprecated_ui_loop_hook != NULL)
1471             detach = deprecated_ui_loop_hook (0);
1472
1473           if (detach)
1474             win32_kill_inferior ();
1475         }
1476     }
1477 }
1478
1479 static void
1480 do_initial_win32_stuff (DWORD pid)
1481 {
1482   extern int stop_after_trap;
1483   int i;
1484
1485   last_sig = TARGET_SIGNAL_0;
1486   event_count = 0;
1487   exception_count = 0;
1488   open_process_used = 0;
1489   debug_registers_changed = 0;
1490   debug_registers_used = 0;
1491   for (i = 0; i < sizeof (dr) / sizeof (dr[0]); i++)
1492     dr[i] = 0;
1493 #ifdef __CYGWIN__
1494   cygwin_load_start = cygwin_load_end = 0;
1495 #endif
1496   current_event.dwProcessId = pid;
1497   memset (&current_event, 0, sizeof (current_event));
1498   push_target (&win32_ops);
1499   disable_breakpoints_in_shlibs ();
1500   win32_clear_solib ();
1501   clear_proceed_status ();
1502   init_wait_for_inferior ();
1503
1504   terminal_init_inferior_with_pgrp (pid);
1505   target_terminal_inferior ();
1506
1507   while (1)
1508     {
1509       stop_after_trap = 1;
1510       wait_for_inferior (0);
1511       if (stop_signal != TARGET_SIGNAL_TRAP)
1512         resume (0, stop_signal);
1513       else
1514         break;
1515     }
1516   stop_after_trap = 0;
1517   return;
1518 }
1519
1520 /* Since Windows XP, detaching from a process is supported by Windows.
1521    The following code tries loading the appropriate functions dynamically.
1522    If loading these functions succeeds use them to actually detach from
1523    the inferior process, otherwise behave as usual, pretending that
1524    detach has worked. */
1525 static BOOL WINAPI (*DebugSetProcessKillOnExit)(BOOL);
1526 static BOOL WINAPI (*DebugActiveProcessStop)(DWORD);
1527
1528 static int
1529 has_detach_ability (void)
1530 {
1531   static HMODULE kernel32 = NULL;
1532
1533   if (!kernel32)
1534     kernel32 = LoadLibrary ("kernel32.dll");
1535   if (kernel32)
1536     {
1537       if (!DebugSetProcessKillOnExit)
1538         DebugSetProcessKillOnExit = GetProcAddress (kernel32,
1539                                                  "DebugSetProcessKillOnExit");
1540       if (!DebugActiveProcessStop)
1541         DebugActiveProcessStop = GetProcAddress (kernel32,
1542                                                  "DebugActiveProcessStop");
1543       if (DebugSetProcessKillOnExit && DebugActiveProcessStop)
1544         return 1;
1545     }
1546   return 0;
1547 }
1548
1549 /* Try to set or remove a user privilege to the current process.  Return -1
1550    if that fails, the previous setting of that privilege otherwise.
1551
1552    This code is copied from the Cygwin source code and rearranged to allow
1553    dynamically loading of the needed symbols from advapi32 which is only
1554    available on NT/2K/XP. */
1555 static int
1556 set_process_privilege (const char *privilege, BOOL enable)
1557 {
1558   static HMODULE advapi32 = NULL;
1559   static BOOL WINAPI (*OpenProcessToken)(HANDLE, DWORD, PHANDLE);
1560   static BOOL WINAPI (*LookupPrivilegeValue)(LPCSTR, LPCSTR, PLUID);
1561   static BOOL WINAPI (*AdjustTokenPrivileges)(HANDLE, BOOL, PTOKEN_PRIVILEGES,
1562                                               DWORD, PTOKEN_PRIVILEGES, PDWORD);
1563
1564   HANDLE token_hdl = NULL;
1565   LUID restore_priv;
1566   TOKEN_PRIVILEGES new_priv, orig_priv;
1567   int ret = -1;
1568   DWORD size;
1569
1570   if (GetVersion () >= 0x80000000)  /* No security availbale on 9x/Me */
1571     return 0;
1572
1573   if (!advapi32)
1574     {
1575       if (!(advapi32 = LoadLibrary ("advapi32.dll")))
1576         goto out;
1577       if (!OpenProcessToken)
1578         OpenProcessToken = GetProcAddress (advapi32, "OpenProcessToken");
1579       if (!LookupPrivilegeValue)
1580         LookupPrivilegeValue = GetProcAddress (advapi32,
1581                                                "LookupPrivilegeValueA");
1582       if (!AdjustTokenPrivileges)
1583         AdjustTokenPrivileges = GetProcAddress (advapi32,
1584                                                 "AdjustTokenPrivileges");
1585       if (!OpenProcessToken || !LookupPrivilegeValue || !AdjustTokenPrivileges)
1586         {
1587           advapi32 = NULL;
1588           goto out;
1589         }
1590     }
1591
1592   if (!OpenProcessToken (GetCurrentProcess (),
1593                          TOKEN_QUERY | TOKEN_ADJUST_PRIVILEGES,
1594                          &token_hdl))
1595     goto out;
1596
1597   if (!LookupPrivilegeValue (NULL, privilege, &restore_priv))
1598     goto out;
1599
1600   new_priv.PrivilegeCount = 1;
1601   new_priv.Privileges[0].Luid = restore_priv;
1602   new_priv.Privileges[0].Attributes = enable ? SE_PRIVILEGE_ENABLED : 0;
1603
1604   if (!AdjustTokenPrivileges (token_hdl, FALSE, &new_priv,
1605                               sizeof orig_priv, &orig_priv, &size))
1606     goto out;
1607 #if 0
1608   /* Disabled, otherwise every `attach' in an unprivileged user session
1609      would raise the "Failed to get SE_DEBUG_NAME privilege" warning in
1610      win32_attach(). */
1611   /* AdjustTokenPrivileges returns TRUE even if the privilege could not
1612      be enabled. GetLastError () returns an correct error code, though. */
1613   if (enable && GetLastError () == ERROR_NOT_ALL_ASSIGNED)
1614     goto out;
1615 #endif
1616
1617   ret = orig_priv.Privileges[0].Attributes == SE_PRIVILEGE_ENABLED ? 1 : 0;
1618
1619 out:
1620   if (token_hdl)
1621     CloseHandle (token_hdl);
1622
1623   return ret;
1624 }
1625
1626 /* Attach to process PID, then initialize for debugging it.  */
1627 static void
1628 win32_attach (char *args, int from_tty)
1629 {
1630   BOOL ok;
1631   DWORD pid;
1632
1633   if (!args)
1634     error_no_arg (_("process-id to attach"));
1635
1636   if (set_process_privilege (SE_DEBUG_NAME, TRUE) < 0)
1637     {
1638       printf_unfiltered ("Warning: Failed to get SE_DEBUG_NAME privilege\n");
1639       printf_unfiltered ("This can cause attach to fail on Windows NT/2K/XP\n");
1640     }
1641
1642   pid = strtoul (args, 0, 0);           /* Windows pid */
1643
1644   win32_init_thread_list ();
1645   ok = DebugActiveProcess (pid);
1646   saw_create = 0;
1647
1648 #ifdef __CYGWIN__
1649   if (!ok)
1650     {
1651       /* Try fall back to Cygwin pid */
1652       pid = cygwin_internal (CW_CYGWIN_PID_TO_WINPID, pid);
1653
1654       if (pid > 0)
1655         ok = DebugActiveProcess (pid);
1656   }
1657 #endif
1658
1659   if (!ok)
1660     error (_("Can't attach to process."));
1661
1662   if (has_detach_ability ())
1663     DebugSetProcessKillOnExit (FALSE);
1664
1665   attach_flag = 1;
1666
1667   if (from_tty)
1668     {
1669       char *exec_file = (char *) get_exec_file (0);
1670
1671       if (exec_file)
1672         printf_unfiltered ("Attaching to program `%s', %s\n", exec_file,
1673                            target_pid_to_str (pid_to_ptid (pid)));
1674       else
1675         printf_unfiltered ("Attaching to %s\n",
1676                            target_pid_to_str (pid_to_ptid (pid)));
1677
1678       gdb_flush (gdb_stdout);
1679     }
1680
1681   do_initial_win32_stuff (pid);
1682   target_terminal_ours ();
1683 }
1684
1685 static void
1686 win32_detach (char *args, int from_tty)
1687 {
1688   int detached = 1;
1689
1690   if (has_detach_ability ())
1691     {
1692       ptid_t ptid = {-1};
1693       win32_resume (ptid, 0, TARGET_SIGNAL_0);
1694
1695       if (!DebugActiveProcessStop (current_event.dwProcessId))
1696         {
1697           error (_("Can't detach process %lu (error %lu)"),
1698                  current_event.dwProcessId, GetLastError ());
1699           detached = 0;
1700         }
1701       DebugSetProcessKillOnExit (FALSE);
1702     }
1703   if (detached && from_tty)
1704     {
1705       char *exec_file = get_exec_file (0);
1706       if (exec_file == 0)
1707         exec_file = "";
1708       printf_unfiltered ("Detaching from program: %s, Pid %lu\n", exec_file,
1709                          current_event.dwProcessId);
1710       gdb_flush (gdb_stdout);
1711     }
1712   inferior_ptid = null_ptid;
1713   unpush_target (&win32_ops);
1714 }
1715
1716 static char *
1717 win32_pid_to_exec_file (int pid)
1718 {
1719   static char path[MAX_PATH + 1];
1720
1721 #ifdef __CYGWIN__
1722   /* Try to find exe name as symlink target of /proc/<pid>/exe */
1723   int nchars;
1724   char procexe[sizeof ("/proc/4294967295/exe")];
1725   sprintf (procexe, "/proc/%lu/exe", current_event.dwProcessId);
1726   nchars = readlink (procexe, path, sizeof(path));
1727   if (nchars > 0 && nchars < sizeof (path))
1728     {
1729       path[nchars] = '\0';      /* Got it */
1730       return path;
1731     }
1732 #endif
1733
1734   /* If we get here then either Cygwin is hosed, this isn't a Cygwin version
1735      of gdb, or we're trying to debug a non-Cygwin windows executable. */
1736   if (!get_module_name (0, path))
1737     path[0] = '\0';
1738
1739   return path;
1740 }
1741
1742 /* Print status information about what we're accessing.  */
1743
1744 static void
1745 win32_files_info (struct target_ops *ignore)
1746 {
1747   printf_unfiltered ("\tUsing the running image of %s %s.\n",
1748       attach_flag ? "attached" : "child", target_pid_to_str (inferior_ptid));
1749 }
1750
1751 static void
1752 win32_open (char *arg, int from_tty)
1753 {
1754   error (_("Use the \"run\" command to start a Unix child process."));
1755 }
1756
1757 /* Start an inferior win32 child process and sets inferior_ptid to its pid.
1758    EXEC_FILE is the file to run.
1759    ALLARGS is a string containing the arguments to the program.
1760    ENV is the environment vector to pass.  Errors reported with error().  */
1761
1762 static void
1763 win32_create_inferior (char *exec_file, char *allargs, char **in_env,
1764                        int from_tty)
1765 {
1766   STARTUPINFO si;
1767   PROCESS_INFORMATION pi;
1768   BOOL ret;
1769   DWORD flags;
1770   char *args;
1771   char real_path[MAXPATHLEN];
1772   char *toexec;
1773   char shell[MAX_PATH + 1]; /* Path to shell */
1774   const char *sh;
1775   int tty;
1776   int ostdin, ostdout, ostderr;
1777   const char *inferior_io_terminal = get_inferior_io_terminal ();
1778
1779   if (!exec_file)
1780     error (_("No executable specified, use `target exec'."));
1781
1782   memset (&si, 0, sizeof (si));
1783   si.cb = sizeof (si);
1784
1785 #ifdef __CYGWIN__
1786   if (!useshell)
1787     {
1788       flags = DEBUG_ONLY_THIS_PROCESS;
1789       cygwin_conv_to_win32_path (exec_file, real_path);
1790       toexec = real_path;
1791     }
1792   else
1793     {
1794       char *newallargs;
1795       sh = getenv ("SHELL");
1796       if (!sh)
1797         sh = "/bin/sh";
1798       cygwin_conv_to_win32_path (sh, shell);
1799       newallargs = alloca (sizeof (" -c 'exec  '") + strlen (exec_file)
1800                            + strlen (allargs) + 2);
1801       sprintf (newallargs, " -c 'exec %s %s'", exec_file, allargs);
1802       allargs = newallargs;
1803       toexec = shell;
1804       flags = DEBUG_PROCESS;
1805     }
1806 #else
1807   toexec = exec_file;
1808   flags = DEBUG_ONLY_THIS_PROCESS;
1809 #endif
1810
1811   if (new_group)
1812     flags |= CREATE_NEW_PROCESS_GROUP;
1813
1814   if (new_console)
1815     flags |= CREATE_NEW_CONSOLE;
1816
1817   attach_flag = 0;
1818
1819   args = alloca (strlen (toexec) + strlen (allargs) + 2);
1820   strcpy (args, toexec);
1821   strcat (args, " ");
1822   strcat (args, allargs);
1823
1824 #ifdef __CYGWIN__
1825   /* Prepare the environment vars for CreateProcess.  */
1826   cygwin_internal (CW_SYNC_WINENV);
1827
1828   if (!inferior_io_terminal)
1829     tty = ostdin = ostdout = ostderr = -1;
1830   else
1831     {
1832       tty = open (inferior_io_terminal, O_RDWR | O_NOCTTY);
1833       if (tty < 0)
1834         {
1835           print_sys_errmsg (inferior_io_terminal, errno);
1836           ostdin = ostdout = ostderr = -1;
1837         }
1838       else
1839         {
1840           ostdin = dup (0);
1841           ostdout = dup (1);
1842           ostderr = dup (2);
1843           dup2 (tty, 0);
1844           dup2 (tty, 1);
1845           dup2 (tty, 2);
1846         }
1847     }
1848 #endif
1849
1850   win32_init_thread_list ();
1851   ret = CreateProcess (0,
1852                        args,    /* command line */
1853                        NULL,    /* Security */
1854                        NULL,    /* thread */
1855                        TRUE,    /* inherit handles */
1856                        flags,   /* start flags */
1857                        NULL,    /* environment */
1858                        NULL,    /* current directory */
1859                        &si,
1860                        &pi);
1861
1862 #ifdef __CYGWIN__
1863   if (tty >= 0)
1864     {
1865       close (tty);
1866       dup2 (ostdin, 0);
1867       dup2 (ostdout, 1);
1868       dup2 (ostderr, 2);
1869       close (ostdin);
1870       close (ostdout);
1871       close (ostderr);
1872     }
1873 #endif
1874
1875   if (!ret)
1876     error (_("Error creating process %s, (error %d)."),
1877            exec_file, (unsigned) GetLastError ());
1878
1879   CloseHandle (pi.hThread);
1880   CloseHandle (pi.hProcess);
1881
1882   if (useshell && shell[0] != '\0')
1883     saw_create = -1;
1884   else
1885     saw_create = 0;
1886
1887   do_initial_win32_stuff (pi.dwProcessId);
1888
1889   /* win32_continue (DBG_CONTINUE, -1); */
1890 }
1891
1892 static void
1893 win32_mourn_inferior (void)
1894 {
1895   (void) win32_continue (DBG_CONTINUE, -1);
1896   i386_cleanup_dregs();
1897   if (open_process_used)
1898     {
1899       CHECK (CloseHandle (current_process_handle));
1900       open_process_used = 0;
1901     }
1902   unpush_target (&win32_ops);
1903   generic_mourn_inferior ();
1904 }
1905
1906 /* Send a SIGINT to the process group.  This acts just like the user typed a
1907    ^C on the controlling terminal. */
1908
1909 static void
1910 win32_stop (void)
1911 {
1912   DEBUG_EVENTS (("gdb: GenerateConsoleCtrlEvent (CTRLC_EVENT, 0)\n"));
1913   CHECK (GenerateConsoleCtrlEvent (CTRL_C_EVENT, current_event.dwProcessId));
1914   registers_changed ();         /* refresh register state */
1915 }
1916
1917 static int
1918 win32_xfer_memory (CORE_ADDR memaddr, gdb_byte *our, int len,
1919                    int write, struct mem_attrib *mem,
1920                    struct target_ops *target)
1921 {
1922   DWORD done = 0;
1923   if (write)
1924     {
1925       DEBUG_MEM (("gdb: write target memory, %d bytes at 0x%08lx\n",
1926                   len, (DWORD) (uintptr_t) memaddr));
1927       if (!WriteProcessMemory (current_process_handle, 
1928                                (LPVOID) (uintptr_t) memaddr, our,
1929                                len, &done))
1930         done = 0;
1931       FlushInstructionCache (current_process_handle, 
1932                              (LPCVOID) (uintptr_t) memaddr, len);
1933     }
1934   else
1935     {
1936       DEBUG_MEM (("gdb: read target memory, %d bytes at 0x%08lx\n",
1937                   len, (DWORD) (uintptr_t) memaddr));
1938       if (!ReadProcessMemory (current_process_handle, 
1939                               (LPCVOID) (uintptr_t) memaddr, our,
1940                               len, &done))
1941         done = 0;
1942     }
1943   return done;
1944 }
1945
1946 static void
1947 win32_kill_inferior (void)
1948 {
1949   CHECK (TerminateProcess (current_process_handle, 0));
1950
1951   for (;;)
1952     {
1953       if (!win32_continue (DBG_CONTINUE, -1))
1954         break;
1955       if (!WaitForDebugEvent (&current_event, INFINITE))
1956         break;
1957       if (current_event.dwDebugEventCode == EXIT_PROCESS_DEBUG_EVENT)
1958         break;
1959     }
1960
1961   target_mourn_inferior ();     /* or just win32_mourn_inferior? */
1962 }
1963
1964 static void
1965 win32_prepare_to_store (struct regcache *regcache)
1966 {
1967   /* Do nothing, since we can store individual regs */
1968 }
1969
1970 static int
1971 win32_can_run (void)
1972 {
1973   return 1;
1974 }
1975
1976 static void
1977 win32_close (int x)
1978 {
1979   DEBUG_EVENTS (("gdb: win32_close, inferior_ptid=%d\n",
1980                 PIDGET (inferior_ptid)));
1981 }
1982
1983 /* Convert pid to printable format. */
1984 static char *
1985 win32_pid_to_str (ptid_t ptid)
1986 {
1987   static char buf[80];
1988   int pid = PIDGET (ptid);
1989
1990   if ((DWORD) pid == current_event.dwProcessId)
1991     sprintf (buf, "process %d", pid);
1992   else
1993     sprintf (buf, "thread %ld.0x%x", current_event.dwProcessId, pid);
1994   return buf;
1995 }
1996
1997 static LONGEST
1998 win32_xfer_shared_libraries (struct target_ops *ops,
1999                              enum target_object object, const char *annex,
2000                              gdb_byte *readbuf, const gdb_byte *writebuf,
2001                              ULONGEST offset, LONGEST len)
2002 {
2003   struct obstack obstack;
2004   const char *buf;
2005   LONGEST len_avail;
2006   struct so_list *so;
2007
2008   if (writebuf)
2009     return -1;
2010
2011   obstack_init (&obstack);
2012   obstack_grow_str (&obstack, "<library-list>\n");
2013   for (so = solib_start.next; so; so = so->next)
2014     win32_xfer_shared_library (so->so_name, so->lm_info->load_addr, &obstack);
2015   obstack_grow_str0 (&obstack, "</library-list>\n");
2016
2017   buf = obstack_finish (&obstack);
2018   len_avail = strlen (buf);
2019   if (offset >= len_avail)
2020     return 0;
2021
2022   if (len > len_avail - offset)
2023     len = len_avail - offset;
2024   memcpy (readbuf, buf + offset, len);
2025
2026   obstack_free (&obstack, NULL);
2027   return len;
2028 }
2029
2030 static LONGEST
2031 win32_xfer_partial (struct target_ops *ops, enum target_object object,
2032                     const char *annex, gdb_byte *readbuf,
2033                     const gdb_byte *writebuf, ULONGEST offset, LONGEST len)
2034 {
2035   switch (object)
2036     {
2037     case TARGET_OBJECT_MEMORY:
2038       if (readbuf)
2039         return (*ops->deprecated_xfer_memory) (offset, readbuf,
2040                                                len, 0/*read*/, NULL, ops);
2041       if (writebuf)
2042         return (*ops->deprecated_xfer_memory) (offset, (gdb_byte *) writebuf,
2043                                                len, 1/*write*/, NULL, ops);
2044       return -1;
2045
2046     case TARGET_OBJECT_LIBRARIES:
2047       return win32_xfer_shared_libraries (ops, object, annex, readbuf,
2048                                           writebuf, offset, len);
2049
2050     default:
2051       if (ops->beneath != NULL)
2052         return ops->beneath->to_xfer_partial (ops->beneath, object, annex,
2053                                               readbuf, writebuf, offset, len);
2054       return -1;
2055     }
2056 }
2057
2058 static void
2059 init_win32_ops (void)
2060 {
2061   win32_ops.to_shortname = "child";
2062   win32_ops.to_longname = "Win32 child process";
2063   win32_ops.to_doc = "Win32 child process (started by the \"run\" command).";
2064   win32_ops.to_open = win32_open;
2065   win32_ops.to_close = win32_close;
2066   win32_ops.to_attach = win32_attach;
2067   win32_ops.to_detach = win32_detach;
2068   win32_ops.to_resume = win32_resume;
2069   win32_ops.to_wait = win32_wait;
2070   win32_ops.to_fetch_registers = win32_fetch_inferior_registers;
2071   win32_ops.to_store_registers = win32_store_inferior_registers;
2072   win32_ops.to_prepare_to_store = win32_prepare_to_store;
2073   win32_ops.deprecated_xfer_memory = win32_xfer_memory;
2074   win32_ops.to_xfer_partial = win32_xfer_partial;
2075   win32_ops.to_files_info = win32_files_info;
2076   win32_ops.to_insert_breakpoint = memory_insert_breakpoint;
2077   win32_ops.to_remove_breakpoint = memory_remove_breakpoint;
2078   win32_ops.to_terminal_init = terminal_init_inferior;
2079   win32_ops.to_terminal_inferior = terminal_inferior;
2080   win32_ops.to_terminal_ours_for_output = terminal_ours_for_output;
2081   win32_ops.to_terminal_ours = terminal_ours;
2082   win32_ops.to_terminal_save_ours = terminal_save_ours;
2083   win32_ops.to_terminal_info = child_terminal_info;
2084   win32_ops.to_kill = win32_kill_inferior;
2085   win32_ops.to_create_inferior = win32_create_inferior;
2086   win32_ops.to_mourn_inferior = win32_mourn_inferior;
2087   win32_ops.to_can_run = win32_can_run;
2088   win32_ops.to_thread_alive = win32_win32_thread_alive;
2089   win32_ops.to_pid_to_str = win32_pid_to_str;
2090   win32_ops.to_stop = win32_stop;
2091   win32_ops.to_stratum = process_stratum;
2092   win32_ops.to_has_all_memory = 1;
2093   win32_ops.to_has_memory = 1;
2094   win32_ops.to_has_stack = 1;
2095   win32_ops.to_has_registers = 1;
2096   win32_ops.to_has_execution = 1;
2097   win32_ops.to_magic = OPS_MAGIC;
2098   win32_ops.to_pid_to_exec_file = win32_pid_to_exec_file;
2099 }
2100
2101 static void
2102 set_win32_aliases (char *argv0)
2103 {
2104   add_info_alias ("dll", "sharedlibrary", 1);
2105 }
2106
2107 void
2108 _initialize_win32_nat (void)
2109 {
2110   struct cmd_list_element *c;
2111
2112   init_win32_ops ();
2113
2114   c = add_com ("dll-symbols", class_files, dll_symbol_command,
2115                _("Load dll library symbols from FILE."));
2116   set_cmd_completer (c, filename_completer);
2117
2118   add_com_alias ("sharedlibrary", "dll-symbols", class_alias, 1);
2119
2120 #ifdef __CYGWIN__
2121   add_setshow_boolean_cmd ("shell", class_support, &useshell, _("\
2122 Set use of shell to start subprocess."), _("\
2123 Show use of shell to start subprocess."), NULL,
2124                            NULL,
2125                            NULL, /* FIXME: i18n: */
2126                            &setlist, &showlist);
2127
2128   add_setshow_boolean_cmd ("cygwin-exceptions", class_support, &cygwin_exceptions, _("\
2129 Break when an exception is detected in the Cygwin DLL itself."), _("\
2130 Show whether gdb breaks on exceptions in the Cygwin DLL itself."), NULL,
2131                            NULL,
2132                            NULL, /* FIXME: i18n: */
2133                            &setlist, &showlist);
2134 #endif
2135
2136   add_setshow_boolean_cmd ("new-console", class_support, &new_console, _("\
2137 Set creation of new console when creating child process."), _("\
2138 Show creation of new console when creating child process."), NULL,
2139                            NULL,
2140                            NULL, /* FIXME: i18n: */
2141                            &setlist, &showlist);
2142
2143   add_setshow_boolean_cmd ("new-group", class_support, &new_group, _("\
2144 Set creation of new group when creating child process."), _("\
2145 Show creation of new group when creating child process."), NULL,
2146                            NULL,
2147                            NULL, /* FIXME: i18n: */
2148                            &setlist, &showlist);
2149
2150   add_setshow_boolean_cmd ("debugexec", class_support, &debug_exec, _("\
2151 Set whether to display execution in child process."), _("\
2152 Show whether to display execution in child process."), NULL,
2153                            NULL,
2154                            NULL, /* FIXME: i18n: */
2155                            &setlist, &showlist);
2156
2157   add_setshow_boolean_cmd ("debugevents", class_support, &debug_events, _("\
2158 Set whether to display kernel events in child process."), _("\
2159 Show whether to display kernel events in child process."), NULL,
2160                            NULL,
2161                            NULL, /* FIXME: i18n: */
2162                            &setlist, &showlist);
2163
2164   add_setshow_boolean_cmd ("debugmemory", class_support, &debug_memory, _("\
2165 Set whether to display memory accesses in child process."), _("\
2166 Show whether to display memory accesses in child process."), NULL,
2167                            NULL,
2168                            NULL, /* FIXME: i18n: */
2169                            &setlist, &showlist);
2170
2171   add_setshow_boolean_cmd ("debugexceptions", class_support,
2172                            &debug_exceptions, _("\
2173 Set whether to display kernel exceptions in child process."), _("\
2174 Show whether to display kernel exceptions in child process."), NULL,
2175                            NULL,
2176                            NULL, /* FIXME: i18n: */
2177                            &setlist, &showlist);
2178
2179   add_prefix_cmd ("w32", class_info, info_w32_command,
2180                   _("Print information specific to Win32 debugging."),
2181                   &info_w32_cmdlist, "info w32 ", 0, &infolist);
2182
2183   add_cmd ("selector", class_info, display_selectors,
2184            _("Display selectors infos."),
2185            &info_w32_cmdlist);
2186   add_target (&win32_ops);
2187   deprecated_init_ui_hook = set_win32_aliases;
2188 }
2189
2190 /* Hardware watchpoint support, adapted from go32-nat.c code.  */
2191
2192 /* Pass the address ADDR to the inferior in the I'th debug register.
2193    Here we just store the address in dr array, the registers will be
2194    actually set up when win32_continue is called.  */
2195 void
2196 cygwin_set_dr (int i, CORE_ADDR addr)
2197 {
2198   if (i < 0 || i > 3)
2199     internal_error (__FILE__, __LINE__,
2200                     _("Invalid register %d in cygwin_set_dr.\n"), i);
2201   dr[i] = (unsigned) addr;
2202   debug_registers_changed = 1;
2203   debug_registers_used = 1;
2204 }
2205
2206 /* Pass the value VAL to the inferior in the DR7 debug control
2207    register.  Here we just store the address in D_REGS, the watchpoint
2208    will be actually set up in win32_wait.  */
2209 void
2210 cygwin_set_dr7 (unsigned val)
2211 {
2212   dr[7] = val;
2213   debug_registers_changed = 1;
2214   debug_registers_used = 1;
2215 }
2216
2217 /* Get the value of the DR6 debug status register from the inferior.
2218    Here we just return the value stored in dr[6]
2219    by the last call to thread_rec for current_event.dwThreadId id.  */
2220 unsigned
2221 cygwin_get_dr6 (void)
2222 {
2223   return dr[6];
2224 }
2225
2226 /* Determine if the thread referenced by "pid" is alive
2227    by "polling" it.  If WaitForSingleObject returns WAIT_OBJECT_0
2228    it means that the pid has died.  Otherwise it is assumed to be alive. */
2229 static int
2230 win32_win32_thread_alive (ptid_t ptid)
2231 {
2232   int pid = PIDGET (ptid);
2233
2234   return WaitForSingleObject (thread_rec (pid, FALSE)->h, 0) == WAIT_OBJECT_0 ?
2235     FALSE : TRUE;
2236 }
2237
2238 void
2239 _initialize_check_for_gdb_ini (void)
2240 {
2241   char *homedir;
2242   if (inhibit_gdbinit)
2243     return;
2244
2245   homedir = getenv ("HOME");
2246   if (homedir)
2247     {
2248       char *p;
2249       char *oldini = (char *) alloca (strlen (homedir) +
2250                                       sizeof ("/gdb.ini"));
2251       strcpy (oldini, homedir);
2252       p = strchr (oldini, '\0');
2253       if (p > oldini && p[-1] != '/')
2254         *p++ = '/';
2255       strcpy (p, "gdb.ini");
2256       if (access (oldini, 0) == 0)
2257         {
2258           int len = strlen (oldini);
2259           char *newini = alloca (len + 1);
2260           sprintf (newini, "%.*s.gdbinit",
2261             (int) (len - (sizeof ("gdb.ini") - 1)), oldini);
2262           warning (_("obsolete '%s' found. Rename to '%s'."), oldini, newini);
2263         }
2264     }
2265 }
2266
2267 void
2268 _initialize_psapi (void)
2269 {
2270   /* Load optional functions used for retrieving filename information
2271      associated with the currently debugged process or its dlls. */
2272   if (!psapi_loaded)
2273     {
2274       HMODULE psapi_module_handle;
2275
2276       psapi_loaded = -1;
2277
2278       psapi_module_handle = LoadLibrary ("psapi.dll");
2279       if (psapi_module_handle)
2280         {
2281           psapi_EnumProcessModules = (void *) GetProcAddress (psapi_module_handle, "EnumProcessModules");
2282           psapi_GetModuleInformation = (void *) GetProcAddress (psapi_module_handle, "GetModuleInformation");
2283           psapi_GetModuleFileNameExA = (void *) GetProcAddress (psapi_module_handle, "GetModuleFileNameExA");
2284
2285           if (psapi_EnumProcessModules != NULL
2286               && psapi_GetModuleInformation != NULL
2287               && psapi_GetModuleFileNameExA != NULL)
2288             psapi_loaded = 1;
2289         }
2290     }
2291
2292   /* This will probably fail on Windows 9x/Me.  Let the user know that we're
2293      missing some functionality. */
2294   if (psapi_loaded < 0)
2295     warning(_("cannot automatically find executable file or library to read symbols.  Use \"file\" or \"dll\" command to load executable/libraries directly."));
2296 }