On 2018.11.19 20:54:30 +0200, Imre Deak wrote: > On Mon, Nov 19, 2018 at 05:29:26PM +0200, Ville Syrjälä wrote: > > On Mon, Nov 19, 2018 at 04:41:07PM +0200, Imre Deak wrote: > > > Depending on the transcoder enum values to translate from transcoder > > > to pipe/transcoder register addresses can easily break if we add a new > > > transcoder. So remove the dependency by using named initializers. > > > > > > Suggested-by: Ville Syrjälä > > > Cc: Ville Syrjälä > > > Signed-off-by: Imre Deak > > > --- > > > drivers/gpu/drm/i915/i915_pci.c | 52 ++++++++++++++++++++++++++++++----------- > > > 1 file changed, 38 insertions(+), 14 deletions(-) > > > > > > diff --git a/drivers/gpu/drm/i915/i915_pci.c b/drivers/gpu/drm/i915/i915_pci.c > > > index 983ae7fd8217..1b81d7cb209e 100644 > > > --- a/drivers/gpu/drm/i915/i915_pci.c > > > +++ b/drivers/gpu/drm/i915/i915_pci.c > > > @@ -33,16 +33,30 @@ > > > #define GEN(x) .gen = (x), .gen_mask = BIT((x) - 1) > > > > > > #define GEN_DEFAULT_PIPEOFFSETS \ > > > - .pipe_offsets = { PIPE_A_OFFSET, PIPE_B_OFFSET, \ > > > - PIPE_C_OFFSET, PIPE_EDP_OFFSET }, \ > > > - .trans_offsets = { TRANSCODER_A_OFFSET, TRANSCODER_B_OFFSET, \ > > > - TRANSCODER_C_OFFSET, TRANSCODER_EDP_OFFSET } > > > + .pipe_offsets = { \ > > > + [TRANSCODER_A] = PIPE_A_OFFSET, \ > > > + [TRANSCODER_B] = PIPE_B_OFFSET, \ > > > + [TRANSCODER_C] = PIPE_C_OFFSET, \ > > > + [TRANSCODER_EDP] = PIPE_EDP_OFFSET, \ > > > > Hmm. We do define this as int pipe_offsets[I915_MAX_TRANSCODERS], and > > PIPECONF/TRANSCONF is per-transcoder so I suppose using TRANSCODER_foo > > here make sense. > > > > Couple of things that came to mind while thinking about this: > > - pipe_offsets[] & co. could probably be u32 since we don't > > need negative values > > Ok, can follow up with that. > > > - _PIPE_EDP could be removed, which would maybe shrink a few > > arrays based on I915_MAX_PIPES > > Agreed. Looks like all the users are in gvt: > > - PIPECONF(_PIPE_EDP) should use PIPECONF(TRANSCODER_EDP) instead. The > current code would also break if we added a new transcoder. yeah, agreed. > - AFAICS > PIPEDSL(_PIPE_EDP) > PIPESTAT(_PIPE_EDP) > PIPE_FRMCOUNT_G4X(_PIPE_EDP) > PIPE_FLIPCOUNT_G4X(_PIPE_EDP) > are bogus, since these registers don't exist. > Thanks for pointing this out, looks they were added in very beginning, will remove those after double check. thanks > Adding gvt folks for these. > > > > > Patch is > > Reviewed-by: Ville Syrjälä > > > > > + }, \ > > > + .trans_offsets = { \ > > > + [TRANSCODER_A] = TRANSCODER_A_OFFSET, \ > > > + [TRANSCODER_B] = TRANSCODER_B_OFFSET, \ > > > + [TRANSCODER_C] = TRANSCODER_C_OFFSET, \ > > > + [TRANSCODER_EDP] = TRANSCODER_EDP_OFFSET, \ > > > + } > > > > > > #define GEN_CHV_PIPEOFFSETS \ > > > - .pipe_offsets = { PIPE_A_OFFSET, PIPE_B_OFFSET, \ > > > - CHV_PIPE_C_OFFSET }, \ > > > - .trans_offsets = { TRANSCODER_A_OFFSET, TRANSCODER_B_OFFSET, \ > > > - CHV_TRANSCODER_C_OFFSET } > > > + .pipe_offsets = { \ > > > + [TRANSCODER_A] = PIPE_A_OFFSET, \ > > > + [TRANSCODER_B] = PIPE_B_OFFSET, \ > > > + [TRANSCODER_C] = CHV_PIPE_C_OFFSET, \ > > > + }, \ > > > + .trans_offsets = { \ > > > + [TRANSCODER_A] = TRANSCODER_A_OFFSET, \ > > > + [TRANSCODER_B] = TRANSCODER_B_OFFSET, \ > > > + [TRANSCODER_C] = CHV_TRANSCODER_C_OFFSET, \ > > > + } > > > > > > #define CURSOR_OFFSETS \ > > > .cursor_offsets = { CURSOR_A_OFFSET, CURSOR_B_OFFSET, CHV_CURSOR_C_OFFSET } > > > @@ -592,12 +606,22 @@ static const struct intel_device_info intel_cannonlake_info = { > > > > > > #define GEN11_FEATURES \ > > > GEN10_FEATURES, \ > > > - .pipe_offsets = { PIPE_A_OFFSET, PIPE_B_OFFSET, \ > > > - PIPE_C_OFFSET, PIPE_EDP_OFFSET, \ > > > - PIPE_DSI0_OFFSET, PIPE_DSI1_OFFSET }, \ > > > - .trans_offsets = { TRANSCODER_A_OFFSET, TRANSCODER_B_OFFSET, \ > > > - TRANSCODER_C_OFFSET, TRANSCODER_EDP_OFFSET, \ > > > - TRANSCODER_DSI0_OFFSET, TRANSCODER_DSI1_OFFSET}, \ > > > + .pipe_offsets = { \ > > > + [TRANSCODER_A] = PIPE_A_OFFSET, \ > > > + [TRANSCODER_B] = PIPE_B_OFFSET, \ > > > + [TRANSCODER_C] = PIPE_C_OFFSET, \ > > > + [TRANSCODER_EDP] = PIPE_EDP_OFFSET, \ > > > + [TRANSCODER_DSI_0] = PIPE_DSI0_OFFSET, \ > > > + [TRANSCODER_DSI_1] = PIPE_DSI1_OFFSET, \ > > > + }, \ > > > + .trans_offsets = { \ > > > + [TRANSCODER_A] = TRANSCODER_A_OFFSET, \ > > > + [TRANSCODER_B] = TRANSCODER_B_OFFSET, \ > > > + [TRANSCODER_C] = TRANSCODER_C_OFFSET, \ > > > + [TRANSCODER_EDP] = TRANSCODER_EDP_OFFSET, \ > > > + [TRANSCODER_DSI_0] = TRANSCODER_DSI0_OFFSET, \ > > > + [TRANSCODER_DSI_1] = TRANSCODER_DSI1_OFFSET, \ > > > + }, \ > > > GEN(11), \ > > > .ddb_size = 2048, \ > > > .has_logical_ring_elsq = 1 > > > -- > > > 2.13.2 > > > > -- > > Ville Syrjälä > > Intel -- Open Source Technology Center, Intel ltd. $gpg --keyserver wwwkeys.pgp.net --recv-keys 4D781827