On Fri, Apr 01, 2022 at 08:29:03AM +0200, Klaus Jensen wrote: > On Mar 31 15:32, Corey Minyard wrote: > > On Thu, Mar 31, 2022 at 06:57:33PM +0200, Klaus Jensen wrote: > > > From: Klaus Jensen <k.jen...@samsung.com> > > > > > > Hi all, > > > > > > This RFC series adds I2C "slave mode" support for the Aspeed I2C > > > controller as well as the necessary infrastructure in the i2c core to > > > support this. > > > > I've been wondering when this would happen :). I had put some thought > > into how this would work, but hadn't come up with anything good. > > > > The big disadvantage of this is you are adding an interface that is > > incompatible with the current masters and slaves. So you are using the > > same I2C bus, but slaves written this way cannot talk to existing > > masters, and masters written this way cannot talk to existing slave. > > You could adapt the masters to be able to work either way, and I suppose > > some slaves that could do it could have both an async send and a normal > > send. > > Would it make sense to introduce a QOM Interface to differentiate > between the slave/master types?
Yes, that would be a good idea, as Damien said. You will have a type that is capable of both for both sync and async for the master and the slave, then types that are capable of one sync and async so the code can sort out what can talk to what. > > > But you could not adapt a slave device for the Aspeed to do both. > > Exactly, the Aspeed must be able to defer the ack, so it cannot > implement send(). Even if it buffered up the write, I don't think it > would be correct to Ack the transfer until the host has Acked it. > > > But that said, I don't know of a better way to handle this. > > > > You don't have the ability to nack a byte in what you have currently. > > That's probably something that will be needed. > > True. Didn't consider that. Since the ack is basically defined as the > scheduling of the bh, I guess I have to come up with something where I > can also pass a "return value". > > > > > This is obviously not something useful by itself. How do you plan to > > tie this in to something else that would use it? > > > > This is specifically for implementing an NVMe-MI device which uses MCTP > transactions (in which both requests and replies are master->slave > transfers). I just wanted to get a feel for how you maintaines would > envision this begin done before posting that. The NVMe-MI device will > function exactly like the example i2c echo device (i.e. receive an MCTP > transaction using the normal i2c slave interface, parse the > transaction/request, master the bus and start a new transfer). Ok, so you aren't planning to add some sort of interface that would allow a net connection to hook up as an I2C master. Someone submitted something a while ago for doing an I2C slave that way, but there were some issues and nothing came of it. It's tricky to do because it has to be non-blocking. IIRC, there was also some work that allowed two emulations to go on at a time in a qemu instance, that could allow a BMC and a main processor to run together. This might be useful in that scenario. My question was really just more curiousity, wondering what else is coming in the future. Thanks, -corey