Add the ability to use an address mask for symbol loading
Rather then silently failing on platform accesses panic
Move BadAddr/IsaFake no Device from Tsunami
Let the system kernel be none, but warn about it
configs/common/FSConfig.py:
We don't have a kernel for sparc yet
src/arch/sparc/system.cc:
Load the hypervisor symbols twice, once with an address mask so that we can get symbols for where it's copied to in memory
src/base/loader/aout_object.cc:
src/base/loader/aout_object.hh:
src/base/loader/ecoff_object.cc:
src/base/loader/ecoff_object.hh:
src/base/loader/elf_object.cc:
src/base/loader/elf_object.hh:
src/base/loader/object_file.hh:
src/base/loader/raw_object.cc:
src/base/loader/raw_object.hh:
Add the ability to use an address mask for symbol loading
src/dev/sparc/t1000.cc:
Rather then silently failing on platform accesses panic
src/dev/sparc/t1000.hh:
fix up a couple of platform comments
src/python/m5/objects/Bus.py:
src/python/m5/objects/Device.py:
src/python/m5/objects/T1000.py:
src/python/m5/objects/Tsunami.py:
Move BadAddr/IsaFake no Device from Tsunami
src/python/m5/objects/System.py:
Let kernel be none
src/sim/system.cc:
Let the system kernel be none, but warn about it
--HG--
extra : convert_revision : 92f6afef599a3d3c7c5026d03434102c41c7b5f4
82 lines
3.1 KiB
C++
82 lines
3.1 KiB
C++
/*
|
|
* Copyright (c) 2006 The Regents of The University of Michigan
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are
|
|
* met: redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer;
|
|
* redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution;
|
|
* neither the name of the copyright holders nor the names of its
|
|
* contributors may be used to endorse or promote products derived from
|
|
* this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* Authors: Steve Reinhardt
|
|
*/
|
|
|
|
#include "base/loader/raw_object.hh"
|
|
#include "base/loader/symtab.hh"
|
|
#include "base/trace.hh"
|
|
|
|
ObjectFile *
|
|
RawObject::tryFile(const std::string &fname, int fd, size_t len, uint8_t *data)
|
|
{
|
|
return new RawObject(fname, fd, len, data, ObjectFile::UnknownArch,
|
|
ObjectFile::UnknownOpSys);
|
|
}
|
|
|
|
RawObject::RawObject(const std::string &_filename, int _fd, size_t _len,
|
|
uint8_t *_data, Arch _arch, OpSys _opSys)
|
|
: ObjectFile(_filename, _fd, _len, _data, _arch, _opSys)
|
|
{
|
|
text.baseAddr = 0;
|
|
text.size = len;
|
|
text.fileImage = fileData;
|
|
|
|
data.baseAddr = 0;
|
|
data.size = 0;
|
|
data.fileImage = NULL;
|
|
|
|
bss.baseAddr = 0;
|
|
bss.size = 0;
|
|
bss.fileImage = NULL;
|
|
|
|
DPRINTFR(Loader, "text: 0x%x %d\ndata: 0x%x %d\nbss: 0x%x %d\n",
|
|
text.baseAddr, text.size, data.baseAddr, data.size,
|
|
bss.baseAddr, bss.size);
|
|
}
|
|
|
|
bool
|
|
RawObject::loadGlobalSymbols(SymbolTable *symtab, Addr addrMask)
|
|
{
|
|
int fnameStart = filename.rfind('/',filename.size()) + 1;
|
|
int extStart = filename.rfind('.',filename.size());
|
|
symtab->insert(text.baseAddr & addrMask, filename.substr(fnameStart,
|
|
extStart-fnameStart) + "_start");
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
RawObject::loadLocalSymbols(SymbolTable *symtab, Addr addrMask)
|
|
{
|
|
int fnameStart = filename.rfind('/',filename.size()) + 1;
|
|
int extStart = filename.rfind('.',filename.size());
|
|
symtab->insert(text.baseAddr & addrMask, filename.substr(fnameStart,
|
|
extStart-fnameStart) + "_start");
|
|
return true;
|
|
}
|