summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChia-I Wu <[email protected]>2014-09-20 10:55:21 +0800
committerChia-I Wu <[email protected]>2014-09-20 11:06:08 +0800
commitbca549691eec731dca9381b457403bcdd662ef9d (patch)
treecf16326ded1411db888a0d8eafbf31d5be4628e6
parentc1165c8ea0df3f1fe56a19926125642c99c1e284 (diff)
ilo: no direct ilo_context access in BLT blitter
We need ilo_builder for command building and ilo_cp for size check. ilo_context is not used.
-rw-r--r--src/gallium/drivers/ilo/ilo_blitter_blt.c41
1 files changed, 20 insertions, 21 deletions
diff --git a/src/gallium/drivers/ilo/ilo_blitter_blt.c b/src/gallium/drivers/ilo/ilo_blitter_blt.c
index aead0b2cf40..c58cad4d5a3 100644
--- a/src/gallium/drivers/ilo/ilo_blitter_blt.c
+++ b/src/gallium/drivers/ilo/ilo_blitter_blt.c
@@ -42,13 +42,13 @@ ilo_blitter_blt_begin(struct ilo_blitter *blitter, int max_cmd_size,
struct intel_bo *dst, enum intel_tiling_mode dst_tiling,
struct intel_bo *src, enum intel_tiling_mode src_tiling)
{
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_cp *cp = blitter->ilo->cp;
struct intel_bo *aper_check[2];
int count;
uint32_t swctrl;
/* change owner */
- ilo_cp_set_owner(ilo->cp, INTEL_RING_BLT, NULL);
+ ilo_cp_set_owner(cp, INTEL_RING_BLT, NULL);
/* check aperture space */
aper_check[0] = dst;
@@ -59,8 +59,8 @@ ilo_blitter_blt_begin(struct ilo_blitter *blitter, int max_cmd_size,
count++;
}
- if (!ilo_builder_validate(&ilo->cp->builder, count, aper_check))
- ilo_cp_submit(ilo->cp, "out of aperture");
+ if (!ilo_builder_validate(&cp->builder, count, aper_check))
+ ilo_cp_submit(cp, "out of aperture");
/* set BCS_SWCTRL */
swctrl = 0x0;
@@ -83,9 +83,9 @@ ilo_blitter_blt_begin(struct ilo_blitter *blitter, int max_cmd_size,
if (swctrl)
max_cmd_size += (4 + 3) * 2;
- if (ilo_cp_space(ilo->cp) < max_cmd_size) {
- ilo_cp_submit(ilo->cp, "out of space");
- assert(ilo_cp_space(ilo->cp) >= max_cmd_size);
+ if (ilo_cp_space(cp) < max_cmd_size) {
+ ilo_cp_submit(cp, "out of space");
+ assert(ilo_cp_space(cp) >= max_cmd_size);
}
if (swctrl) {
@@ -95,9 +95,8 @@ ilo_blitter_blt_begin(struct ilo_blitter *blitter, int max_cmd_size,
* "SW is required to flush the HW before changing the polarity of
* this bit (Tile Y Destination/Source)."
*/
- gen6_MI_FLUSH_DW(&ilo->cp->builder);
- gen6_MI_LOAD_REGISTER_IMM(&ilo->cp->builder,
- GEN6_REG_BCS_SWCTRL, swctrl);
+ gen6_MI_FLUSH_DW(&cp->builder);
+ gen6_MI_LOAD_REGISTER_IMM(&cp->builder, GEN6_REG_BCS_SWCTRL, swctrl);
swctrl &= ~(GEN6_REG_BCS_SWCTRL_DST_TILING_Y |
GEN6_REG_BCS_SWCTRL_SRC_TILING_Y);
@@ -109,12 +108,12 @@ ilo_blitter_blt_begin(struct ilo_blitter *blitter, int max_cmd_size,
static void
ilo_blitter_blt_end(struct ilo_blitter *blitter, uint32_t swctrl)
{
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_builder *builder = &blitter->ilo->cp->builder;
/* set BCS_SWCTRL back */
if (swctrl) {
- gen6_MI_FLUSH_DW(&ilo->cp->builder);
- gen6_MI_LOAD_REGISTER_IMM(&ilo->cp->builder, GEN6_REG_BCS_SWCTRL, swctrl);
+ gen6_MI_FLUSH_DW(builder);
+ gen6_MI_LOAD_REGISTER_IMM(builder, GEN6_REG_BCS_SWCTRL, swctrl);
}
}
@@ -127,7 +126,7 @@ buf_clear_region(struct ilo_blitter *blitter,
{
const uint8_t rop = 0xf0; /* PATCOPY */
const int cpp = gen6_blt_translate_value_cpp(value_mask);
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_builder *builder = &blitter->ilo->cp->builder;
struct gen6_blt_bo dst;
if (offset % cpp || size % cpp)
@@ -158,7 +157,7 @@ buf_clear_region(struct ilo_blitter *blitter,
dst.pitch = 0;
}
- gen6_COLOR_BLT(&ilo->cp->builder, &dst, val,
+ gen6_COLOR_BLT(builder, &dst, val,
width, height, rop, value_mask, write_mask);
dst.offset += dst.pitch * height;
@@ -177,7 +176,7 @@ buf_copy_region(struct ilo_blitter *blitter,
unsigned size)
{
const uint8_t rop = 0xcc; /* SRCCOPY */
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_builder *builder = &blitter->ilo->cp->builder;
struct gen6_blt_bo dst, src;
dst.bo = dst_buf->bo;
@@ -212,7 +211,7 @@ buf_copy_region(struct ilo_blitter *blitter,
src.pitch = 0;
}
- gen6_SRC_COPY_BLT(&ilo->cp->builder, &dst, &src,
+ gen6_SRC_COPY_BLT(builder, &dst, &src,
width, height, rop, GEN6_BLT_MASK_8, GEN6_BLT_MASK_8);
dst.offset += dst.pitch * height;
@@ -236,7 +235,7 @@ tex_clear_region(struct ilo_blitter *blitter,
const int cpp = gen6_blt_translate_value_cpp(value_mask);
const unsigned max_extent = 32767; /* INT16_MAX */
const uint8_t rop = 0xf0; /* PATCOPY */
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_builder *builder = &blitter->ilo->cp->builder;
struct gen6_blt_xy_bo dst;
uint32_t swctrl;
int slice;
@@ -273,7 +272,7 @@ tex_clear_region(struct ilo_blitter *blitter,
dst.y + dst_box->height > max_extent)
break;
- gen6_XY_COLOR_BLT(&ilo->cp->builder, &dst, val,
+ gen6_XY_COLOR_BLT(builder, &dst, val,
dst_box->width, dst_box->height, rop, value_mask, write_mask);
}
@@ -295,7 +294,7 @@ tex_copy_region(struct ilo_blitter *blitter,
util_format_description(dst_tex->layout.format);
const unsigned max_extent = 32767; /* INT16_MAX */
const uint8_t rop = 0xcc; /* SRCCOPY */
- struct ilo_context *ilo = blitter->ilo;
+ struct ilo_builder *builder = &blitter->ilo->cp->builder;
enum gen6_blt_mask mask;
struct gen6_blt_xy_bo dst, src;
uint32_t swctrl;
@@ -380,7 +379,7 @@ tex_copy_region(struct ilo_blitter *blitter,
dst.x + width > max_extent || dst.y + height > max_extent)
break;
- gen6_XY_SRC_COPY_BLT(&ilo->cp->builder, &dst, &src,
+ gen6_XY_SRC_COPY_BLT(builder, &dst, &src,
width, height, rop, mask, mask);
}