提交 0537db80 编写于 作者: P Philipp Zabel

gpu: ipu-v3: image-convert: reconfigure IC per tile

For differently sized tiles or if the resizing coefficients change,
we have to stop, reconfigure, and restart the IC between tiles.
Signed-off-by: NPhilipp Zabel <p.zabel@pengutronix.de>
Acked-by: NSteve Longerbeam <slongerbeam@gmail.com>
Tested-by: NSteve Longerbeam <slongerbeam@gmail.com>
上级 70b9b6b3
...@@ -1151,6 +1151,24 @@ static irqreturn_t do_bh(int irq, void *dev_id) ...@@ -1151,6 +1151,24 @@ static irqreturn_t do_bh(int irq, void *dev_id)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
static bool ic_settings_changed(struct ipu_image_convert_ctx *ctx)
{
unsigned int cur_tile = ctx->next_tile - 1;
unsigned int next_tile = ctx->next_tile;
if (ctx->resize_coeffs_h[cur_tile % ctx->in.num_cols] !=
ctx->resize_coeffs_h[next_tile % ctx->in.num_cols] ||
ctx->resize_coeffs_v[cur_tile / ctx->in.num_cols] !=
ctx->resize_coeffs_v[next_tile / ctx->in.num_cols] ||
ctx->in.tile[cur_tile].width != ctx->in.tile[next_tile].width ||
ctx->in.tile[cur_tile].height != ctx->in.tile[next_tile].height ||
ctx->out.tile[cur_tile].width != ctx->out.tile[next_tile].width ||
ctx->out.tile[cur_tile].height != ctx->out.tile[next_tile].height)
return true;
return false;
}
/* hold irqlock when calling */ /* hold irqlock when calling */
static irqreturn_t do_irq(struct ipu_image_convert_run *run) static irqreturn_t do_irq(struct ipu_image_convert_run *run)
{ {
...@@ -1194,27 +1212,32 @@ static irqreturn_t do_irq(struct ipu_image_convert_run *run) ...@@ -1194,27 +1212,32 @@ static irqreturn_t do_irq(struct ipu_image_convert_run *run)
* not done, place the next tile buffers. * not done, place the next tile buffers.
*/ */
if (!ctx->double_buffering) { if (!ctx->double_buffering) {
if (ic_settings_changed(ctx)) {
src_tile = &s_image->tile[ctx->next_tile]; convert_stop(run);
dst_idx = ctx->out_tile_map[ctx->next_tile]; convert_start(run, ctx->next_tile);
dst_tile = &d_image->tile[dst_idx]; } else {
src_tile = &s_image->tile[ctx->next_tile];
ipu_cpmem_set_buffer(chan->in_chan, 0, dst_idx = ctx->out_tile_map[ctx->next_tile];
s_image->base.phys0 + src_tile->offset); dst_tile = &d_image->tile[dst_idx];
ipu_cpmem_set_buffer(outch, 0,
d_image->base.phys0 + dst_tile->offset); ipu_cpmem_set_buffer(chan->in_chan, 0,
if (s_image->fmt->planar) s_image->base.phys0 +
ipu_cpmem_set_uv_offset(chan->in_chan, src_tile->offset);
src_tile->u_off, ipu_cpmem_set_buffer(outch, 0,
src_tile->v_off); d_image->base.phys0 +
if (d_image->fmt->planar) dst_tile->offset);
ipu_cpmem_set_uv_offset(outch, if (s_image->fmt->planar)
dst_tile->u_off, ipu_cpmem_set_uv_offset(chan->in_chan,
dst_tile->v_off); src_tile->u_off,
src_tile->v_off);
ipu_idmac_select_buffer(chan->in_chan, 0); if (d_image->fmt->planar)
ipu_idmac_select_buffer(outch, 0); ipu_cpmem_set_uv_offset(outch,
dst_tile->u_off,
dst_tile->v_off);
ipu_idmac_select_buffer(chan->in_chan, 0);
ipu_idmac_select_buffer(outch, 0);
}
} else if (ctx->next_tile < ctx->num_tiles - 1) { } else if (ctx->next_tile < ctx->num_tiles - 1) {
src_tile = &s_image->tile[ctx->next_tile + 1]; src_tile = &s_image->tile[ctx->next_tile + 1];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册