Add base ARM code to M5

--HG--
extra : convert_revision : d811bf87d1a0bfc712942ecd3db1b48fc75257af
This commit is contained in:
Stephen Hines 2008-02-05 23:44:13 -05:00
parent ca313e2303
commit 0ccf9a2c37
9 changed files with 45 additions and 6 deletions

View file

@ -6,3 +6,4 @@ cscope.files
cscope.out cscope.out
*.pyc *.pyc
*~ *~
.*.swp

View file

@ -49,6 +49,7 @@
#define SPARC_ISA 42 #define SPARC_ISA 42
#define MIPS_ISA 34000 #define MIPS_ISA 34000
#define X86_ISA 8086 #define X86_ISA 8086
#define ARM_ISA 6
//These tell the preprocessor where to find the files of a particular //These tell the preprocessor where to find the files of a particular
//ISA, and set the "TheISA" macro for use elsewhere. //ISA, and set the "TheISA" macro for use elsewhere.
@ -60,6 +61,8 @@
#define TheISA MipsISA #define TheISA MipsISA
#elif THE_ISA == X86_ISA #elif THE_ISA == X86_ISA
#define TheISA X86ISA #define TheISA X86ISA
#elif THE_ISA == ARM_ISA
#define TheISA ArmISA
#else #else
#error "THE_ISA not set" #error "THE_ISA not set"
#endif #endif

View file

