From 3fa311e5acd58ce720014dd964728c2fa414ca6a Mon Sep 17 00:00:00 2001 From: Brandon Potter Date: Thu, 17 Mar 2016 10:22:39 -0700 Subject: syscall_emul: add many Linux kernel flags --- src/arch/mips/linux/linux.cc | 42 +++++++++++++++++++++++++++------ src/arch/mips/linux/linux.hh | 56 +++++++++++++++++++++++++++++++++++++------- 2 files changed, 82 insertions(+), 16 deletions(-) (limited to 'src/arch/mips') diff --git a/src/arch/mips/linux/linux.cc b/src/arch/mips/linux/linux.cc index ce1d7664a..4861f7cb9 100644 --- a/src/arch/mips/linux/linux.cc +++ b/src/arch/mips/linux/linux.cc @@ -38,32 +38,60 @@ SyscallFlagTransTable MipsLinux::openFlagTable[] = { { MipsLinux::TGT_O_RDONLY, _O_RDONLY }, { MipsLinux::TGT_O_WRONLY, _O_WRONLY }, { MipsLinux::TGT_O_RDWR, _O_RDWR }, - { MipsLinux::TGT_O_APPEND, _O_APPEND }, { MipsLinux::TGT_O_CREAT, _O_CREAT }, - { MipsLinux::TGT_O_TRUNC, _O_TRUNC }, { MipsLinux::TGT_O_EXCL, _O_EXCL }, +#ifdef _O_NOCTTY + { MipsLinux::TGT_O_NOCTTY, _O_NOCTTY }, +#endif + { MipsLinux::TGT_O_TRUNC, _O_TRUNC }, + { MipsLinux::TGT_O_APPEND, _O_APPEND }, #ifdef _O_NONBLOCK { MipsLinux::TGT_O_NONBLOCK, _O_NONBLOCK }, #endif -#ifdef _O_NOCTTY - { MipsLinux::TGT_O_NOCTTY, _O_NOCTTY }, +#ifdef _O_DSYNC + { MipsLinux::TGT_O_DSYNC, _O_DSYNC }, +#endif + { MipsLinux::TGT_O_DIRECT, _O_DIRECT }, + { MipsLinux::TGT_O_LARGEFILE, _O_LARGEFILE }, + { MipsLinux::TGT_O_DIRECTORY, _O_DIRECTORY }, + { MipsLinux::TGT_O_NOFOLLOW, _O_NOFOLLOW }, + { MipsLinux::TGT_O_NOATIME, _O_NOATIME }, +#ifdef _O_CLOEXEC + { MipsLinux::TGT_O_CLOEXEC, _O_CLOEXEC }, #endif #ifdef _O_SYNC { MipsLinux::TGT_O_SYNC, _O_SYNC }, #endif +#ifdef _O_PATH + { MipsLinux::TGT_O_PATH, _O_PATH }, +#endif #else /* !_MSC_VER */ { MipsLinux::TGT_O_RDONLY, O_RDONLY }, { MipsLinux::TGT_O_WRONLY, O_WRONLY }, { MipsLinux::TGT_O_RDWR, O_RDWR }, - { MipsLinux::TGT_O_APPEND, O_APPEND }, { MipsLinux::TGT_O_CREAT, O_CREAT }, - { MipsLinux::TGT_O_TRUNC, O_TRUNC }, { MipsLinux::TGT_O_EXCL, O_EXCL }, - { MipsLinux::TGT_O_NONBLOCK, O_NONBLOCK }, { MipsLinux::TGT_O_NOCTTY, O_NOCTTY }, + { MipsLinux::TGT_O_TRUNC, O_TRUNC }, + { MipsLinux::TGT_O_APPEND, O_APPEND }, + { MipsLinux::TGT_O_NONBLOCK, O_NONBLOCK }, +#ifdef O_DSYNC + { MipsLinux::TGT_O_DSYNC, O_DSYNC }, +#endif + { MipsLinux::TGT_O_DIRECT, O_DIRECT }, + { MipsLinux::TGT_O_LARGEFILE, O_LARGEFILE }, + { MipsLinux::TGT_O_DIRECTORY, O_DIRECTORY }, + { MipsLinux::TGT_O_NOFOLLOW, O_NOFOLLOW }, + { MipsLinux::TGT_O_NOATIME, O_NOATIME }, +#ifdef O_CLOEXEC + { MipsLinux::TGT_O_CLOEXEC, O_CLOEXEC }, +#endif #ifdef O_SYNC { MipsLinux::TGT_O_SYNC, O_SYNC }, #endif +#ifdef O_PATH + { MipsLinux::TGT_O_PATH, O_PATH }, +#endif #endif /* _MSC_VER */ }; diff --git a/src/arch/mips/linux/linux.hh b/src/arch/mips/linux/linux.hh index 50a0362da..6e4b6a82d 100644 --- a/src/arch/mips/linux/linux.hh +++ b/src/arch/mips/linux/linux.hh @@ -37,6 +37,41 @@ class MipsLinux : public Linux { public: + static const int TGT_SIGHUP = 0x000001; + static const int TGT_SIGINT = 0x000002; + static const int TGT_SIGQUIT = 0x000003; + static const int TGT_SIGILL = 0x000004; + static const int TGT_SIGTRAP = 0x000005; + static const int TGT_SIGIOT = 0x000006; + static const int TGT_SIGABRT = 0x000006; + static const int TGT_SIGEMT = 0x000007; + static const int TGT_SIGFPE = 0x000008; + static const int TGT_SIGKILL = 0x000009; + static const int TGT_SIGBUS = 0x00000a; + static const int TGT_SIGSEGV = 0x00000b; + static const int TGT_SIGSYS = 0x00000c; + static const int TGT_SIGPIPE = 0x00000d; + static const int TGT_SIGALRM = 0x00000e; + static const int TGT_SIGTERM = 0x00000f; + static const int TGT_SIGUSR1 = 0x000010; + static const int TGT_SIGUSR2 = 0x000011; + static const int TGT_SIGCHLD = 0x000012; + static const int TGT_SIGCLD = 0x000012; + static const int TGT_SIGPWR = 0x000013; + static const int TGT_SIGWINCH = 0x000014; + static const int TGT_SIGURG = 0x000015; + static const int TGT_SIGIO = 0x000016; + static const int TGT_SIGPOLL = 0x000016; + static const int TGT_SIGSTOP = 0x000017; + static const int TGT_SIGTSTP = 0x000018; + static const int TGT_SIGCONT = 0x000019; + static const int TGT_SIGTTIN = 0x00001a; + static const int TGT_SIGTTOU = 0x00001b; + static const int TGT_SIGVTALRM = 0x00001c; + static const int TGT_SIGPROF = 0x00001d; + static const int TGT_SIGXCPU = 0x00001e; + static const int TGT_SIGXFSZ = 0x00001f; + /// This table maps the target open() flags to the corresponding /// host open() flags. static SyscallFlagTransTable openFlagTable[]; @@ -49,18 +84,21 @@ class MipsLinux : public Linux static const int TGT_O_RDONLY = 0x00000000; //!< O_RDONLY static const int TGT_O_WRONLY = 0x00000001; //!< O_WRONLY static const int TGT_O_RDWR = 0x00000002; //!< O_RDWR - static const int TGT_O_NONBLOCK = 0x00000080; //!< O_NONBLOCK - static const int TGT_O_APPEND = 0x00000008; //!< O_APPEND static const int TGT_O_CREAT = 0x00000100; //!< O_CREAT - static const int TGT_O_TRUNC = 0x00000200; //!< O_TRUNC static const int TGT_O_EXCL = 0x00000400; //!< O_EXCL static const int TGT_O_NOCTTY = 0x00000800; //!< O_NOCTTY - static const int TGT_O_SYNC = 0x00000010; //!< O_SYNC - static const int TGT_O_DRD = 0x00010000; //!< O_DRD - static const int TGT_O_DIRECTIO = 0x00020000; //!< O_DIRECTIO - static const int TGT_O_CACHE = 0x00002000; //!< O_CACHE - static const int TGT_O_DSYNC = 0x00008000; //!< O_DSYNC - static const int TGT_O_RSYNC = 0x00040000; //!< O_RSYNC + static const int TGT_O_TRUNC = 0x00000200; //!< O_TRUNC + static const int TGT_O_APPEND = 0x00000008; //!< O_APPEND + static const int TGT_O_NONBLOCK = 0x00000080; //!< O_NONBLOCK + static const int TGT_O_DSYNC = 0x00000010; //!< O_DSYNC + static const int TGT_O_DIRECT = 0x00008000; //!< O_DIRECT + static const int TGT_O_LARGEFILE = 0x00002000; //!< O_LARGEFILE + static const int TGT_O_DIRECTORY = 0x00010000; //!< O_DIRECTORY + static const int TGT_O_NOFOLLOW = 0x00020000; //!< O_NOFOLLOW + static const int TGT_O_NOATIME = 0x00040000; //!< O_NOATIME + static const int TGT_O_CLOEXEC = 0x00080000; //!< O_CLOEXEC + static const int TGT_O_SYNC = 0x00004010; //!< O_SYNC + static const int TGT_O_PATH = 0x00200000; //!< O_PATH //@} /// For mmap(). -- cgit v1.2.3