From 7234efcb531fa088586e4a546a80500deb080038 Mon Sep 17 00:00:00 2001 From: Keith Seitz Date: Mon, 13 Apr 1998 20:05:15 +0000 Subject: [PATCH] * gdbtk.c (gdbtk_start_timer): Include on all platforms. Decrease timer interval a little. (gdbtk_stop_timer): Include on all platforms. (gdbtk_wait): No more signals! Use a timer on all platforms to keep the GUI alive. (gdbtk_init): Remove FIOASYNC and all x_fd references. Now using timers on all platforms. --- gdb/ChangeLog-gdbtk | 10 +++ gdb/gdbtk.c | 185 ++++++-------------------------------------- 2 files changed, 33 insertions(+), 162 deletions(-) diff --git a/gdb/ChangeLog-gdbtk b/gdb/ChangeLog-gdbtk index fe226d011a..0257c3a9f2 100644 --- a/gdb/ChangeLog-gdbtk +++ b/gdb/ChangeLog-gdbtk @@ -1,3 +1,13 @@ +Mon Apr 13 12:58:26 1998 Keith Seitz + + * gdbtk.c (gdbtk_start_timer): Include on all platforms. Decrease + timer interval a little. + (gdbtk_stop_timer): Include on all platforms. + (gdbtk_wait): No more signals! Use a timer on all platforms to keep the + GUI alive. + (gdbtk_init): Remove FIOASYNC and all x_fd references. Now using timers + on all platforms. + Fri Apr 10 15:48:10 1998 Jason Molenda (crash@bugshack.cygnus.com) * gdbtk.c (gdb_listfiles): Allocate space for 'files' dynamically. diff --git a/gdb/gdbtk.c b/gdb/gdbtk.c index a0a5d4d10a..4c58c9b22f 100644 --- a/gdb/gdbtk.c +++ b/gdb/gdbtk.c @@ -65,16 +65,8 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include "gdbcmd.h" -#ifndef WINNT -#ifndef FIOASYNC -#include -#endif -#endif - -#ifdef __CYGWIN32__ #include "annotate.h" #include -#endif #ifdef WINNT #define GDBTK_PATH_SEP ";" @@ -97,14 +89,6 @@ int (*ui_load_progress_hook) PARAMS ((char *, unsigned long)); void (*pre_add_symbol_hook) PARAMS ((char *)); void (*post_add_symbol_hook) PARAMS ((void)); -/* This is a disgusting hack. Unfortunately, the UI will lock up if we - are doing something like blocking in a system call, waiting for serial I/O, - or what have you. - - This hook should be used whenever we might block. This means adding appropriate - timeouts to code and what not to allow this hook to be called. */ -void (*ui_loop_hook) PARAMS ((int)); - char * get_prompt PARAMS ((void)); static void null_routine PARAMS ((int)); @@ -175,33 +159,14 @@ static int gdb_loadfile PARAMS ((ClientData, Tcl_Interp *, int, Tcl_Obj *CONST o static int gdb_set_bp PARAMS ((ClientData, Tcl_Interp *, int, Tcl_Obj *CONST objv[])); static struct symtab *full_lookup_symtab PARAMS ((char *file)); static int gdb_get_mem PARAMS ((ClientData, Tcl_Interp *, int, char *[])); -#ifdef __CYGWIN32__ -static void gdbtk_annotate_starting PARAMS ((void)); -static void gdbtk_annotate_stopped PARAMS ((void)); -static void gdbtk_annotate_signalled PARAMS ((void)); -static void gdbtk_annotate_exited PARAMS ((void)); -#endif /* Handle for TCL interpreter */ static Tcl_Interp *interp = NULL; -#ifndef WINNT -static int x_fd; /* X network socket */ -#endif - -#ifdef __CYGWIN32__ - -/* On Windows we use timer interrupts when gdb might otherwise hang - for a long time. See the comment above gdbtk_start_timer. This - variable is true when timer interrupts are being used. */ - static int gdbtk_timer_going = 0; - static void gdbtk_start_timer PARAMS ((void)); static void gdbtk_stop_timer PARAMS ((void)); -#endif - /* This variable is true when the inferior is running. Although it's possible to disable most input from widgets and thus prevent attempts to do anything while the inferior is running, any commands @@ -1130,23 +1095,17 @@ gdb_cmd (clientData, interp, argc, argv) save_ptr = result_ptr; result_ptr = NULL; load_in_progress = 1; - - /* On Windows, use timer interrupts so that the user can cancel - the download. FIXME: We may have to do something on other - systems. */ -#ifdef __CYGWIN32__ gdbtk_start_timer (); -#endif } execute_command (argv[1], 1); -#ifdef __CYGWIN32__ if (load_in_progress) - gdbtk_stop_timer (); -#endif + { + gdbtk_stop_timer (); + load_in_progress = 0; + } - load_in_progress = 0; bpstat_do_actions (&stop_bpstat); if (save_ptr) @@ -1211,11 +1170,9 @@ call_wrapper (clientData, interp, argc, argv) { wrapped_args.val = TCL_ERROR; /* Flag an error for TCL */ -#ifdef __CYGWIN32__ /* Make sure the timer interrupts are turned off. */ if (gdbtk_timer_going) - gdbtk_stop_timer (); -#endif + gdbtk_stop_timer (); gdb_flush (gdb_stderr); /* Flush error output */ gdb_flush (gdb_stdout); /* Sometimes error output comes here as well */ @@ -1789,7 +1746,6 @@ x_event (signo) { static int in_x_event = 0; static Tcl_Obj *varname = NULL; - if (in_x_event || in_fputs) return; @@ -1821,8 +1777,6 @@ x_event (signo) in_x_event = 0; } -#ifdef __CYGWIN32__ - /* For Cygwin32, we use a timer to periodically check for Windows messages. FIXME: It would be better to not poll, but to instead rewrite the target_wait routines to serve as input sources. @@ -1851,31 +1805,36 @@ gdbtk_start_timer () act2.sa_flags = 0; it_on.it_interval.tv_sec = 0; - it_on.it_interval.tv_usec = 500000; /* .5 sec */ + it_on.it_interval.tv_usec = 250000; /* .25 sec */ it_on.it_value.tv_sec = 0; - it_on.it_value.tv_usec = 500000; + it_on.it_value.tv_usec = 250000; it_off.it_interval.tv_sec = 0; it_off.it_interval.tv_usec = 0; it_off.it_value.tv_sec = 0; it_off.it_value.tv_usec = 0; } - sigaction (SIGALRM, &act1, NULL); - setitimer (ITIMER_REAL, &it_on, NULL); - gdbtk_timer_going = 1; + + if (!gdbtk_timer_going) + { + sigaction (SIGALRM, &act1, NULL); + setitimer (ITIMER_REAL, &it_on, NULL); + gdbtk_timer_going = 1; + } } static void gdbtk_stop_timer () { - gdbtk_timer_going = 0; - /*TclDebug ("Stopping timer.");*/ - setitimer (ITIMER_REAL, &it_off, NULL); - sigaction (SIGALRM, &act2, NULL); + if (gdbtk_timer_going) + { + gdbtk_timer_going = 0; + /*TclDebug ("Stopping timer.");*/ + setitimer (ITIMER_REAL, &it_off, NULL); + sigaction (SIGALRM, &act2, NULL); + } } -#endif - /* This hook function is called whenever we want to wait for the target. */ @@ -1884,29 +1843,9 @@ gdbtk_wait (pid, ourstatus) int pid; struct target_waitstatus *ourstatus; { -#ifndef WINNT - struct sigaction action; - static sigset_t nullsigmask = {0}; - - -#ifndef SA_RESTART - /* Needed for SunOS 4.1.x */ -#define SA_RESTART 0 -#endif - - action.sa_handler = x_event; - action.sa_mask = nullsigmask; - action.sa_flags = SA_RESTART; - sigaction(SIGIO, &action, NULL); -#endif /* WINNT */ - + gdbtk_start_timer (); pid = target_wait (pid, ourstatus); - -#ifndef WINNT - action.sa_handler = SIG_IGN; - sigaction(SIGIO, &action, NULL); -#endif - + gdbtk_stop_timer (); return pid; } @@ -2213,50 +2152,6 @@ gdbtk_init ( argv0 ) delete_tracepoint_hook = gdbtk_delete_tracepoint; modify_tracepoint_hook = gdbtk_modify_tracepoint; pc_changed_hook = pc_changed; -#ifdef __CYGWIN32__ - annotate_starting_hook = gdbtk_annotate_starting; - annotate_stopped_hook = gdbtk_annotate_stopped; - annotate_signalled_hook = gdbtk_annotate_signalled; - annotate_exited_hook = gdbtk_annotate_exited; - ui_loop_hook = x_event; -#endif -#ifndef WINNT - /* Get the file descriptor for the X server */ - - x_fd = ConnectionNumber (Tk_Display (Tk_MainWindow (interp))); - - /* Setup for I/O interrupts */ - - action.sa_mask = nullsigmask; - action.sa_flags = 0; - action.sa_handler = SIG_IGN; - sigaction(SIGIO, &action, NULL); - -#ifdef FIOASYNC - i = 1; - if (ioctl (x_fd, FIOASYNC, &i)) - perror_with_name ("gdbtk_init: ioctl FIOASYNC failed"); - -#ifdef SIOCSPGRP - i = getpid(); - if (ioctl (x_fd, SIOCSPGRP, &i)) - perror_with_name ("gdbtk_init: ioctl SIOCSPGRP failed"); - -#else -#ifdef F_SETOWN - i = getpid(); - if (fcntl (x_fd, F_SETOWN, i)) - perror_with_name ("gdbtk_init: fcntl F_SETOWN failed"); -#endif /* F_SETOWN */ -#endif /* !SIOCSPGRP */ -#else -#ifndef WINNT - if (ioctl (x_fd, I_SETSIG, S_INPUT|S_RDNORM) < 0) - perror_with_name ("gdbtk_init: ioctl I_SETSIG failed"); -#endif - -#endif /* ifndef FIOASYNC */ -#endif /* WINNT */ add_com ("tk", class_obscure, tk_command, "Send a command directly into tk."); @@ -3334,40 +3229,6 @@ gdb_set_bp (clientData, interp, objc, objv) return ret; } -#ifdef __CYGWIN32__ -/* The whole timer idea is an easy one, but POSIX does not appear to have - some sort of interval timer requirement. Consequently, we cannot rely - on cygwin32 to always deliver the timer's signal. This is especially - painful given that all serial I/O will block the timer right now. */ -static void -gdbtk_annotate_starting () -{ - /* TclDebug ("### STARTING ###"); */ - gdbtk_start_timer (); -} - -static void -gdbtk_annotate_stopped () -{ - /* TclDebug ("### STOPPED ###"); */ - gdbtk_stop_timer (); -} - -static void -gdbtk_annotate_exited () -{ - /* TclDebug ("### EXITED ###"); */ - gdbtk_stop_timer (); -} - -static void -gdbtk_annotate_signalled () -{ - /* TclDebug ("### SIGNALLED ###"); */ - gdbtk_stop_timer (); -} -#endif - /* Come here during initialize_all_files () */ void