Go to the documentation of this file.
36 #include "debug/IsaFake.hh"
55 if (
params().warn_access !=
"")
56 warn(
"Device %s accessed by read to address %#x size=%d\n",
58 if (
params().ret_bad_addr) {
67 case sizeof(uint64_t):
70 case sizeof(uint32_t):
73 case sizeof(uint16_t):
83 panic(
"invalid access size! Device being accessed by cache?\n");
93 if (
params().warn_access !=
"") {
96 case sizeof(uint64_t):
99 case sizeof(uint32_t):
102 case sizeof(uint16_t):
105 case sizeof(uint8_t):
111 warn(
"Device %s accessed by write to address %#x size=%d data=%#x\n",
114 if (
params().ret_bad_addr) {
122 if (
params().update_data) {
124 case sizeof(uint64_t):
127 case sizeof(uint32_t):
130 case sizeof(uint16_t):
133 case sizeof(uint8_t):
137 panic(
"invalid access size!\n");
void makeAtomicResponse()
Addr pioAddr
Address that the device listens to.
uint64_t Tick
Tick count type.
IsaFake(const Params &p)
The constructor for Isa Fake just registers itself with the MMU.
virtual Tick read(PacketPtr pkt)
This read always returns -1.
virtual Tick write(PacketPtr pkt)
All writes are simply ignored.
Addr pioSize
Size that the device's address range.
IsaFake is a device that returns, BadAddr, 1 or 0 on all reads and rites.
virtual const std::string name() const
T getLE() const
Get the data in the packet byte swapped from little endian to host endian.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
Tick pioDelay
Delay that the device experinces on an access.
void setLE(T v)
Set the value in the data pointer to v as little endian.
T * getPtr()
get a pointer to the data ptr.
const Params & params() const
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Mar 23 2021 19:41:26 for gem5 by doxygen 1.8.17