diff options
Diffstat (limited to 'drivers/gpu')
-rw-r--r-- | drivers/gpu/drm/i915/i915_reg.h | 35 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_ringbuffer.c | 25 |
2 files changed, 21 insertions, 39 deletions
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 605db647e920..ddbcd8c109e0 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h | |||
@@ -253,11 +253,13 @@ | |||
253 | #define RENDER_RING_BASE 0x02000 | 253 | #define RENDER_RING_BASE 0x02000 |
254 | #define BSD_RING_BASE 0x04000 | 254 | #define BSD_RING_BASE 0x04000 |
255 | #define GEN6_BSD_RING_BASE 0x12000 | 255 | #define GEN6_BSD_RING_BASE 0x12000 |
256 | #define RING_TAIL(base) (base)+0x30 | 256 | #define RING_TAIL(base) ((base)+0x30) |
257 | #define RING_HEAD(base) (base)+0x34 | 257 | #define RING_HEAD(base) ((base)+0x34) |
258 | #define RING_START(base) (base)+0x38 | 258 | #define RING_START(base) ((base)+0x38) |
259 | #define RING_CTL(base) (base)+0x3c | 259 | #define RING_CTL(base) ((base)+0x3c) |
260 | #define RING_HWS_PGA(base) (base)+0x80 | 260 | #define RING_HWS_PGA(base) ((base)+0x80) |
261 | #define RING_HWS_PGA_GEN6(base) ((base)+0x2080) | ||
262 | #define RING_ACTHD(base) ((base)+0x74) | ||
261 | #define TAIL_ADDR 0x001FFFF8 | 263 | #define TAIL_ADDR 0x001FFFF8 |
262 | #define HEAD_WRAP_COUNT 0xFFE00000 | 264 | #define HEAD_WRAP_COUNT 0xFFE00000 |
263 | #define HEAD_WRAP_ONE 0x00200000 | 265 | #define HEAD_WRAP_ONE 0x00200000 |
@@ -283,7 +285,6 @@ | |||
283 | #define INSTDONE1 0x0207c /* 965+ only */ | 285 | #define INSTDONE1 0x0207c /* 965+ only */ |
284 | #define ACTHD_I965 0x02074 | 286 | #define ACTHD_I965 0x02074 |
285 | #define HWS_PGA 0x02080 | 287 | #define HWS_PGA 0x02080 |
286 | #define HWS_PGA_GEN6 0x04080 | ||
287 | #define HWS_ADDRESS_MASK 0xfffff000 | 288 | #define HWS_ADDRESS_MASK 0xfffff000 |
288 | #define HWS_START_ADDRESS_SHIFT 4 | 289 | #define HWS_START_ADDRESS_SHIFT 4 |
289 | #define PWRCTXA 0x2088 /* 965GM+ only */ | 290 | #define PWRCTXA 0x2088 /* 965GM+ only */ |
@@ -441,28 +442,6 @@ | |||
441 | #define GEN6_BLITTER_COMMAND_PARSER_MASTER_ERROR (1 << 25) | 442 | #define GEN6_BLITTER_COMMAND_PARSER_MASTER_ERROR (1 << 25) |
442 | #define GEN6_BLITTER_SYNC_STATUS (1 << 24) | 443 | #define GEN6_BLITTER_SYNC_STATUS (1 << 24) |
443 | #define GEN6_BLITTER_USER_INTERRUPT (1 << 22) | 444 | #define GEN6_BLITTER_USER_INTERRUPT (1 << 22) |
444 | /* | ||
445 | * BSD (bit stream decoder instruction and interrupt control register defines | ||
446 | * (G4X and Ironlake only) | ||
447 | */ | ||
448 | |||
449 | #define BSD_RING_TAIL 0x04030 | ||
450 | #define BSD_RING_HEAD 0x04034 | ||
451 | #define BSD_RING_START 0x04038 | ||
452 | #define BSD_RING_CTL 0x0403c | ||
453 | #define BSD_RING_ACTHD 0x04074 | ||
454 | #define BSD_HWS_PGA 0x04080 | ||
455 | |||
456 | /* | ||
457 | * video command stream instruction and interrupt control register defines | ||
458 | * for GEN6 | ||
459 | */ | ||
460 | #define GEN6_BSD_RING_TAIL 0x12030 | ||
461 | #define GEN6_BSD_RING_HEAD 0x12034 | ||
462 | #define GEN6_BSD_RING_START 0x12038 | ||
463 | #define GEN6_BSD_RING_CTL 0x1203c | ||
464 | #define GEN6_BSD_RING_ACTHD 0x12074 | ||
465 | #define GEN6_BSD_HWS_PGA 0x14080 | ||
466 | 445 | ||
467 | #define GEN6_BSD_SLEEP_PSMI_CONTROL 0x12050 | 446 | #define GEN6_BSD_SLEEP_PSMI_CONTROL 0x12050 |
468 | #define GEN6_BSD_SLEEP_PSMI_CONTROL_RC_ILDL_MESSAGE_MODIFY_MASK (1 << 16) | 447 | #define GEN6_BSD_SLEEP_PSMI_CONTROL_RC_ILDL_MESSAGE_MODIFY_MASK (1 << 16) |
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c index ede436ba22d2..487575f2340d 100644 --- a/drivers/gpu/drm/i915/intel_ringbuffer.c +++ b/drivers/gpu/drm/i915/intel_ringbuffer.c | |||
@@ -131,7 +131,8 @@ static unsigned int render_ring_get_active_head(struct drm_device *dev, | |||
131 | struct intel_ring_buffer *ring) | 131 | struct intel_ring_buffer *ring) |
132 | { | 132 | { |
133 | drm_i915_private_t *dev_priv = dev->dev_private; | 133 | drm_i915_private_t *dev_priv = dev->dev_private; |
134 | u32 acthd_reg = INTEL_INFO(dev)->gen >= 4 ? ACTHD_I965 : ACTHD; | 134 | u32 acthd_reg = INTEL_INFO(dev)->gen >= 4 ? |
135 | RING_ACTHD(ring->mmio_base) : ACTHD; | ||
135 | 136 | ||
136 | return I915_READ(acthd_reg); | 137 | return I915_READ(acthd_reg); |
137 | } | 138 | } |
@@ -352,11 +353,13 @@ static void render_setup_status_page(struct drm_device *dev, | |||
352 | { | 353 | { |
353 | drm_i915_private_t *dev_priv = dev->dev_private; | 354 | drm_i915_private_t *dev_priv = dev->dev_private; |
354 | if (IS_GEN6(dev)) { | 355 | if (IS_GEN6(dev)) { |
355 | I915_WRITE(HWS_PGA_GEN6, ring->status_page.gfx_addr); | 356 | I915_WRITE(RING_HWS_PGA_GEN6(ring->mmio_base), |
356 | I915_READ(HWS_PGA_GEN6); /* posting read */ | 357 | ring->status_page.gfx_addr); |
358 | I915_READ(RING_HWS_PGA_GEN6(ring->mmio_base)); /* posting read */ | ||
357 | } else { | 359 | } else { |
358 | I915_WRITE(HWS_PGA, ring->status_page.gfx_addr); | 360 | I915_WRITE(RING_HWS_PGA(ring->mmio_base), |
359 | I915_READ(HWS_PGA); /* posting read */ | 361 | ring->status_page.gfx_addr); |
362 | I915_READ(RING_HWS_PGA(ring->mmio_base)); /* posting read */ | ||
360 | } | 363 | } |
361 | 364 | ||
362 | } | 365 | } |
@@ -377,7 +380,7 @@ static unsigned int bsd_ring_get_active_head(struct drm_device *dev, | |||
377 | struct intel_ring_buffer *ring) | 380 | struct intel_ring_buffer *ring) |
378 | { | 381 | { |
379 | drm_i915_private_t *dev_priv = dev->dev_private; | 382 | drm_i915_private_t *dev_priv = dev->dev_private; |
380 | return I915_READ(BSD_RING_ACTHD); | 383 | return I915_READ(RING_ACTHD(ring->mmio_base)); |
381 | } | 384 | } |
382 | 385 | ||
383 | static int init_bsd_ring(struct drm_device *dev, | 386 | static int init_bsd_ring(struct drm_device *dev, |
@@ -412,8 +415,8 @@ static void bsd_setup_status_page(struct drm_device *dev, | |||
412 | struct intel_ring_buffer *ring) | 415 | struct intel_ring_buffer *ring) |
413 | { | 416 | { |
414 | drm_i915_private_t *dev_priv = dev->dev_private; | 417 | drm_i915_private_t *dev_priv = dev->dev_private; |
415 | I915_WRITE(BSD_HWS_PGA, ring->status_page.gfx_addr); | 418 | I915_WRITE(RING_HWS_PGA(ring->mmio_base), ring->status_page.gfx_addr); |
416 | I915_READ(BSD_HWS_PGA); | 419 | I915_READ(RING_HWS_PGA(ring->mmio_base)); |
417 | } | 420 | } |
418 | 421 | ||
419 | static void | 422 | static void |
@@ -801,8 +804,8 @@ static void gen6_bsd_setup_status_page(struct drm_device *dev, | |||
801 | struct intel_ring_buffer *ring) | 804 | struct intel_ring_buffer *ring) |
802 | { | 805 | { |
803 | drm_i915_private_t *dev_priv = dev->dev_private; | 806 | drm_i915_private_t *dev_priv = dev->dev_private; |
804 | I915_WRITE(GEN6_BSD_HWS_PGA, ring->status_page.gfx_addr); | 807 | I915_WRITE(RING_HWS_PGA_GEN6(ring->mmio_base), ring->status_page.gfx_addr); |
805 | I915_READ(GEN6_BSD_HWS_PGA); | 808 | I915_READ(RING_HWS_PGA_GEN6(ring->mmio_base)); |
806 | } | 809 | } |
807 | 810 | ||
808 | static void gen6_bsd_ring_set_tail(struct drm_device *dev, | 811 | static void gen6_bsd_ring_set_tail(struct drm_device *dev, |
@@ -832,7 +835,7 @@ static unsigned int gen6_bsd_ring_get_active_head(struct drm_device *dev, | |||
832 | struct intel_ring_buffer *ring) | 835 | struct intel_ring_buffer *ring) |
833 | { | 836 | { |
834 | drm_i915_private_t *dev_priv = dev->dev_private; | 837 | drm_i915_private_t *dev_priv = dev->dev_private; |
835 | return I915_READ(GEN6_BSD_RING_ACTHD); | 838 | return I915_READ(RING_ACTHD(ring->mmio_base)); |
836 | } | 839 | } |
837 | 840 | ||
838 | static void gen6_bsd_ring_flush(struct drm_device *dev, | 841 | static void gen6_bsd_ring_flush(struct drm_device *dev, |