diff options
author | Ben Skeggs <bskeggs@redhat.com> | 2010-02-09 10:08:34 +1000 |
---|---|---|
committer | Ben Skeggs <bskeggs@redhat.com> | 2010-02-09 12:50:43 +1000 |
commit | 1ee7698fc3ec3d7949fa55e5154c8f5de8f1c3d9 (patch) | |
tree | a75f98cc8ec56ae9ed0f238622a699f65059cf3e /drivers | |
parent | e235c1f3e132a243a1f81b3d95c99ee199b4d3f3 (diff) | |
download | op-kernel-dev-1ee7698fc3ec3d7949fa55e5154c8f5de8f1c3d9.zip op-kernel-dev-1ee7698fc3ec3d7949fa55e5154c8f5de8f1c3d9.tar.gz |
drm/nouveau: make dp auxch xfer len check for reads only
Writes don't return a count, and adding the check broke native DP.
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_dp.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_dp.c b/drivers/gpu/drm/nouveau/nouveau_dp.c index dd49372..f954ad9 100644 --- a/drivers/gpu/drm/nouveau/nouveau_dp.c +++ b/drivers/gpu/drm/nouveau/nouveau_dp.c @@ -502,12 +502,12 @@ nouveau_dp_auxch(struct nouveau_i2c_chan *auxch, int cmd, int addr, break; } - if ((stat & NV50_AUXCH_STAT_COUNT) != data_nr) { - ret = -EREMOTEIO; - goto out; - } - if (cmd & 1) { + if ((stat & NV50_AUXCH_STAT_COUNT) != data_nr) { + ret = -EREMOTEIO; + goto out; + } + for (i = 0; i < 4; i++) { data32[i] = nv_rd32(dev, NV50_AUXCH_DATA_IN(index, i)); NV_DEBUG_KMS(dev, "rd %d: 0x%08x\n", i, data32[i]); |