process.hh revision 7073
12SN/A/* 21762SN/A * Copyright (c) 2007 The Hewlett-Packard Development Company 32SN/A * All rights reserved. 42SN/A * 52SN/A * Redistribution and use of this software in source and binary forms, 62SN/A * with or without modification, are permitted provided that the 72SN/A * following conditions are met: 82SN/A * 92SN/A * The software must be used only for Non-Commercial Use which means any 102SN/A * use which is NOT directed to receiving any direct monetary 112SN/A * compensation for, or commercial advantage from such use. Illustrative 122SN/A * examples of non-commercial use are academic research, personal study, 132SN/A * teaching, education and corporate research & development. 142SN/A * Illustrative examples of commercial use are distributing products for 152SN/A * commercial advantage and providing services using the software for 162SN/A * commercial advantage. 172SN/A * 182SN/A * If you wish to use this software or functionality therein that may be 192SN/A * covered by patents for commercial use, please contact: 202SN/A * Director of Intellectual Property Licensing 212SN/A * Office of Strategy and Technology 222SN/A * Hewlett-Packard Company 232SN/A * 1501 Page Mill Road 242SN/A * Palo Alto, California 94304 252SN/A * 262SN/A * Redistributions of source code must retain the above copyright notice, 272665Ssaidi@eecs.umich.edu * this list of conditions and the following disclaimer. Redistributions 282665Ssaidi@eecs.umich.edu * in binary form must reproduce the above copyright notice, this list of 292665Ssaidi@eecs.umich.edu * conditions and the following disclaimer in the documentation and/or 302SN/A * other materials provided with the distribution. Neither the name of 312SN/A * the COPYRIGHT HOLDER(s), HEWLETT-PACKARD COMPANY, nor the names of its 322410SN/A * contributors may be used to endorse or promote products derived from 332410SN/A * this software without specific prior written permission. No right of 342SN/A * sublicense is granted herewith. Derivatives of the software and 352SN/A * output created using the software may be prepared, but only for 362SN/A * Non-Commercial Uses. Derivatives of the software may be shared with 372SN/A * others provided: (i) the others agree to abide by the list of 382SN/A * conditions herein which includes the Non-Commercial Use restrictions; 392SN/A * and (ii) such Derivatives of the software include the above copyright 402SN/A * notice to acknowledge the contribution from this software where 412SN/A * applicable, this list of conditions and the disclaimer below. 422SN/A * 432SN/A * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 442SN/A * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 452410SN/A * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 462410SN/A * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 472410SN/A * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 482410SN/A * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 492410SN/A * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 502410SN/A * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 512410SN/A * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 522410SN/A * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 532410SN/A * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 542410SN/A * 552410SN/A * Authors: Gabe Black 562410SN/A */ 572410SN/A 582410SN/A#ifndef __ARCH_X86_PROCESS_HH__ 592410SN/A#define __ARCH_X86_PROCESS_HH__ 602SN/A 612SN/A#include <string> 622SN/A#include <vector> 632410SN/A#include "sim/process.hh" 642SN/A 652SN/Aclass SyscallDesc; 662SN/A 672410SN/Anamespace X86ISA 68{ 69 enum X86AuxiliaryVectorTypes { 70 M5_AT_SYSINFO = 32, 71 M5_AT_SYSINFO_EHDR = 33 72 }; 73 74 class X86LiveProcess : public LiveProcess 75 { 76 protected: 77 Addr _gdtStart; 78 Addr _gdtSize; 79 80 SyscallDesc *syscallDescs; 81 const int numSyscallDescs; 82 83 X86LiveProcess(LiveProcessParams * params, ObjectFile *objFile, 84 SyscallDesc *_syscallDescs, int _numSyscallDescs); 85 86 template<class IntType> 87 void argsInit(int pageSize, 88 std::vector<AuxVector<IntType> > extraAuxvs); 89 90 public: 91 Addr gdtStart() 92 { return _gdtStart; } 93 94 Addr gdtSize() 95 { return _gdtSize; } 96 97 SyscallDesc* getDesc(int callnum); 98 99 void setSyscallReturn(ThreadContext *tc, SyscallReturn return_value); 100 }; 101 102 class X86_64LiveProcess : public X86LiveProcess 103 { 104 protected: 105 X86_64LiveProcess(LiveProcessParams *params, ObjectFile *objFile, 106 SyscallDesc *_syscallDescs, int _numSyscallDescs); 107 108 class VSyscallPage 109 { 110 public: 111 Addr base; 112 Addr size; 113 Addr vtimeOffset; 114 Addr vgettimeofdayOffset; 115 }; 116 VSyscallPage vsyscallPage; 117 118 public: 119 void argsInit(int intSize, int pageSize); 120 void startup(); 121 122 X86ISA::IntReg getSyscallArg(ThreadContext *tc, int &i); 123 void setSyscallArg(ThreadContext *tc, int i, X86ISA::IntReg val); 124 }; 125 126 class I386LiveProcess : public X86LiveProcess 127 { 128 protected: 129 I386LiveProcess(LiveProcessParams *params, ObjectFile *objFile, 130 SyscallDesc *_syscallDescs, int _numSyscallDescs); 131 132 class VSyscallPage 133 { 134 public: 135 Addr base; 136 Addr size; 137 Addr vsyscallOffset; 138 Addr vsysexitOffset; 139 }; 140 VSyscallPage vsyscallPage; 141 142 public: 143 void argsInit(int intSize, int pageSize); 144 void startup(); 145 146 void syscall(int64_t callnum, ThreadContext *tc); 147 X86ISA::IntReg getSyscallArg(ThreadContext *tc, int &i); 148 X86ISA::IntReg getSyscallArg(ThreadContext *tc, int &i, int width); 149 void setSyscallArg(ThreadContext *tc, int i, X86ISA::IntReg val); 150 }; 151} 152 153#endif // __ARCH_X86_PROCESS_HH__ 154