Go to the documentation of this file.
31 #include "debug/LupioBLK.hh"
34 #include "params/LupioBLK.hh"
37 #define LUPIO_BLK_TYPE 0x2
40 #define LUPIO_BLK_IRQE 0x1
43 #define LUPIO_BLK_BUSY 0x1
44 #define LUPIO_BLK_ERRR 0x4
48 #define SECTOR_SIZE (1ULL << SECTOR_BITS)
55 platform(params.platform),
57 pioAddr(params.pio_addr),
58 pioSize(params.pio_size),
60 lupioBLKIntID(params.int_id)
63 " match LupIO device\n");
64 nbBlocks = image.size();
73 int64_t _offset =
lba;
126 panic(
"Unexpected read to the LupioBLK device at address"
136 uint32_t
val = val64;
159 panic(
"Attempting to write to LupioBLK device while transfer"
165 panic(
"Unexpected write to the LupioBLK device at address"
176 panic(
"Bad LBA range\n");
185 int64_t _offset =
lba;
212 "Read request - addr: %#x, size: %#x\n",
addr, pkt->
getSize());
uint64_t getUintX(ByteOrder endian) const
Get the data in the packet byte swapped from the specified endianness and zero-extended to 64 bits.
Tick write(PacketPtr pkt) override
Pure virtual function that the device must implement.
AddrRange RangeSize(Addr start, Addr size)
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
const ByteOrder byteOrder
void dmaRead(Addr addr, int size, Event *event, uint8_t *data, uint32_t sid, uint32_t ssid, Tick delay=0)
virtual std::streampos write(const uint8_t *data, std::streampos offset)=0
static constexpr bool isPowerOf2(const T &n)
EventFunctionWrapper dmaEvent
AddrRangeList getAddrRanges() const override
Implement BasicPioDevice virtual functions.
void lupioBLKWrite(const uint8_t addr, uint64_t val64)
Function to write to registers containing data pertaining to block transfers.
LupioBLK: A virtual block device which aims to provide a disk-like interface for second-level storage...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
uint64_t lupioBLKRead(const uint8_t addr)
Function to return data pertaining to blocks being transferred.
void dmaWrite(Addr addr, int size, Event *event, uint8_t *data, uint32_t sid, uint32_t ssid, Tick delay=0)
Tick read(PacketPtr pkt) override
Pure virtual function that the device must implement.
void lupioBLKCmd(void)
Function to initiate and direct the transfer of data by the DMA device.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
const std::string & name()
static constexpr int ceilLog2(const T &n)
void makeResponse()
Take a request packet and modify it in place to be suitable for returning as a response to that reque...
virtual std::streampos read(uint8_t *data, std::streampos offset) const =0
LupioBLK(const Params ¶ms)
#define gem5_assert(cond,...)
The assert macro will function like a normal assert, but will use panic instead of straight abort().
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void setUintX(uint64_t w, ByteOrder endian)
Set the value in the word w after truncating it to the length of the packet and then byteswapping it ...
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed May 4 2022 12:13:56 for gem5 by doxygen 1.8.17