/* 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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 "gdb_stat.h" /* 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_unfiltered("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. */ void _initialize_ultra3 () { #ifdef SYM1 init_SigMask(); #endif }