40 #include "debug/Checkpoint.hh" 54 :
BasicPioDevice(p, 0x1000), scl(1), sda(1), state(IDLE), currBit(7),
55 i2cAddr(0x00), message(0x00)
59 for (
auto d : p->devices) {
105 d.second->i2cStart();
162 panic(
"Invalid state on posedge of clock in I2CBus::write.\n");
173 uint8_t msg = pkt->
getRaw<uint8_t>();
178 scl = (msg & 1) ? 1 :
scl;
179 sda = (msg & 2) ? 1 :
sda;
182 scl = (msg & 1) ? 0 :
scl;
183 sda = (msg & 2) ? 0 :
sda;
193 uint8_t msg = pkt->
getRaw<uint8_t>();
201 uint8_t msg = pkt->
getRaw<uint8_t>();
209 uint8_t msg = pkt->
getRaw<uint8_t>();
216 DPRINTF(Checkpoint,
"Serializing I2C bus.\n");
228 DPRINTF(Checkpoint,
"Unserializing I2C bus.\n");
238 I2CBusParams::create()
#define panic(...)
This implements a cprintf based panic() function.
bool isStart(PacketPtr pkt) const
i2c start signal check
std::map< uint8_t, I2CDevice * > devices
All the slave i2c devices that are connected to this bus.
enum I2CState state
State used by I2CBus::write to determine what stage of an i2c transmission it is currently in...
uint8_t i2cAddr
Key used to access a device in the slave devices map.
void setRaw(T v)
Set the value in the data pointer to v without byte swapping.
static const int SB_CONTROLS
Read [and Set] serial control bits: Bit [0] is SCL Bit [1] is SDA.
uint8_t message
8-bit buffer used to send and receive messages bit by bit.
#define UNSERIALIZE_SCALAR(scalar)
All i2c devices should derive from this class.
#define SERIALIZE_ENUM(scalar)
void makeAtomicResponse()
uint64_t Tick
Tick count type.
I2CBus(const I2CBusParams *p)
4KB - see e.g.
void updateSignals(PacketPtr pkt)
Update data (sda) and clock (scl) to match any transitions specified by pkt.
Tick read(PacketPtr pkt) override
Reads will always be to SB_CONTROLS.
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 unserialize(CheckpointIn &cp) override
Unserialize an object.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
int currBit
Order of the bit of the current message that is being sent or received (0 - 7).
#define SERIALIZE_SCALAR(scalar)
std::ostream CheckpointOut
static const int SB_CONTROLC
Clear control bits.
T getRaw() const
Get the data in the packet without byte swapping.
bool isEnd(PacketPtr pkt) const
i2c end signal check
#define UNSERIALIZE_ENUM(scalar)
void serialize(CheckpointOut &cp) const override
Serialize an object.
Tick pioDelay
Delay that the device experinces on an access.
uint8_t scl
I2C clock wire (0, 1).
Addr pioAddr
Address that the device listens to.
uint8_t sda
I2C data wire (0, 1)
Implementiation of an i2c bus.
bool isClockSet(PacketPtr pkt) const
Clock set check.