# Node ID 767b13a252feb530d5db97591e53f0b5b569fda6 # Parent 96f28447a81571f63652082845a53a177913e009 diff --git a/src/arch/x86/linux/linux.hh b/src/arch/x86/linux/linux.hh --- a/src/arch/x86/linux/linux.hh +++ b/src/arch/x86/linux/linux.hh @@ -67,6 +67,24 @@ int64_t unused0[3]; } tgt_stat64; + typedef struct { + long val[2]; + } tgt_fsid; + + typedef struct { + long f_type; + long f_bsize; + long f_blocks; + long f_bfree; + long f_bavail; + long f_files; + long f_ffree; + tgt_fsid f_fsid; + long f_namelen; + long f_frsize; + long f_spare[5]; + } tgt_statfs; + static const int TGT_SIGHUP = 0x000001; static const int TGT_SIGINT = 0x000002; static const int TGT_SIGQUIT = 0x000003; diff --git a/src/arch/x86/linux/process.cc b/src/arch/x86/linux/process.cc --- a/src/arch/x86/linux/process.cc +++ b/src/arch/x86/linux/process.cc @@ -355,7 +355,7 @@ /* 134 */ SyscallDesc("uselib", unimplementedFunc), /* 135 */ SyscallDesc("personality", unimplementedFunc), /* 136 */ SyscallDesc("ustat", unimplementedFunc), - /* 137 */ SyscallDesc("statfs", unimplementedFunc), + /* 137 */ SyscallDesc("statfs", statfsFunc), /* 138 */ SyscallDesc("fstatfs", unimplementedFunc), /* 139 */ SyscallDesc("sysfs", unimplementedFunc), /* 140 */ SyscallDesc("getpriority", unimplementedFunc), diff --git a/src/sim/syscall_emul.hh b/src/sim/syscall_emul.hh --- a/src/sim/syscall_emul.hh +++ b/src/sim/syscall_emul.hh @@ -62,6 +62,7 @@ #include #include #include +#include #include #include #include @@ -451,6 +452,7 @@ // ////////////////////////////////////////////////////////////////////// + typedef struct statfs hst_statfs; #if NO_STAT64 typedef struct stat hst_stat; typedef struct stat hst_stat64; @@ -556,6 +558,32 @@ tgt.copyOut(mem); } +template +static void +copyOutStatfsBuf(SETranslatingPortProxy &mem, Addr addr, + hst_statfs *host) +{ + TypedBufferArg tgt(addr); + +#if defined(__OpenBSD__) || defined(__APPLE__) || defined(__FreeBSD__) + tgt->f_type = 0; +#else + tgt->f_type = TheISA::htog(host->f_type); +#endif + tgt->f_bsize = TheISA::htog(host->f_bsize); + tgt->f_blocks = TheISA::htog(host->f_blocks); + tgt->f_bfree = TheISA::htog(host->f_bfree); + tgt->f_bavail = TheISA::htog(host->f_bavail); + tgt->f_files = TheISA::htog(host->f_files); + tgt->f_ffree = TheISA::htog(host->f_ffree); + memcpy(&tgt->f_fsid, &host->f_fsid, sizeof(host->f_fsid)); + tgt->f_namelen = TheISA::htog(host->f_namelen); + tgt->f_frsize = TheISA::htog(host->f_frsize); + memcpy(&tgt->f_spare, &host->f_spare, sizeof(host->f_spare)); + + tgt.copyOut(mem); +} + /// Target ioctl() handler. For the most part, programs call ioctl() /// only to find out if their stdout is a tty, to determine whether to /// do line or block buffering. We always claim that output fds are @@ -1156,7 +1184,7 @@ if (result < 0) return -errno; - OS::copyOutStatfsBuf(tc->getMemProxy(), bufPtr, &hostBuf); + copyOutStatfsBuf(tc->getMemProxy(), bufPtr, &hostBuf); return 0; } @@ -1182,7 +1210,7 @@ if (result < 0) return -errno; - OS::copyOutStatfsBuf(tc->getMemProxy(), bufPtr, &hostBuf); + copyOutStatfsBuf(tc->getMemProxy(), bufPtr, &hostBuf); return 0; }