summaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2017-08-14 22:17:26 +0200
committerWolfram Sang <wsa@the-dreams.de>2017-08-17 21:53:03 +0200
commited1094012ae82798de33bad0ba1cc5f19a005e68 (patch)
tree07b614eb567bb550cbc6a7f3b75c77418adc3244 /kernel
parenti2c-cht-wc: Ack read irqs after reading the data register (diff)
downloadlinux-ed1094012ae82798de33bad0ba1cc5f19a005e68.tar.xz
linux-ed1094012ae82798de33bad0ba1cc5f19a005e68.zip
i2c-cht-wc: Workaround CHT GPIO controller IRQ issues
The Cherry Trail Whiskey Cove PMIC's IRQ line is attached to one of the GPIOs of the Cherry Trail SoC. The CHT GPIO controller sometimes fails to deliver IRQs (seen when there is an IRQ storm on another pin). This commit works around this by reducing the long timeout which was a poor attempt to workaround this from 3s to 30ms and after that manually checking the status register for transfer completion by calling the threaded IRQ handler directly. This is safe todo as the entire threaded IRQ handler is protected by a mutex. Note 30ms should be more then long enough, at 100KHz any smbus single byte transaction should be finished in 4ms. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
Diffstat (limited to 'kernel')
0 files changed, 0 insertions, 0 deletions