@ -88,6 +88,8 @@ ElfObject::tryFile(const string &fname, int fd, size_t len, uint8_t *data)
arch = ObjectFile::X86; arch = ObjectFile::X86;
} else if (ehdr.e_ident[EI_CLASS] == ELFCLASS64) { } else if (ehdr.e_ident[EI_CLASS] == ELFCLASS64) {
arch = ObjectFile::Alpha; arch = ObjectFile::Alpha;
} else if (ehdr.e_machine == EM_ARM) {
arch = ObjectFile::Arm;
} else { } else {
warn("Unknown architecture: %d\n", ehdr.e_machine); warn("Unknown architecture: %d\n", ehdr.e_machine);
arch = ObjectFile::UnknownArch; arch = ObjectFile::UnknownArch;
@ -98,6 +100,7 @@ ElfObject::tryFile(const string &fname, int fd, size_t len, uint8_t *data)
{ {
case ELFOSABI_LINUX: case ELFOSABI_LINUX:
case ELFOSABI_ARM:
opSys = ObjectFile::Linux; opSys = ObjectFile::Linux;
break; break;
case ELFOSABI_SOLARIS: case ELFOSABI_SOLARIS:

View file

@ -50,7 +50,8 @@ class ObjectFile
SPARC64, SPARC64,
SPARC32, SPARC32,
Mips, Mips,
X86 X86,
Arm
}; };
enum OpSys { enum OpSys {

View file

@ -1,4 +1,4 @@
# Copyright (c) 2005-2007 The Regents of The University of Michigan # Copyright (c) 2005-2008 The Regents of The University of Michigan
# All rights reserved. # All rights reserved.
# #
# Redistribution and use in source and binary forms, with or without # Redistribution and use in source and binary forms, with or without
@ -45,6 +45,8 @@ elif build_env['TARGET_ISA'] == 'x86':
from X86TLB import X86DTB, X86ITB from X86TLB import X86DTB, X86ITB
elif build_env['TARGET_ISA'] == 'mips': elif build_env['TARGET_ISA'] == 'mips':
from MipsTLB import MipsTLB,MipsDTB, MipsITB, MipsUTB from MipsTLB import MipsTLB,MipsDTB, MipsITB, MipsUTB
elif build_env['TARGET_ISA'] == 'arm':
from ArmTLB import ArmTLB, ArmDTB, ArmITB, ArmUTB
class BaseCPU(SimObject): class BaseCPU(SimObject):
type = 'BaseCPU' type = 'BaseCPU'
@ -76,6 +78,11 @@ class BaseCPU(SimObject):
dtb = Param.MipsDTB(MipsDTB(), "Data TLB") dtb = Param.MipsDTB(MipsDTB(), "Data TLB")
itb = Param.MipsITB(MipsITB(), "Instruction TLB") itb = Param.MipsITB(MipsITB(), "Instruction TLB")
tlb = Param.MipsUTB(MipsUTB(), "Unified TLB") tlb = Param.MipsUTB(MipsUTB(), "Unified TLB")
elif build_env['TARGET_ISA'] == 'arm':
UnifiedTLB = Param.Bool(True, "Is this a Unified TLB?")
dtb = Param.ArmDTB(ArmDTB(), "Data TLB")
itb = Param.ArmITB(ArmITB(), "Instruction TLB")
tlb = Param.ArmUTB(ArmUTB(), "Unified TLB")
else: else:
print "Don't know what TLB to use for ISA %s" % \ print "Don't know what TLB to use for ISA %s" % \
build_env['TARGET_ISA'] build_env['TARGET_ISA']

View file

@ -49,6 +49,10 @@
template <class Impl> class X86DynInst; template <class Impl> class X86DynInst;
struct X86SimpleImpl; struct X86SimpleImpl;
typedef X86DynInst<X86SimpleImpl> O3DynInst; typedef X86DynInst<X86SimpleImpl> O3DynInst;
#elif THE_ISA == ARM_ISA
template <class Impl> class ArmDynInst;
struct ArmSimpleImpl;
typedef ArmDynInst<ArmSimpleImpl> O3DynInst;
#else #else
#error "O3DynInst not defined for this ISA" #error "O3DynInst not defined for this ISA"
#endif #endif

View file

@ -598,13 +598,19 @@ TimingSimpleCPU::completeIfetch(PacketPtr pkt)
assert(fault == NoFault); assert(fault == NoFault);
} else { } else {
if (fault == NoFault) { if (fault == NoFault) {
// Note that ARM can have NULL packets if the instruction gets
// squashed due to predication
// early fail on store conditional: complete now // early fail on store conditional: complete now
assert(dcache_pkt != NULL); assert(dcache_pkt != NULL || THE_ISA == ARM_ISA);
fault = curStaticInst->completeAcc(dcache_pkt, this, fault = curStaticInst->completeAcc(dcache_pkt, this,
traceData); traceData);
if (dcache_pkt != NULL)
{
delete dcache_pkt->req; delete dcache_pkt->req;
delete dcache_pkt; delete dcache_pkt;
dcache_pkt = NULL; dcache_pkt = NULL;
}
// keep an instruction count // keep an instruction count
if (fault == NoFault) if (fault == NoFault)

View file

@ -259,6 +259,7 @@ class StaticInstBase : public RefCounted
bool isMicroBranch() const { return flags[IsMicroBranch]; } bool isMicroBranch() const { return flags[IsMicroBranch]; }
//@} //@}
void setLastMicroop() { flags[IsLastMicroop] = true; }
/// Operation class. Used to select appropriate function unit in issue. /// Operation class. Used to select appropriate function unit in issue.
OpClass opClass() const { return _opClass; } OpClass opClass() const { return _opClass; }
}; };

View file

@ -61,6 +61,8 @@
#include "arch/sparc/solaris/process.hh" #include "arch/sparc/solaris/process.hh"
#elif THE_ISA == MIPS_ISA #elif THE_ISA == MIPS_ISA
#include "arch/mips/linux/process.hh" #include "arch/mips/linux/process.hh"
#elif THE_ISA == ARM_ISA
#include "arch/arm/linux/process.hh"
#elif THE_ISA == X86_ISA #elif THE_ISA == X86_ISA
#include "arch/x86/linux/process.hh" #include "arch/x86/linux/process.hh"
#else #else
@ -697,6 +699,17 @@ LiveProcess::create(LiveProcessParams * params)
process = new MipsLinuxProcess(params, objFile); process = new MipsLinuxProcess(params, objFile);
break; break;
default:
fatal("Unknown/unsupported operating system.");
}
#elif THE_ISA == ARM_ISA
if (objFile->getArch() != ObjectFile::Arm)
fatal("Object file architecture does not match compiled ISA (ARM).");
switch (objFile->getOpSys()) {
case ObjectFile::Linux:
process = new ArmLinuxProcess(params, objFile);
break;
default: default:
fatal("Unknown/unsupported operating system."); fatal("Unknown/unsupported operating system.");
} }