Go to the documentation of this file.
41 I8237::Register::ReadFunc
42 readUnimpl(
const std::string &label)
45 panic(
"Read from i8237 %s unimplemented.", label);
49 I8237::Register::WriteFunc
50 writeUnimpl(
const std::string &label)
53 panic(
"Write to i8237 %s unimplemented.", label);
62 reader(readUnimpl(
name()));
69 reader(readUnimpl(
name()));
77 panic(
"Illegal read from i8237 register %d.",
offset);
83 statusCommandReg(
"status/command"),
84 requestReg(
"request", 0x9),
85 setMaskBitReg(
"set mask bit", 0xa),
87 clearFlipFlopReg(
"clear flip-flop", 0xc),
88 temporaryMasterClearReg(
"temporary/maskter clear"),
89 clearMaskReg(
"clear mask", 0
xe),
90 writeMaskReg(
"write mask", 0xf)
93 for (
auto &channel: channels)
94 regs.addRegisters({ channel.addrReg, channel.remainingReg });
99 reader(readUnimpl(
"status register")).
100 writer(writeUnimpl(
"command register")),
103 writer(writeUnimpl(
"request register")),
109 writer(writeUnimpl(
"mode register")),
112 writer(writeUnimpl(
"clear LSB/MSB flip-flop register")),
114 temporaryMasterClearReg.
115 reader(readUnimpl(
"temporary register")).
116 writer(writeUnimpl(
"master clear register")),
119 writer(writeUnimpl(
"clear mask register")),
122 writer(writeUnimpl(
"write all mask register bits"))
129 uint8_t select =
bits(command, 1, 0);
130 uint8_t bitVal =
bits(command, 2);
132 panic(
"Turning on i8237 channels unimplemented.");
void makeAtomicResponse()
Addr pioAddr
Address that the device listens to.
ChannelAddrReg(Channel &)
#define UNSERIALIZE_SCALAR(scalar)
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::array< Channel, 4 > channels
RegisterBankLE::Register8 Register
uint64_t Tick
Tick count type.
virtual void write(Addr addr, const void *buf, Addr bytes)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void setMaskBit(Register ®, const uint8_t &command)
virtual void read(Addr addr, void *buf, Addr bytes)
ChannelRemainingReg(Channel &)
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
This is exposed globally, independent of the ISA.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
#define SERIALIZE_SCALAR(scalar)
virtual const std::string name() const
WriteOnlyReg(const std::string &new_name, Addr offset)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
T * getPtr()
get a pointer to the data ptr.
std::ostream CheckpointOut
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
std::string csprintf(const char *format, const Args &...args)
constexpr void replaceBits(T &val, unsigned first, unsigned last, B bit_val)
A convenience function to replace bits first to last of val with bit_val in place.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Jun 22 2021 15:28:28 for gem5 by doxygen 1.8.17