summaryrefslogtreecommitdiff
path: root/lib/mpi/mpi-internal.h
diff options
context:
space:
mode:
authorLinus Walleij <linus.walleij@linaro.org>2018-03-05 13:17:02 +0300
committerLinus Walleij <linus.walleij@linaro.org>2018-03-08 00:48:19 +0300
commit2e7a66a8b5ebf1b04a866e5d7c981640f7f62934 (patch)
treea100d4103f0aa011d1e9b8a4706306a2e5107023 /lib/mpi/mpi-internal.h
parent20a0dfeead0512af1d194ebaa8b0abe05323bbdb (diff)
downloadlinux-2e7a66a8b5ebf1b04a866e5d7c981640f7f62934.tar.xz
drm/bridge: sii902x: Retry status read after DDI I2C
The following happens when connection a DVI output driven from the SiI9022 using a DVI-to-VGA adapter plug: i2c i2c-0: sendbytes: NAK bailout. i2c i2c-0: sendbytes: NAK bailout. Then no picture. Apparently the I2C engine inside the SiI9022 is not smart enough to try to fall back to DDC I2C. Or the vendor have not integrated the electronics properly. I don't know which one it is. After this, the I2C bus seems stalled and the first attempt to read the status register fails, and the code returns with negative return value, and the display fails to initialized. Instead, retry status readout five times and continue even if this fails. Tested on the ARM Versatile Express with a DVI-to-VGA connector, it now gives picture. Introduce a helper struct device *dev variable to make the code more readable. Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Liviu Dudau <Liviu.Dudau@arm.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org> Link: https://patchwork.freedesktop.org/patch/msgid/20180305101702.13441-1-linus.walleij@linaro.org
Diffstat (limited to 'lib/mpi/mpi-internal.h')
0 files changed, 0 insertions, 0 deletions