summaryrefslogtreecommitdiff
path: root/kern/linux
diff options
context:
space:
mode:
authorAndrew Schultz <alschult@umich.edu>2004-02-21 20:31:08 -0500
committerAndrew Schultz <alschult@umich.edu>2004-02-21 20:31:08 -0500
commitc82113d02296c40e1a2eac84ba55ae7ffbcf4419 (patch)
tree1ca4ba2b062f7c7cacefa84fe4db3ba7b63ffbbd /kern/linux
parent43787ad8639f6ed32d99acb7b1347e58797fde6c (diff)
downloadgem5-c82113d02296c40e1a2eac84ba55ae7ffbcf4419.tar.xz
Load local kernel symbols, and set aic7xxx_no_reset to prevent an initial
(very painful) bus reset from occuring base/loader/elf_object.cc: Fixed to allow proper loading of local symbols --HG-- extra : convert_revision : 5c9a1f4d7b5748a1c8cabdfd67763c21f988f8fd
Diffstat (limited to 'kern/linux')
-rw-r--r--kern/linux/linux_system.cc14
1 files changed, 14 insertions, 0 deletions
diff --git a/kern/linux/linux_system.cc b/kern/linux/linux_system.cc
index 798577ba5..718e54ad2 100644
--- a/kern/linux/linux_system.cc
+++ b/kern/linux/linux_system.cc
@@ -77,6 +77,9 @@ LinuxSystem::LinuxSystem(const string _name, const uint64_t _init_param,
panic("could not load kernel symbols\n");
debugSymbolTable = kernelSymtab;
+ if (!kernel->loadLocalSymbols(kernelSymtab))
+ panic("could not load kernel local symbols\n");
+
if (!console->loadGlobalSymbols(consoleSymtab))
panic("could not load console symbols\n");
@@ -271,6 +274,7 @@ LinuxSystem::LinuxSystem(const string _name, const uint64_t _init_param,
#endif //FS_MEASURE
Addr addr = 0;
+
if (kernelSymtab->findAddress("est_cycle_freq", addr)) {
Addr paddr = vtophys(physmem, addr);
uint8_t *est_cycle_frequency =
@@ -280,6 +284,16 @@ LinuxSystem::LinuxSystem(const string _name, const uint64_t _init_param,
*(uint64_t *)est_cycle_frequency = ticksPerSecond;
}
+ if (kernelSymtab->findAddress("aic7xxx_no_reset", addr)) {
+ Addr paddr = vtophys(physmem, addr);
+ uint8_t *aic7xxx_no_reset =
+ physmem->dma_addr(paddr, sizeof(uint32_t));
+
+ if (aic7xxx_no_reset) {
+ *(uint32_t *)aic7xxx_no_reset = 1;
+ }
+ }
+
if (consoleSymtab->findAddress("env_booted_osflags", addr)) {
Addr paddr = vtophys(physmem, addr);
char *osflags = (char *)physmem->dma_addr(paddr, sizeof(uint32_t));