Go to the documentation of this file.
38 #ifndef __DEV_PCI_HOST_HH__
39 #define __DEV_PCI_HOST_HH__
48 struct GenericPciHostParams;
112 const std::string
name()
const;
333 #endif // __DEV_PCI_HOST_HH__
virtual ~GenericPciHost()
void postInt(const PciBusAddr &addr, PciIntPin pin) override
Post an interrupt to the CPU.
void clearInt(const PciBusAddr &addr, PciIntPin pin) override
Post an interrupt to the CPU.
virtual Addr pioAddr(const PciBusAddr &bus_addr, Addr pci_addr) const =0
Calculate the physical address of an IO location on the PCI bus.
virtual std::pair< PciBusAddr, Addr > decodeAddress(Addr address)
Decode a configuration space address.
This device is the base class which all devices senstive to an address range inherit from.
Addr dmaAddr(Addr addr) const
Calculate the physical address of a prefetchable memory location in the PCI address space.
PciHost(const PciHostParams &p)
Addr memAddr(Addr addr) const
Calculate the physical address of a non-prefetchable memory location in the PCI address space.
void operator=(const DeviceInterface &)=delete
virtual Addr memAddr(const PciBusAddr &bus_addr, Addr pci_addr) const =0
Calculate the physical address of a non-prefetchable memory location in the PCI address space.
const uint8_t confDeviceBits
GenericPciHost(const GenericPciHostParams &p)
virtual void clearInt(const PciBusAddr &bus_addr, PciIntPin pin)=0
Post an interrupt to the CPU.
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
virtual void postInt(const PciBusAddr &bus_addr, PciIntPin pin)=0
Post an interrupt to the CPU.
virtual Addr dmaAddr(const PciBusAddr &bus_addr, Addr pci_addr) const =0
Calculate the physical address of a prefetchable memory location in the PCI address space.
The PCI host describes the interface between PCI devices and a simulated system.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
Addr pioAddr(Addr addr) const
Calculate the physical address of an IO location on the PCI bus.
Configurable generic PCI host interface.
Addr memAddr(const PciBusAddr &bus_addr, Addr pci_addr) const override
Calculate the physical address of a non-prefetchable memory location in the PCI address space.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void clearInt()
Clear a posted PCI interrupt.
uint64_t Tick
Tick count type.
Addr pioAddr(const PciBusAddr &bus_addr, Addr pci_addr) const override
Calculate the physical address of an IO location on the PCI bus.
Callback interface from PCI devices to the host.
PCI device, base implementation is only config space.
void postInt()
Post a PCI interrupt to the CPU.
const std::string name() const
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Addr dmaAddr(const PciBusAddr &bus_addr, Addr pci_addr) const override
Calculate the physical address of a prefetchable memory location in the PCI address space.
AddrRangeList getAddrRanges() const override
Every PIO device is obliged to provide an implementation that returns the address ranges the device r...
virtual DeviceInterface registerDevice(PciDevice *device, PciBusAddr bus_addr, PciIntPin pin)
Register a PCI device with the host.
std::map< PciBusAddr, PciDevice * > devices
Currently registered PCI devices.
PciDevice * getDevice(const PciBusAddr &addr)
Retrieve a PCI device from its bus address.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const PciIntPin interruptPin
virtual uint32_t mapPciInterrupt(const PciBusAddr &bus_addr, PciIntPin pin) const
Generated on Wed May 4 2022 12:13:57 for gem5 by doxygen 1.8.17