aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_i2c.c
diff options
context:
space:
mode:
authorDaniel Kurtz <djkurtz@chromium.org>2012-03-30 07:46:37 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2012-04-12 15:14:06 -0400
commit7a39a9d4767e8d22d60f2c4bf5eece4f4398c274 (patch)
treef76f557e76b5aa0bdfaa5c81b3d8e1176786dfb6 /drivers/gpu/drm/i915/intel_i2c.c
parent26883c31b0799e76edf8f0ea8be48b64e09b2a7d (diff)
drm/i915/intel_i2c: use double-buffered writes
The GMBUS controller GMBUS3 register is double-buffered. Take advantage of this by writing two 4-byte words before the first wait for HW_RDY. This helps keep the GMBUS controller from becoming idle during long writes. In fact, during experiments using the GMBUS interrupts, the HW_RDY interrupt would only trigger for transactions >4 bytes after 2 writes to GMBUS3. Signed-off-by: Daniel Kurtz <djkurtz@chromium.org> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_i2c.c')
-rw-r--r--drivers/gpu/drm/i915/intel_i2c.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/drivers/gpu/drm/i915/intel_i2c.c b/drivers/gpu/drm/i915/intel_i2c.c
index 99a04f8bcb1f..f02e52aca746 100644
--- a/drivers/gpu/drm/i915/intel_i2c.c
+++ b/drivers/gpu/drm/i915/intel_i2c.c
@@ -262,13 +262,6 @@ gmbus_xfer_write(struct drm_i915_private *dev_priv, struct i2c_msg *msg,
262 GMBUS_SLAVE_WRITE | GMBUS_SW_RDY); 262 GMBUS_SLAVE_WRITE | GMBUS_SW_RDY);
263 POSTING_READ(GMBUS2 + reg_offset); 263 POSTING_READ(GMBUS2 + reg_offset);
264 while (len) { 264 while (len) {
265 if (wait_for(I915_READ(GMBUS2 + reg_offset) &
266 (GMBUS_SATOER | GMBUS_HW_RDY),
267 50))
268 return -ETIMEDOUT;
269 if (I915_READ(GMBUS2 + reg_offset) & GMBUS_SATOER)
270 return -ENXIO;
271
272 val = loop = 0; 265 val = loop = 0;
273 do { 266 do {
274 val |= *buf++ << (8 * loop); 267 val |= *buf++ << (8 * loop);
@@ -276,6 +269,13 @@ gmbus_xfer_write(struct drm_i915_private *dev_priv, struct i2c_msg *msg,
276 269
277 I915_WRITE(GMBUS3 + reg_offset, val); 270 I915_WRITE(GMBUS3 + reg_offset, val);
278 POSTING_READ(GMBUS2 + reg_offset); 271 POSTING_READ(GMBUS2 + reg_offset);
272
273 if (wait_for(I915_READ(GMBUS2 + reg_offset) &
274 (GMBUS_SATOER | GMBUS_HW_RDY),
275 50))
276 return -ETIMEDOUT;
277 if (I915_READ(GMBUS2 + reg_offset) & GMBUS_SATOER)
278 return -ENXIO;
279 } 279 }
280 return 0; 280 return 0;
281} 281}