diff options
author | Alex Deucher <alexander.deucher@amd.com> | 2011-10-03 09:13:45 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2011-10-03 13:37:30 -0400 |
commit | 109bc10d30f33e84f1d7289f0039e0c858ade82f (patch) | |
tree | a7f787307d22b00ccf1a05c8b1ba1da77976c484 | |
parent | 9b13776977d45505469edc6decc93e9e3799afe2 (diff) |
drm/radeon/kms: fix regression in DP aux defer handling
An incorrect ordering in the error checking code lead
to DP aux defer being skipped in the aux native write
path. Move the bytes transferred check (ret == 0)
below the defer check.
Tracked down by: Brad Campbell <brad@fnarfbargle.com>
Fixes:
https://bugs.freedesktop.org/show_bug.cgi?id=41121
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Cc: Brad Campbell <brad@fnarfbargle.com>
Cc: stable@kernel.org
Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r-- | drivers/gpu/drm/radeon/atombios_dp.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/atombios_dp.c b/drivers/gpu/drm/radeon/atombios_dp.c index 7ad43c6b1db7..f526fa77e320 100644 --- a/drivers/gpu/drm/radeon/atombios_dp.c +++ b/drivers/gpu/drm/radeon/atombios_dp.c | |||
@@ -158,14 +158,14 @@ static int radeon_dp_aux_native_read(struct radeon_connector *radeon_connector, | |||
158 | while (1) { | 158 | while (1) { |
159 | ret = radeon_process_aux_ch(dig_connector->dp_i2c_bus, | 159 | ret = radeon_process_aux_ch(dig_connector->dp_i2c_bus, |
160 | msg, msg_bytes, recv, recv_bytes, delay, &ack); | 160 | msg, msg_bytes, recv, recv_bytes, delay, &ack); |
161 | if (ret == 0) | ||
162 | return -EPROTO; | ||
163 | if (ret < 0) | 161 | if (ret < 0) |
164 | return ret; | 162 | return ret; |
165 | if ((ack & AUX_NATIVE_REPLY_MASK) == AUX_NATIVE_REPLY_ACK) | 163 | if ((ack & AUX_NATIVE_REPLY_MASK) == AUX_NATIVE_REPLY_ACK) |
166 | return ret; | 164 | return ret; |
167 | else if ((ack & AUX_NATIVE_REPLY_MASK) == AUX_NATIVE_REPLY_DEFER) | 165 | else if ((ack & AUX_NATIVE_REPLY_MASK) == AUX_NATIVE_REPLY_DEFER) |
168 | udelay(400); | 166 | udelay(400); |
167 | else if (ret == 0) | ||
168 | return -EPROTO; | ||
169 | else | 169 | else |
170 | return -EIO; | 170 | return -EIO; |
171 | } | 171 | } |