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"
73 ConfigSpaceRegs(
const std::string &
name) :
80 addRegisters({primaryTiming, secondaryTiming, deviceTiming, raz0,
81 udmaControl, raz1, udmaTiming, raz2});
86 TimeRegWithDecodeEnabled = 0x8000
90 Register16 primaryTiming =
91 {
"primary timing", TimeRegWithDecodeEnabled};
92 Register16 secondaryTiming =
93 {
"secondary timing", TimeRegWithDecodeEnabled};
94 Register8 deviceTiming = {
"device timing"};
95 RegisterRaz raz0 = {
"raz0", 3};
96 Register8 udmaControl = {
"udma control"};
97 RegisterRaz raz1 = {
"raz1", 1};
98 Register16 udmaTiming = {
"udma timing"};
123 memset(
static_cast<void *
>(
this), 0,
sizeof(*
this));
193 #endif // __DEV_STORAGE_IDE_CTRL_HH_
RegisterBank< ByteOrder::little > RegisterBankLE
void serialize(const std::string &base, std::ostream &os) const
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
void select(bool select_device_1)
#define PCI_DEVICE_SPECIFIC
IdeDisk * device0
IDE disks connected to this controller For more details about device0 and device1 see: https://en....
Registers used for bus master interface.
virtual std::string name() const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
IdeController(const Params &p)
void accessCommand(Addr offset, int size, uint8_t *data, bool read)
void dispatchAccess(PacketPtr pkt, bool read)
PCI device, base implementation is only config space.
void accessControl(Addr offset, int size, uint8_t *data, bool read)
Device model for an Intel PIIX4 IDE controller.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Tick readConfig(PacketPtr pkt) override
Read from the PCI config space data that is stored locally.
BitUnion8(BMIStatusReg) Bitfield< 6 > dmaCap0
void serialize(CheckpointOut &cp) const override
Serialize this object to the given output stream.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
void setDmaComplete(IdeDisk *disk)
void unserialize(const std::string &base, CheckpointIn &cp)
bool isDiskSelected(IdeDisk *diskPtr)
See if a disk is selected based on its pointer.
IdeDisk * selected
Currently selected disk.
struct gem5::IdeController::Channel::BMIRegs bmiRegs
EndBitUnion(BMICommandReg) class ConfigSpaceRegs ConfigSpaceRegs configSpaceRegs
Registers used in device specific PCI configuration.
void unserialize(CheckpointIn &cp) override
Reconstruct the state of this object from a checkpoint.
void accessBMI(Addr offset, int size, uint8_t *data, bool read)
std::ostream CheckpointOut
Tick writeConfig(PacketPtr pkt) override
Write to the PCI config space data that is stored locally.
Channel(std::string newName)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
EndBitUnion(BMIStatusReg) BitUnion8(BMICommandReg) Bitfield< 3 > rw
Generated on Tue Dec 21 2021 11:34:30 for gem5 by doxygen 1.8.17