Add base ARM code to M5
--HG-- extra : convert_revision : d811bf87d1a0bfc712942ecd3db1b48fc75257af
This commit is contained in:
parent
ca313e2303
commit
0ccf9a2c37
9 changed files with 45 additions and 6 deletions
|
@ -6,3 +6,4 @@ cscope.files
|
||||||
cscope.out
|
cscope.out
|
||||||
*.pyc
|
*.pyc
|
||||||
*~
|
*~
|
||||||
|
.*.swp
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -50,7 +50,8 @@ class ObjectFile
|
||||||
SPARC64,
|
SPARC64,
|
||||||
SPARC32,
|
SPARC32,
|
||||||
Mips,
|
Mips,
|
||||||
X86
|
X86,
|
||||||
|
Arm
|
||||||
};
|
};
|
||||||
|
|
||||||
enum OpSys {
|
enum OpSys {
|
||||||
|
|
|
@ -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']
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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; }
|
||||||
};
|
};
|
||||||
|
|
|
@ -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.");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue