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