On Thu, May 05, 2016 at 03:06:49AM -0700, Kenneth Graunke wrote: > Allowing register copies where the source and destination are both > whitelisted should be safe, and is useful. For example, Mesa uses > this to load the command streamer math registers with data from the > pipeline statistics counters. > > Signed-off-by: Kenneth Graunke <kenneth@xxxxxxxxxxxxx> Reviewed-by: Chris Wilson <chris@xxxxxxxxxxxxxxxxxx> > --- > drivers/gpu/drm/i915/i915_cmd_parser.c | 12 ++++++++++-- > 1 file changed, 10 insertions(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/i915/i915_cmd_parser.c b/drivers/gpu/drm/i915/i915_cmd_parser.c > index 69a1ba8..14f3b44 100644 > --- a/drivers/gpu/drm/i915/i915_cmd_parser.c > +++ b/drivers/gpu/drm/i915/i915_cmd_parser.c > @@ -215,7 +215,8 @@ static const struct drm_i915_cmd_descriptor hsw_render_cmds[] = { HWS RCS only. ✔ > CMD( MI_RS_CONTEXT, SMI, F, 1, S ), > CMD( MI_LOAD_SCAN_LINES_INCL, SMI, !F, 0x3F, M ), > CMD( MI_LOAD_SCAN_LINES_EXCL, SMI, !F, 0x3F, R ), > - CMD( MI_LOAD_REGISTER_REG, SMI, !F, 0xFF, R ), > + CMD( MI_LOAD_REGISTER_REG, SMI, !F, 0xFF, W, > + .reg = { .offset = 1, .mask = 0x007FFFFC, .step = 1 } ), Bits 22:2 are the address, 0:1 mbz. ✔ offset=1, length=3, step=1 => check both src/dst against whitelist ✔ > CMD( MI_RS_STORE_DATA_IMM, SMI, !F, 0xFF, S ), > CMD( MI_LOAD_URB_MEM, SMI, !F, 0xFF, S ), > CMD( MI_STORE_URB_MEM, SMI, !F, 0xFF, S ), > @@ -1113,6 +1114,12 @@ static bool check_cmd(const struct intel_engine_cs *engine, > return false; > } > > + if (desc->cmd.value == MI_LOAD_REGISTER_REG) { > + DRM_DEBUG_DRIVER("CMD: Rejected LRR to masked register 0x%08X\n", > + reg_addr); > + return false; > + } Since we can't inspect the value to see if meets the permitted mask. ✔ The only thing missing on the checklist would be an igt to load, copy, then store that register back to memory to check this works. -Chris -- Chris Wilson, Intel Open Source Technology Centre _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx