Go to the documentation of this file.
34 #ifndef __DEV_STORAGE_IDE_CTRL_HH__
35 #define __DEV_STORAGE_IDE_CTRL_HH__
41 #include "params/IdeController.hh"
70 ConfigSpaceRegs(
const std::string &
name) :
77 addRegisters({primaryTiming, secondaryTiming, deviceTiming, raz0,
78 udmaControl, raz1, udmaTiming, raz2});
82 TimeRegWithDecodeEnabled = 0x8000
86 Register16 primaryTiming =
87 {
"primary timing", TimeRegWithDecodeEnabled};
88 Register16 secondaryTiming =
89 {
"secondary timing", TimeRegWithDecodeEnabled};
90 Register8 deviceTiming = {
"device timing"};
91 RegisterRaz raz0 = {
"raz0", 3};
92 Register8 udmaControl = {
"udma control"};
93 RegisterRaz raz1 = {
"raz1", 1};
94 Register16 udmaTiming = {
"udma timing"};
119 memset(
static_cast<void *
>(
this), 0,
sizeof(*
this));
186 #endif // __DEV_STORAGE_IDE_CTRL_HH_
Device model for an Intel PIIX4 IDE controller.
void accessBMI(Addr offset, int size, uint8_t *data, bool read)
void serialize(CheckpointOut &cp) const override
Serialize this object to the given output stream.
struct IdeController::Channel::BMIRegs bmiRegs
uint64_t Tick
Tick count type.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
IdeDisk * selected
Currently selected disk.
Channel(std::string newName)
IdeDisk * device0
IDE disks connected to this controller For more details about device0 and device1 see: https://en....
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
#define PCI_DEVICE_SPECIFIC
bool isDiskSelected(IdeDisk *diskPtr)
See if a disk is selected based on its pointer.
void dispatchAccess(PacketPtr pkt, bool read)
void setDmaComplete(IdeDisk *disk)
void accessControl(Addr offset, int size, uint8_t *data, bool read)
EndBitUnion(BMIStatusReg) BitUnion8(BMICommandReg) Bitfield< 3 > rw
void select(bool select_device_1)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Tick writeConfig(PacketPtr pkt) override
Write to the PCI config space data that is stored locally.
void accessCommand(Addr offset, int size, uint8_t *data, bool read)
virtual const std::string name() const
Tick readConfig(PacketPtr pkt) override
Read from the PCI config space data that is stored locally.
BitUnion8(BMIStatusReg) Bitfield< 6 > dmaCap0
Registers used for bus master interface.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
EndBitUnion(BMICommandReg) class ConfigSpaceRegs ConfigSpaceRegs configSpaceRegs
Registers used in device specific PCI configuration.
void unserialize(const std::string &base, CheckpointIn &cp)
std::ostream CheckpointOut
RegisterBank< ByteOrder::little > RegisterBankLE
void serialize(const std::string &base, std::ostream &os) const
PCI device, base implementation is only config space.
void unserialize(CheckpointIn &cp) override
Reconstruct the state of this object from a checkpoint.
IdeController(const Params &p)
Generated on Tue Jun 22 2021 15:28:28 for gem5 by doxygen 1.8.17