Go to the documentation of this file.
41 #include "debug/Checkpoint.hh"
60 i2cAddr(0x00), message(0x00)
64 for (
auto d :
p.devices) {
110 d.second->i2cStart();
167 panic(
"Invalid state on posedge of clock in I2CBus::write.\n");
178 uint8_t msg = pkt->
getRaw<uint8_t>();
183 scl = (msg & 1) ? 1 :
scl;
184 sda = (msg & 2) ? 1 :
sda;
187 scl = (msg & 1) ? 0 :
scl;
188 sda = (msg & 2) ? 0 :
sda;
198 uint8_t msg = pkt->
getRaw<uint8_t>();
206 uint8_t msg = pkt->
getRaw<uint8_t>();
214 uint8_t msg = pkt->
getRaw<uint8_t>();
221 DPRINTF(Checkpoint,
"Serializing I2C bus.\n");
233 DPRINTF(Checkpoint,
"Unserializing I2C bus.\n");
Addr pioAddr
Address that the device listens to.
Tick write(PacketPtr pkt) override
The default i2c bus driver used by the realview pbx board writes to this device one bit at a time.
void setRaw(T v)
Set the value in the data pointer to v without byte swapping.
#define UNSERIALIZE_SCALAR(scalar)
bool isClockSet(PacketPtr pkt) const
Clock set check.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool isStart(PacketPtr pkt) const
i2c start signal check
void updateSignals(PacketPtr pkt)
Update data (sda) and clock (scl) to match any transitions specified by pkt.
void makeAtomicResponse()
bool isEnd(PacketPtr pkt) const
i2c end signal check
static const int SB_CONTROLC
Clear control bits.
int currBit
Order of the bit of the current message that is being sent or received (0 - 7).
#define SERIALIZE_ENUM(scalar)
uint8_t sda
I2C data wire (0, 1)
I2CBus(const I2CBusParams &p)
4KB - see e.g.
T getRaw() const
Get the data in the packet without byte swapping.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
uint64_t Tick
Tick count type.
Tick pioDelay
Delay that the device experinces on an access.
std::map< uint8_t, I2CDevice * > devices
All the slave i2c devices that are connected to this bus.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
#define SERIALIZE_SCALAR(scalar)
uint8_t scl
I2C clock wire (0, 1).
Tick read(PacketPtr pkt) override
Reads will always be to SB_CONTROLS.
std::ostream CheckpointOut
#define UNSERIALIZE_ENUM(scalar)
static const int SB_CONTROLS
Read [and Set] serial control bits: Bit [0] is SCL Bit [1] is SDA.
uint8_t i2cAddr
Key used to access a device in the slave devices map.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint8_t message
8-bit buffer used to send and receive messages bit by bit.
enum I2CState state
State used by I2CBus::write to determine what stage of an i2c transmission it is currently in.
void serialize(CheckpointOut &cp) const override
Serialize an object.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Sep 7 2021 14:53:46 for gem5 by doxygen 1.8.17