Go to the documentation of this file.
28 #ifndef __DEV_QEMU_FW_CFG_HH__
29 #define __DEV_QEMU_FW_CFG_HH__
34 #include <type_traits>
40 #include "params/QemuFwCfg.hh"
41 #include "params/QemuFwCfgIo.hh"
42 #include "params/QemuFwCfgItem.hh"
43 #include "params/QemuFwCfgItemBytes.hh"
44 #include "params/QemuFwCfgItemFile.hh"
45 #include "params/QemuFwCfgItemString.hh"
46 #include "params/QemuFwCfgMmio.hh"
65 FwCfgItem(
const std::string &new_path,
bool arch_specific,
66 uint16_t new_index=0) :
77 virtual uint64_t
length()
const = 0;
79 virtual void read(
void *buf, uint64_t
offset, uint32_t to_read) = 0;
86 virtual const void *
bytes()
const = 0;
91 void read(
void *buf, uint64_t
offset, uint32_t to_read)
override;
102 const std::string
path, uint16_t new_index=0) :
122 const std::string _str, uint16_t new_index=0) :
130 const void *
bytes()
const override {
return (
void *)
str.data(); }
134 return sizeof(std::string::value_type) *
str.length();
154 const void *
bytes()
const override {
return (
void *)
data.data(); }
171 template <
class ItemType>
178 template <
class PType,
class =
typename std::enable_if_t<
179 std::is_base_of_v<SimObjectParams, PType>>>
193 std::map<std::string, uint16_t>
names;
213 void update(
const std::map<std::string, uint16_t> &
names,
214 const std::map<uint16_t, FwCfgItem *> &
numbers);
216 const void *
bytes()
const override {
return (
void *)
data.data(); }
229 void select(uint16_t key);
237 void readItem(
void *buf, uint32_t length);
274 #endif //__DEV_QEMU_FW_CFG_HH__
bool archSpecific() const
uint64_t length() const override
FwCfgItemString(const QemuFwCfgItemStringParams &p)
FwCfgItem(const std::string &new_path, bool arch_specific, uint16_t new_index=0)
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
This device is the base class which all devices senstive to an address range inherit from.
void select(uint16_t key)
FwCfgItemBytes(const std::string &new_path, bool arch_specific, const std::vector< uint8_t > &_data, uint16_t new_index=0)
FwCfgItemFactory(const PType &p)
uint64_t length() const override
static const uint32_t MaxArchIndex
uint64_t length() const override
virtual uint64_t length() const =0
std::vector< uint8_t > data
virtual const void * bytes() const =0
FwCfgItem & item() override
void readItem(void *buf, uint32_t length)
FwCfgItemString(const std::string &new_path, bool arch_specific, const std::string _str, uint16_t new_index=0)
static const uint32_t MaxGenericIndex
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
FwCfg(const Params &p, const AddrRangeList &addr_ranges)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
const uint8_t * data() const
uint64_t Tick
Tick count type.
const void * bytes() const override
FwCfgMmio(const Params &p)
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
FwCfgItemFactoryBase(const Params &p)
std::map< std::string, uint16_t > names
FwCfgItemBytes(const QemuFwCfgItemBytesParams &p)
const void * bytes() const override
Abstract superclass for simulation objects.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
FwCfgItemFile(const QemuFwCfgItemFileParams &p)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const void * bytes() const override
void index(uint16_t new_index)
const void * bytes() const override
const AddrRangeList addrRanges
const std::string & path() const
virtual FwCfgItem & item()=0
FwCfgItemFile(const std::string &new_path, bool arch_specific, const std::string path, uint16_t new_index=0)
void addItem(FwCfgItem *item)
void read(void *buf, uint64_t offset, uint32_t to_read) override
std::vector< uint8_t > data
FwCfgItemString signature
uint64_t length() const override
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint32_t nextGenericIndex
std::map< uint16_t, FwCfgItem * > numbers
const gem5::loader::ImageFileData data
void update(const std::map< std::string, uint16_t > &names, const std::map< uint16_t, FwCfgItem * > &numbers)
virtual void read(void *buf, uint64_t offset, uint32_t to_read)=0
Generated on Wed Jul 13 2022 10:39:20 for gem5 by doxygen 1.8.17