]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
i2c: rcar: handle RXDMA HW behaviour on Gen3
authorWolfram Sang <wsa+renesas@sang-engineering.com>
Thu, 28 Jun 2018 20:45:38 +0000 (22:45 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 3 Aug 2018 05:48:03 +0000 (07:48 +0200)
commitae7b02e0806594bc050c5de35b60c03aff0e2d4e
treea92b0012895413196d4bafc95382313b24a1e367
parenteabee58e7f2b800142ba0278c91f2ab3849a8a6b
i2c: rcar: handle RXDMA HW behaviour on Gen3

commit 2b16fd63059ab9a46d473620749672dc342e1d21 upstream.

On Gen3, we can only do RXDMA once per transfer reliably. For that, we
must reset the device, then we can have RXDMA once. This patch
implements this. When there is no reset controller or the reset fails,
RXDMA will be blocked completely. Otherwise, it will be disabled after
the first RXDMA transfer. Based on a commit from the BSP by Hiromitsu
Yamasaki, yet completely refactored to handle multiple read messages
within one transfer.

Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
Cc: stable@kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/i2c/busses/i2c-rcar.c