* gdb.base/display.c (do_loops): Add float variable `f'.
[deliverable/binutils-gdb.git] / gdb / ultra3-xdep.c
index 504f56b881a9a4635dff377e255d63b342de3d4c..ea87fd6fab2d2b5c1fac16c98a7145d9bc604e27 100644 (file)
-/* Host-dependent code for GDB, for NYU Ultra3 running Sym1 OS.
-   Copyright (C) 1988, 1989, 1991, 1992 Free Software Foundation, Inc.
-   Contributed by David Wood (wood@nyu.edu) at New York University.
-
-This file is part of GDB.
-
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2 of the License, or
-(at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
-
-#define DEBUG
-#include "defs.h"
-#include "frame.h"
-#include "inferior.h"
-#include "symtab.h"
-#include "value.h"
-
-#include <sys/types.h>
-#include <sys/param.h>
-#include <signal.h>
-#include <sys/ioctl.h>
-#include <fcntl.h>  
-
-#include "gdbcore.h"
-
-#include <sys/file.h>
-#include <sys/stat.h>
-
-/* Assumes support for AMD's Binary Compatibility Standard
-   for ptrace().  If you define ULTRA3, the ultra3 extensions to
-   ptrace() are used allowing the reading of more than one register
-   at a time. 
-
-   This file assumes KERNEL_DEBUGGING is turned off.  This means
-   that if the user/gdb tries to read gr64-gr95 or any of the 
-   protected special registers we silently return -1 (see the
-   CANNOT_STORE/FETCH_REGISTER macros).  */
-#define        ULTRA3
-
-#if !defined (offsetof)
-# define offsetof(TYPE, MEMBER) ((unsigned long) &((TYPE *)0)->MEMBER)
-#endif
-
-extern int errno;
-struct ptrace_user pt_struct;
-
-/*  
- * Takes a register number as defined in tm.h via REGISTER_NAMES, and maps
- * it to an offset in a struct ptrace_user defined by AMD's BCS.
- * That is, it defines the mapping between gdb register numbers and items in
- * a struct ptrace_user.
- * A register protection scheme is set up here.  If a register not
- * available to the user is specified in 'regno', then an address that
- * will cause ptrace() to fail is returned.
- */
-unsigned int 
-register_addr (regno,blockend)
-     unsigned int      regno;
-     char              *blockend;
-{
-  if ((regno >= LR0_REGNUM) && (regno < LR0_REGNUM + 128)) {
-    return(offsetof(struct ptrace_user,pt_lr[regno-LR0_REGNUM]));
-  } else if ((regno >= GR96_REGNUM) && (regno < GR96_REGNUM + 32)) {
-    return(offsetof(struct ptrace_user,pt_gr[regno-GR96_REGNUM]));
-  } else {
-    switch (regno) {
-       case GR1_REGNUM: return(offsetof(struct ptrace_user,pt_gr1));
-       case CPS_REGNUM: return(offsetof(struct ptrace_user,pt_psr));
-       case NPC_REGNUM: return(offsetof(struct ptrace_user,pt_pc0));
-       case PC_REGNUM:  return(offsetof(struct ptrace_user,pt_pc1));
-       case PC2_REGNUM: return(offsetof(struct ptrace_user,pt_pc2));
-       case IPC_REGNUM: return(offsetof(struct ptrace_user,pt_ipc));
-       case IPA_REGNUM: return(offsetof(struct ptrace_user,pt_ipa));
-       case IPB_REGNUM: return(offsetof(struct ptrace_user,pt_ipb));
-       case Q_REGNUM:   return(offsetof(struct ptrace_user,pt_q));
-       case BP_REGNUM:  return(offsetof(struct ptrace_user,pt_bp));
-       case FC_REGNUM:  return(offsetof(struct ptrace_user,pt_fc));
-       default:
-            fprintf_filtered(stderr,"register_addr():Bad register %s (%d)\n", 
-                               reg_names[regno],regno);
-            return(0xffffffff);        /* Should make ptrace() fail */
-    }
-  }
-}
-
-
-/* Assorted operating system circumventions */
-
-#ifdef SYM1
-
-/* FIXME: Kludge this for now. It really should be system call. */
-int
-getpagesize()
-{ return(8192); }
-
-/* FIXME: Fake out the fcntl() call, which we don't have.  */
-fcntl(fd, cmd, arg)
-int fd, cmd, arg;
-{
-
-  switch (cmd) {
-       case F_GETFL: return(O_RDONLY); break;
-       default:        
-               printf("Ultra3's fcntl() failing, cmd = %d.\n",cmd);
-               return(-1);
-  }
-}
-
-
-/* 
- * 4.2 Signal support, requires linking with libjobs.
- */
-static int     _SigMask;
-#define sigbit(s)       (1L << ((s)-1))
-
-init_SigMask()
-{
-       /* Taken from the sym1 kernel in machdep.c:startup() */
-       _SigMask = sigbit (SIGTSTP) | sigbit (SIGTTOU) | sigbit (SIGTTIN) |
-                        sigbit (SIGCHLD) | sigbit (SIGTINT);
-}
-
-sigmask(signo)
-       int signo;
-{
-       return (1 << (signo-1));
-}
-
-sigsetmask(sigmask)
-unsigned int sigmask;
-{
-       int i, mask = 1;
-       int lastmask = _SigMask;
-
-       for (i=0 ; i<NSIG ; i++) {
-               if (sigmask & mask) { 
-                       if (!(_SigMask & mask)) {
-                               sighold(i+1);
-                               _SigMask |= mask;
-                       }
-               } else if (_SigMask & mask) {
-                       sigrelse(i+1);
-                       _SigMask &= ~mask;
-               }
-               mask <<= 1;
-       }
-       return (lastmask);
-}
-
-sigblock(sigmask)
-unsigned int sigmask;
-{
-       int i, mask = 1;
-       int lastmask = _SigMask;
-
-       for (i=0 ; i<NSIG ; i++) {
-               if ((sigmask & mask) && !(_SigMask & mask)) {
-                       sighold(i+1);
-                       _SigMask |= mask;
-               }
-               mask <<= 1;
-       }
-       return (lastmask);
-}
-#endif /* SYM1 */
-
-
-/* Initialization code for this module.  */
-
-_initialize_ultra3 ()
-{
-#ifdef SYM1
-       init_SigMask();
-#endif
-}
+/* OBSOLETE /* Host-dependent code for GDB, for NYU Ultra3 running Sym1 OS. */
+/* OBSOLETE    Copyright 1988, 1989, 1991, 1992, 1993, 1995, 2000 */
+/* OBSOLETE    Free Software Foundation, Inc. */
+/* OBSOLETE    Contributed by David Wood (wood@nyu.edu) at New York University. */
+/* OBSOLETE  */
+/* OBSOLETE    This file is part of GDB. */
+/* OBSOLETE  */
+/* OBSOLETE    This program is free software; you can redistribute it and/or modify */
+/* OBSOLETE    it under the terms of the GNU General Public License as published by */
+/* OBSOLETE    the Free Software Foundation; either version 2 of the License, or */
+/* OBSOLETE    (at your option) any later version. */
+/* OBSOLETE  */
+/* OBSOLETE    This program is distributed in the hope that it will be useful, */
+/* OBSOLETE    but WITHOUT ANY WARRANTY; without even the implied warranty of */
+/* OBSOLETE    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the */
+/* OBSOLETE    GNU General Public License for more details. */
+/* OBSOLETE  */
+/* OBSOLETE    You should have received a copy of the GNU General Public License */
+/* OBSOLETE    along with this program; if not, write to the Free Software */
+/* OBSOLETE    Foundation, Inc., 59 Temple Place - Suite 330, */
+/* OBSOLETE    Boston, MA 02111-1307, USA.  */ */
+/* OBSOLETE  */
+/* OBSOLETE #define DEBUG */
+/* OBSOLETE #include "defs.h" */
+/* OBSOLETE #include "frame.h" */
+/* OBSOLETE #include "inferior.h" */
+/* OBSOLETE #include "symtab.h" */
+/* OBSOLETE #include "value.h" */
+/* OBSOLETE  */
+/* OBSOLETE #include <sys/types.h> */
+/* OBSOLETE #include <sys/param.h> */
+/* OBSOLETE #include <signal.h> */
+/* OBSOLETE #include <sys/ioctl.h> */
+/* OBSOLETE #include <fcntl.h> */
+/* OBSOLETE  */
+/* OBSOLETE #include "gdbcore.h" */
+/* OBSOLETE  */
+/* OBSOLETE #include <sys/file.h> */
+/* OBSOLETE #include "gdb_stat.h" */
+/* OBSOLETE  */
+/* OBSOLETE /* Assorted operating system circumventions */ */
+/* OBSOLETE  */
+/* OBSOLETE #ifdef SYM1 */
+/* OBSOLETE  */
+/* OBSOLETE /* FIXME: Kludge this for now. It really should be system call. */ */
+/* OBSOLETE int */
+/* OBSOLETE getpagesize (void) */
+/* OBSOLETE { */
+/* OBSOLETE   return (8192); */
+/* OBSOLETE } */
+/* OBSOLETE  */
+/* OBSOLETE /* FIXME: Fake out the fcntl() call, which we don't have.  */ */
+/* OBSOLETE fcntl (int fd, int cmd, int arg) */
+/* OBSOLETE { */
+/* OBSOLETE  */
+/* OBSOLETE   switch (cmd) */
+/* OBSOLETE     { */
+/* OBSOLETE     case F_GETFL: */
+/* OBSOLETE       return (O_RDONLY); */
+/* OBSOLETE       break; */
+/* OBSOLETE     default: */
+/* OBSOLETE       printf_unfiltered ("Ultra3's fcntl() failing, cmd = %d.\n", cmd); */
+/* OBSOLETE       return (-1); */
+/* OBSOLETE     } */
+/* OBSOLETE } */
+/* OBSOLETE  */
+/* OBSOLETE  */
+/* OBSOLETE /*  */
+/* OBSOLETE  * 4.2 Signal support, requires linking with libjobs. */
+/* OBSOLETE  */ */
+/* OBSOLETE static int _SigMask; */
+/* OBSOLETE #define sigbit(s)       (1L << ((s)-1)) */
+/* OBSOLETE  */
+/* OBSOLETE init_SigMask (void) */
+/* OBSOLETE { */
+/* OBSOLETE   /* Taken from the sym1 kernel in machdep.c:startup() */ */
+/* OBSOLETE   _SigMask = sigbit (SIGTSTP) | sigbit (SIGTTOU) | sigbit (SIGTTIN) | */
+/* OBSOLETE     sigbit (SIGCHLD) | sigbit (SIGTINT); */
+/* OBSOLETE } */
+/* OBSOLETE  */
+/* OBSOLETE sigmask (int signo) */
+/* OBSOLETE { */
+/* OBSOLETE   return (1 << (signo - 1)); */
+/* OBSOLETE } */
+/* OBSOLETE  */
+/* OBSOLETE sigsetmask (unsigned int sigmask) */
+/* OBSOLETE { */
+/* OBSOLETE   int i, mask = 1; */
+/* OBSOLETE   int lastmask = _SigMask; */
+/* OBSOLETE  */
+/* OBSOLETE   for (i = 0; i < NSIG; i++) */
+/* OBSOLETE     { */
+/* OBSOLETE       if (sigmask & mask) */
+/* OBSOLETE    { */
+/* OBSOLETE      if (!(_SigMask & mask)) */
+/* OBSOLETE        { */
+/* OBSOLETE          sighold (i + 1); */
+/* OBSOLETE          _SigMask |= mask; */
+/* OBSOLETE        } */
+/* OBSOLETE    } */
+/* OBSOLETE       else if (_SigMask & mask) */
+/* OBSOLETE    { */
+/* OBSOLETE      sigrelse (i + 1); */
+/* OBSOLETE      _SigMask &= ~mask; */
+/* OBSOLETE    } */
+/* OBSOLETE       mask <<= 1; */
+/* OBSOLETE     } */
+/* OBSOLETE   return (lastmask); */
+/* OBSOLETE } */
+/* OBSOLETE  */
+/* OBSOLETE sigblock (unsigned int sigmask) */
+/* OBSOLETE { */
+/* OBSOLETE   int i, mask = 1; */
+/* OBSOLETE   int lastmask = _SigMask; */
+/* OBSOLETE  */
+/* OBSOLETE   for (i = 0; i < NSIG; i++) */
+/* OBSOLETE     { */
+/* OBSOLETE       if ((sigmask & mask) && !(_SigMask & mask)) */
+/* OBSOLETE    { */
+/* OBSOLETE      sighold (i + 1); */
+/* OBSOLETE      _SigMask |= mask; */
+/* OBSOLETE    } */
+/* OBSOLETE       mask <<= 1; */
+/* OBSOLETE     } */
+/* OBSOLETE   return (lastmask); */
+/* OBSOLETE } */
+/* OBSOLETE #endif /* SYM1 */ */
+/* OBSOLETE  */
+/* OBSOLETE  */
+/* OBSOLETE /* Initialization code for this module.  */ */
+/* OBSOLETE  */
+/* OBSOLETE void */
+/* OBSOLETE _initialize_ultra3 (void) */
+/* OBSOLETE { */
+/* OBSOLETE #ifdef SYM1 */
+/* OBSOLETE   init_SigMask (); */
+/* OBSOLETE #endif */
+/* OBSOLETE } */
This page took 0.026492 seconds and 4 git commands to generate.