From c1b748d691fe407c7cd43330658fba83e3435247 Mon Sep 17 00:00:00 2001 From: Gabe Black Date: Thu, 2 May 2019 22:51:09 -0700 Subject: base: Add a type for keeping track of object file loaders. This avoids having a big pile of #if-s in sim/process.cc and allows dynamically adding new types of object file loaders which might recognize new arch/OS combinations. Change-Id: Ie3b9c1aa2974d30a61afc4fcc529ffd6a74d43e0 Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/18583 Reviewed-by: Andreas Sandberg Maintainer: Andreas Sandberg Tested-by: kokoro --- src/base/loader/object_file.cc | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) (limited to 'src/base/loader/object_file.cc') diff --git a/src/base/loader/object_file.cc b/src/base/loader/object_file.cc index a82314e68..86278e44f 100644 --- a/src/base/loader/object_file.cc +++ b/src/base/loader/object_file.cc @@ -40,6 +40,7 @@ #include #include #include +#include #include "base/cprintf.hh" #include "base/loader/aout_object.hh" @@ -97,6 +98,37 @@ ObjectFile::loadSections(PortProxy& mem_proxy, Addr addr_mask, Addr offset) && loadSection(&bss, mem_proxy, addr_mask, offset)); } +namespace +{ + +typedef std::vector LoaderList; + +LoaderList & +object_file_loaders() +{ + static LoaderList loaders; + return loaders; +} + +} // anonymous namespace + +ObjectFile::Loader::Loader() +{ + object_file_loaders().emplace_back(this); +} + +Process * +ObjectFile::tryLoaders(ProcessParams *params, ObjectFile *obj_file) +{ + for (auto &loader: object_file_loaders()) { + Process *p = loader->load(params, obj_file); + if (p) + return p; + } + + return nullptr; +} + static bool hasGzipMagic(int fd) { -- cgit v1.2.3