pw_i2c_mcuxpresso#
NXP MCUXpresso SDK implementation for pw_i2c
Stable C++17
pw_i2c_mcuxpresso
implements the pw_i2c
interface using the
NXP MCUXpresso SDK.
The implementation is based on the i2c driver in SDK. I2C transfers use non-blocking driver API.
I3cMcuxpressoInitiator
implements the pw_i2c
initiator interface using
the MCUXpresso I3C driver. It exposes a few I3C specific API’s for setting up
the bus, allowing normal I2C API’s to work after setup.
Setup#
This module requires following setup:
Use
pw_build_mcuxpresso
to create apw_source_set
for an MCUXpresso SDK.Include the i2c driver component in this SDK definition.
Specify the
pw_third_party_mcuxpresso_SDK
GN global variable to specify the name of this source set.Use
pw::i2c::McuxpressoInitiator
implementation ofpw::i2c::Initiator
while creatingpw::i2c::Device
orpw::i2c::RegisterDevice
interface to access the I2C devices connected to target.
Usage#
constexpr uint32_t kI2CBaudRate = 100000;
constexpr McuxpressoInitiator::Config kConfig = {
.flexcomm_address = I2C11_BASE,
.clock_name = kCLOCK_Flexcomm11Clk,
.baud_rate_bps = kI2CBaudRate,
};
McuxpressoInitiator initiator{kConfig};
initiator.Enable();
I3cMcuxpressoInitiator
example usage.
constexpr I3cMcuxpressoInitiator::Config kI3c0Config = {
.base_address = I3C0_BASE,
.i2c_baud_rate = kI3cI2cBaudRate,
.i3c_open_drain_baud_rate = kI3cOpenDrainBaudRate,
.i3c_push_pull_baud_rate = kI3cPushPullBaudRate,
.enable_open_drain_stop = false, // NXP default
.enable_open_drain_high = true, // necessary to allow bus to operate in
// mixed mode
};
I3cMcuxpressoInitiator i3c_0_initiator{kI3c0Config};
// Initialize the i3c core library. After this is called, the
// initiator can be used for regular i2c communication.
i3c_0_initiator.Enable();
// Perform an i3c bus initialization by assigning the following targets
// their i2c static address as their i3c dynamic address.
constexpr std::array<pw::i2c::Address, 2> kI3cTargets = {
pw::i2c::Address::SevenBit<0x23>(),
pw::i2c::Address::SevenBit<0x38>(),
};
i3c_initiator.SetStaticAddressList(kI3cTargets);
PW_TRY(i3c_initiator.Initialize());
I3cMcuxpressoInitiator
example of a individual static i3c devices
that comes on and offline to save power.
constexpr I3cMcuxpressoInitiator::Config kI3c0Config = {
.base_address = I3C0_BASE,
.i2c_baud_rate = kI3cI2cBaudRate,
.i3c_open_drain_baud_rate = kI3cOpenDrainBaudRate,
.i3c_push_pull_baud_rate = kI3cPushPullBaudRate,
.enable_open_drain_stop = false, // NXP default
.enable_open_drain_high = true, // necessary to allow bus to operate in
// mixed mode
};
I3cMcuxpressoInitiator i3c_0_initiator{kI3c0Config};
// Initialize the i3c core library. After this is called, the
// initiator can be used for regular i2c communication.
i3c_0_initiator.Enable();
constexpr auto address = pw::i2c:Address::SevenBit<0x58>();
// Assign a fixed i3c address from the static i2c address.
i3c_0_initiator.SetDasa(address);
// i3c read write activity against address
// Power off device.
// Tell the initiator that the address is no longer assigned.
i3c_0_initiator.ForgetAssignedAddress(address);
// Optionally disable the initiator to bring the SDA/SCL lines low.
// i3c_0_initiator.Disable();