All of lore.kernel.org
 help / color / mirror / Atom feed
From: Frederic Konrad <fred.konrad@greensocs.com>
To: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
Cc: Peter Maydell <peter.maydell@linaro.org>,
	Mark Burton <mark.burton@greensocs.com>,
	"qemu-devel@nongnu.org Developers" <qemu-devel@nongnu.org>,
	hyunk@xilinx.com, guillaume.delbergue@greensocs.com
Subject: Re: [Qemu-devel] [PATCH V2 2/7] i2c: implement broadcast write.
Date: Mon, 06 Jul 2015 18:28:51 +0200	[thread overview]
Message-ID: <559AACC3.1090009@greensocs.com> (raw)
In-Reply-To: <CAEgOgz79FOMH2Yb4h2Rr_ZqTf0hCbnO=qovE7wX8GQfV5Bbz-A@mail.gmail.com>

On 24/06/2015 08:35, Peter Crosthwaite wrote:
> On Mon, Jun 15, 2015 at 8:15 AM,  <fred.konrad@greensocs.com> wrote:
>> From: KONRAD Frederic <fred.konrad@greensocs.com>
>>
>> This does a write to every slaves when the I2C bus get a write to address 0.
>>
>> Signed-off-by: KONRAD Frederic <fred.konrad@greensocs.com>
>> ---
>>   hw/i2c/core.c | 46 +++++++++++++++++++++++++++++++++++++++++++++-
>>   1 file changed, 45 insertions(+), 1 deletion(-)
>>
>> diff --git a/hw/i2c/core.c b/hw/i2c/core.c
>> index 5a64026..db1cbdd 100644
>> --- a/hw/i2c/core.c
>> +++ b/hw/i2c/core.c
>> @@ -15,6 +15,7 @@ struct I2CBus
>>       I2CSlave *current_dev;
>>       I2CSlave *dev;
>>       uint8_t saved_address;
>> +    bool broadcast;
>>   };
>>
>>   static Property i2c_props[] = {
>> @@ -67,6 +68,8 @@ I2CBus *i2c_init_bus(DeviceState *parent, const char *name)
>>
>>       bus = I2C_BUS(qbus_create(TYPE_I2C_BUS, parent, name));
>>       vmstate_register(NULL, -1, &vmstate_i2c_bus, bus);
>> +
>> +    bus->broadcast = false;
> 0 initialiser should not be needed for new QOM object.
>
>>       return bus;
>>   }
>>
>> @@ -89,6 +92,21 @@ int i2c_start_transfer(I2CBus *bus, uint8_t address, int recv)
>>       I2CSlave *slave = NULL;
>>       I2CSlaveClass *sc;
>>
>> +    if (address == 0x00) {
>> +        /*
>> +         * This is a broadcast.
>> +         */
> One line comment.
>
>> +        QTAILQ_FOREACH(kid, &bus->qbus.children, sibling) {
>> +            I2CSlave *dev = I2C_SLAVE(kid->child);
>> +            sc = I2C_SLAVE_GET_CLASS(dev);
>> +            bus->broadcast = true;
> Move outside loop.
>
>> +            if (sc->event) {
>> +                sc->event(dev, recv ? I2C_START_RECV : I2C_START_SEND);
>> +            }
>> +        }
>> +        return 0;
>> +    }
>> +
>>       QTAILQ_FOREACH(kid, &bus->qbus.children, sibling) {
>>           DeviceState *qdev = kid->child;
>>           I2CSlave *candidate = I2C_SLAVE(qdev);
>> @@ -114,9 +132,21 @@ int i2c_start_transfer(I2CBus *bus, uint8_t address, int recv)
>>
>>   void i2c_end_transfer(I2CBus *bus)
>>   {
>> +    BusChild *kid;
>>       I2CSlave *dev = bus->current_dev;
>>       I2CSlaveClass *sc;
>>
>> +    if (bus->broadcast) {
>> +        QTAILQ_FOREACH(kid, &bus->qbus.children, sibling) {
>> +            I2CSlave *dev = I2C_SLAVE(kid->child);
>> +            sc = I2C_SLAVE_GET_CLASS(dev);
>> +            if (sc->event) {
>> +                sc->event(dev, I2C_FINISH);
>> +            }
>> +        }
>> +        bus->broadcast = false;
>> +    }
>> +
>>       if (!dev) {
>>           return;
>>       }
>> @@ -131,8 +161,22 @@ void i2c_end_transfer(I2CBus *bus)
>>
>>   int i2c_send(I2CBus *bus, uint8_t data)
>>   {
>> +    BusChild *kid;
>>       I2CSlave *dev = bus->current_dev;
>>       I2CSlaveClass *sc;
>> +    int ret = 0;
>> +
>> +    if (bus->broadcast) {
>> +        QTAILQ_FOREACH(kid, &bus->qbus.children, sibling) {
>> +            I2CSlave *dev = I2C_SLAVE(kid->child);
>> +            sc = I2C_SLAVE_GET_CLASS(dev);
>> +            bus->broadcast = true;
>> +            if (sc->send) {
>> +                ret |= sc->send(dev, data);
>> +            }
>> +        }
> Still not sure about the duped core functionality of each of these
> APIs. That is, the same code is needed in both a looped form and a 1
> form. Can this be solved by listifying current_dev? That is, ->current
> dev is turned into a list which in the normal case will be populated
> with 1 element by start_transfer() for the current dev. In the
> broadcast case, all qbus.children are added to the list. The broadcast
> bool is then removed. start() send() and end_transfer() then just loop
> through the list unconditionally.

I think better keeping this broadcast as we need it for VMSD anyway?

> Regards,
> Peter
>
>> +        return ret;
>> +    }
>>
>>       if (!dev) {
>>           return -1;
>> @@ -151,7 +195,7 @@ int i2c_recv(I2CBus *bus)
>>       I2CSlave *dev = bus->current_dev;
>>       I2CSlaveClass *sc;
>>
>> -    if (!dev) {
>> +    if ((!dev) || (bus->broadcast)) {
>>           return -1;
>>       }
>>
>> --
>> 1.9.0
>>
>>

  reply	other threads:[~2015-07-06 16:29 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-06-15 15:15 [Qemu-devel] [PATCH V2 0/7] Xilinx DisplayPort fred.konrad
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 1/7] Introduce AUX bus fred.konrad
2015-06-24  6:21   ` Peter Crosthwaite
2015-07-06 16:27     ` Frederic Konrad
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 2/7] i2c: implement broadcast write fred.konrad
2015-06-24  6:35   ` Peter Crosthwaite
2015-07-06 16:28     ` Frederic Konrad [this message]
2015-07-06 16:54       ` Peter Crosthwaite
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 3/7] introduce dpcd module fred.konrad
2015-06-24  6:44   ` Peter Crosthwaite
2015-07-06 16:30     ` Frederic Konrad
2015-07-06 16:57       ` Peter Crosthwaite
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 4/7] hw/i2c-ddc.c: Implement DDC I2C slave fred.konrad
2015-06-24  7:03   ` Peter Crosthwaite
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 5/7] Introduce xilinx dpdma fred.konrad
2015-06-24  7:41   ` Peter Crosthwaite
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 6/7] Introduce xilinx dp fred.konrad
2015-06-24  8:21   ` Peter Crosthwaite
2015-06-15 15:15 ` [Qemu-devel] [PATCH V2 7/7] arm: xlnx-zynqmp: Add DisplayPort and DPDMA fred.konrad
2015-06-24  8:23   ` Peter Crosthwaite

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=559AACC3.1090009@greensocs.com \
    --to=fred.konrad@greensocs.com \
    --cc=guillaume.delbergue@greensocs.com \
    --cc=hyunk@xilinx.com \
    --cc=mark.burton@greensocs.com \
    --cc=peter.crosthwaite@xilinx.com \
    --cc=peter.maydell@linaro.org \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.