Re: [PATCH 1/1] regmap-irq: Introduce inverted status registers support

From: Maxim Kochetkov
Date: Mon May 24 2021 - 01:04:31 EST


18.05.2021 15:06, Mark Brown wrote:
On Tue, May 18, 2021 at 12:44:41PM +0300, Maxim Kochetkov wrote:

+ if (chip->status_invert)
+ for (i = 0; i < data->chip->num_regs; i++)
+ data->status_buf[i] = ~data->status_buf[i];
+

This is the only active change so this only affects readback meaning
that if both read and write are inverted this won't do what's expected,
breaking acks.

I mean 'status_invert' as just status register has inverted bits. So to keep all other logic we just need to invert status register after read. It will not break acks because we can use ack_invert option to invert status back if needed. Anyway it will not affect existing devices just new ones with inverted status.

I'm guessing your device either mixes things or is clear on read?

Yes my device is clear on read. It don`t use ack registers. It has only mask and status.


I missed read status register at regmap_add_irq_chip_fwnode(). I will send v2.