Go to the documentation of this file.
41 #ifndef __MEM_FLASH_MEM_HH__
42 #define __MEM_FLASH_MEM_HH__
45 #include "params/CfiMemory.hh"
187 void setup(ssize_t buffer_size);
200 bool write(
Addr flash_address,
void *data_ptr, ssize_t
size);
355 void init()
override;
std::unique_ptr< Packet > pendingDelete
Upstream caches need this packet until true is returned, so hold it for deletion until a subsequent c...
bool isBusy
Track the state of the memory as either idle or busy, no need for an enum with only two states.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
DrainState drain() override
Draining is the process of clearing out the states of SimObjects.These are the SimObjects that are pa...
ProgramBuffer programBuffer
CfiCommand readState
Previous command (issued in the previous write cycle)
void write(PacketPtr pkt)
Write request to the CFI Memory.
A deferred packet stores a packet along with its scheduled transmission time.
void read(PacketPtr pkt)
Read request to the CFI Memory.
void dequeue()
Dequeue a packet from our internal packet queue and move it to the port where it will be sent as soon...
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Tick recvAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &_backdoor)
const uint8_t numberOfChips
static const ssize_t MAX_BUFFER_SIZE
bool recvTimingReq(PacketPtr pkt) override
Receive a timing request from the peer.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
EventFunctionWrapper releaseEvent
ProgramBuffer(const CfiMemory &_parent)
uint8_t cfiQueryTable[49]
Tick getLatency() const
Detemine the latency.
Port & getPort(const std::string &if_name, PortID idx=InvalidPortID) override
Get a port with a given name and index.
Word Buffer used by the BUFFERED PROGRAM command to write (program) chunks of words to flash.
Tick recvAtomicBackdoor(PacketPtr pkt, MemBackdoorPtr &_backdoor) override
Receive an atomic request packet from the peer, and optionally provide a backdoor to the data being a...
void recvFunctional(PacketPtr pkt) override
Receive a functional request packet from the peer.
const PortID InvalidPortID
uint64_t cfiQuery(Addr addr)
Return the selected entry in the CFI table.
Metadata about the erase blocks in flash.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
@ BUFFER_SIZE_READ
This is not a real command, but it is used by the internal model only to represent the 2nd write cycl...
const double bandwidth
Bandwidth in ticks per byte.
uint32_t blockIdx(Addr block_address) const
static const uint8_t STATUS_LOCK_ERROR
Basic support for object serialization.
DrainState
Object drain/handover states.
void setup(ssize_t buffer_size)
Start buffering.
ssize_t size() const
Size in bytes of a single erase block.
BlockData(const CfiMemory &_parent, ssize_t number, ssize_t size)
static const uint8_t STATUS_ERASE_ERROR
Possible in the status register.
AddrRangeList getAddrRanges() const override
Get a list of the non-overlapping address ranges the owner is responsible for.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
An abstract memory represents a contiguous block of physical memory, with an associated address range...
uint64_t Tick
Tick count type.
const Tick latency_var
Fudge factor added to the latency.
static const uint8_t STATUS_READY
MemoryPort(const std::string &_name, CfiMemory &_memory)
CfiMemory: This is modelling a flash memory adhering to the Common Flash Interface (CFI):
bool write(Addr flash_address, void *data_ptr, ssize_t size)
Write data into the buffer.
std::list< DeferredPacket > packetQueue
Internal (unbounded) storage to mimic the delay caused by the actual memory access.
@ BUFFERED_PROGRAM_CONFIRM
bool retryReq
Remember if we have to retry an outstanding request that arrived while we were busy.
void cfiAccess(PacketPtr pkt)
Make a read/write access to the CFI Memory.
void erase(PacketPtr pkt)
Erase a single block.
CfiMemory(const CfiMemoryParams &p)
EventFunctionWrapper dequeueEvent
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void serialize(CheckpointOut &cp) const override
Serialize an object.
ssize_t number() const
Number of erase blocks in flash memory.
bool recvTimingReq(PacketPtr pkt)
static const uint8_t STATUS_PROGRAM_LOCK_BIT
uint64_t size() const
Get the memory size.
A ResponsePort is a specialization of a port.
uint64_t readDeviceID(Addr flash_address) const
Helper function to read the device identifier after the read state machine is put in the CfiCommand::...
std::vector< bool > locked
void unlock(Addr block_address)
Unlock the block pointed by the block_address parameter.
Tick recvAtomic(PacketPtr pkt)
void release()
Release the memory after being busy and send a retry if a request was rejected in the meanwhile.
void recvRespRetry() override
Called by the peer if sendTimingResp was called on this protocol (causing recvTimingResp to be called...
Ports are used to interface objects to each other.
Tick recvAtomic(PacketPtr pkt) override
Receive an atomic request packet from the peer.
DeferredPacket(PacketPtr _pkt, Tick _tick)
void serialize(CheckpointOut &cp) const override
Serialize an object.
std::ostream CheckpointOut
bool isLocked(Addr block_address) const
Return true if the block pointed by the block_address parameter is locked.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
std::vector< uint8_t > buffer
const Tick latency
Latency from that a request is accepted until the response is ready to be sent.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void serialize(CheckpointOut &cp) const override
Serialize an object.
void recvFunctional(PacketPtr pkt)
void lock(Addr block_address)
Lock the block pointed by the block_address parameter.
void handleCommand(CfiCommand command)
Service a new command issued to the flash device.
bool retryResp
Remember if we failed to send a response and are awaiting a retry.
Generated on Wed Jul 28 2021 12:10:28 for gem5 by doxygen 1.8.17