utility.cc revision 6048
13584Ssaidi@eecs.umich.edu/* 23584Ssaidi@eecs.umich.edu * Copyright (c) 2003-2005 The Regents of The University of Michigan 33584Ssaidi@eecs.umich.edu * All rights reserved. 43584Ssaidi@eecs.umich.edu * 53584Ssaidi@eecs.umich.edu * Redistribution and use in source and binary forms, with or without 63584Ssaidi@eecs.umich.edu * modification, are permitted provided that the following conditions are 73584Ssaidi@eecs.umich.edu * met: redistributions of source code must retain the above copyright 83584Ssaidi@eecs.umich.edu * notice, this list of conditions and the following disclaimer; 93584Ssaidi@eecs.umich.edu * redistributions in binary form must reproduce the above copyright 103584Ssaidi@eecs.umich.edu * notice, this list of conditions and the following disclaimer in the 113584Ssaidi@eecs.umich.edu * documentation and/or other materials provided with the distribution; 123584Ssaidi@eecs.umich.edu * neither the name of the copyright holders nor the names of its 133584Ssaidi@eecs.umich.edu * contributors may be used to endorse or promote products derived from 143584Ssaidi@eecs.umich.edu * this software without specific prior written permission. 153584Ssaidi@eecs.umich.edu * 163584Ssaidi@eecs.umich.edu * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 173584Ssaidi@eecs.umich.edu * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 183584Ssaidi@eecs.umich.edu * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 193584Ssaidi@eecs.umich.edu * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 203584Ssaidi@eecs.umich.edu * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 213584Ssaidi@eecs.umich.edu * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 223584Ssaidi@eecs.umich.edu * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 233584Ssaidi@eecs.umich.edu * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 243584Ssaidi@eecs.umich.edu * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 253584Ssaidi@eecs.umich.edu * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 263584Ssaidi@eecs.umich.edu * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 273584Ssaidi@eecs.umich.edu * 283584Ssaidi@eecs.umich.edu * Authors: Nathan Binkert 293584Ssaidi@eecs.umich.edu * Ali Saidi 303584Ssaidi@eecs.umich.edu */ 313584Ssaidi@eecs.umich.edu 323603Ssaidi@eecs.umich.edu#include "arch/alpha/utility.hh" 333584Ssaidi@eecs.umich.edu 348232Snate@binkert.org#if FULL_SYSTEM 353584Ssaidi@eecs.umich.edu#include "arch/alpha/vtophys.hh" 363584Ssaidi@eecs.umich.edu#include "mem/vport.hh" 3710880SCurtis.Dunham@arm.com#endif 383584Ssaidi@eecs.umich.edu 3910880SCurtis.Dunham@arm.comnamespace AlphaISA { 403584Ssaidi@eecs.umich.edu 413584Ssaidi@eecs.umich.eduuint64_t 423584Ssaidi@eecs.umich.edugetArgument(ThreadContext *tc, int number, bool fp) 4310880SCurtis.Dunham@arm.com{ 443584Ssaidi@eecs.umich.edu#if FULL_SYSTEM 4510880SCurtis.Dunham@arm.com const int NumArgumentRegs = 6; 463584Ssaidi@eecs.umich.edu if (number < NumArgumentRegs) { 473584Ssaidi@eecs.umich.edu if (fp) 483584Ssaidi@eecs.umich.edu return tc->readFloatRegBits(16 + number); 493584Ssaidi@eecs.umich.edu else 503584Ssaidi@eecs.umich.edu return tc->readIntReg(16 + number); 513584Ssaidi@eecs.umich.edu } else { 523584Ssaidi@eecs.umich.edu Addr sp = tc->readIntReg(StackPointerReg); 533584Ssaidi@eecs.umich.edu VirtualPort *vp = tc->getVirtPort(); 543584Ssaidi@eecs.umich.edu uint64_t arg = vp->read<uint64_t>(sp + 553584Ssaidi@eecs.umich.edu (number-NumArgumentRegs) * sizeof(uint64_t)); 563584Ssaidi@eecs.umich.edu return arg; 573584Ssaidi@eecs.umich.edu } 583584Ssaidi@eecs.umich.edu#else 593584Ssaidi@eecs.umich.edu panic("getArgument() is Full system only\n"); 603584Ssaidi@eecs.umich.edu M5_DUMMY_RETURN; 613584Ssaidi@eecs.umich.edu#endif 623584Ssaidi@eecs.umich.edu} 633584Ssaidi@eecs.umich.edu 643584Ssaidi@eecs.umich.edu} // namespace AlphaISA 653812Ssaidi@eecs.umich.edu 663584Ssaidi@eecs.umich.edu