Re: [Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
On Fri, Oct 23, 2020 at 02:56:21AM +0300, Ville Syrjälä wrote: On Thu, Oct 08, 2020 at 01:52:30AM -0700, Lucas De Marchi wrote: On Thu, Oct 08, 2020 at 11:40:28AM +0300, Ville Syrjälä wrote: >On Wed, Oct 07, 2020 at 03:51:11PM -0700, Lucas De Marchi wrote: >> On Tue, Oct 06, 2020 at 05:33:34PM +0300, Ville Syrjälä wrote: >> >From: Ville Syrjälä >> > >> >Just like with the DDIs tgl+ renamed the AUX CHs to reflect >> >the type of the DDI. Let's add the aliasing enum values for >> >the type-C AUX CHs. >> > >> >Signed-off-by: Ville Syrjälä >> >--- >> > drivers/gpu/drm/i915/display/intel_display.h | 8 +++ >> > drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- >> > 2 files changed, 58 insertions(+), 3 deletions(-) >> > >> >diff --git a/drivers/gpu/drm/i915/display/intel_display.h b/drivers/gpu/drm/i915/display/intel_display.h >> >index a39be3c9e0cf..cba876721ea0 100644 >> >--- a/drivers/gpu/drm/i915/display/intel_display.h >> >+++ b/drivers/gpu/drm/i915/display/intel_display.h >> >@@ -290,6 +290,14 @@ enum aux_ch { >> > AUX_CH_G, >> > AUX_CH_H, >> > AUX_CH_I, >> >+ >> >+ /* tgl+ */ >> >+ AUX_CH_USBC1 = AUX_CH_D, >> >+ AUX_CH_USBC2, >> >+ AUX_CH_USBC3, >> >+ AUX_CH_USBC4, >> >+ AUX_CH_USBC5, >> >+ AUX_CH_USBC6, >> > }; >> > >> > #define aux_ch_name(a) ((a) + 'A') >> >diff --git a/drivers/gpu/drm/i915/display/intel_dp.c b/drivers/gpu/drm/i915/display/intel_dp.c >> >index 239016dcd544..a73c354c920e 100644 >> >--- a/drivers/gpu/drm/i915/display/intel_dp.c >> >+++ b/drivers/gpu/drm/i915/display/intel_dp.c >> >@@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp *intel_dp) >> > case AUX_CH_D: >> > case AUX_CH_E: >> > case AUX_CH_F: >> >- case AUX_CH_G: >> > return DP_AUX_CH_CTL(aux_ch); >> > default: >> > MISSING_CASE(aux_ch); >> >@@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp *intel_dp, int index) >> > case AUX_CH_D: >> > case AUX_CH_E: >> > case AUX_CH_F: >> >- case AUX_CH_G: >> >+ return DP_AUX_CH_DATA(aux_ch, index); >> >+ default: >> >+ MISSING_CASE(aux_ch); >> >+ return DP_AUX_CH_DATA(AUX_CH_A, index); >> >+ } >> >+} >> >+ >> >+static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) >> >+{ >> >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); >> >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >> >+ enum aux_ch aux_ch = dig_port->aux_ch; >> >+ >> >+ switch (aux_ch) { >> >+ case AUX_CH_A: >> >+ case AUX_CH_B: >> >+ case AUX_CH_C: >> >+ case AUX_CH_USBC1: >> >+ case AUX_CH_USBC2: >> >+ case AUX_CH_USBC3: >> >+ case AUX_CH_USBC4: >> >+ case AUX_CH_USBC5: >> >+ case AUX_CH_USBC6: >> >+ return DP_AUX_CH_CTL(aux_ch); >> >+ default: >> >+ MISSING_CASE(aux_ch); >> >+ return DP_AUX_CH_CTL(AUX_CH_A); >> >+ } >> >+} >> >+ >> >+static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) >> >+{ >> >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); >> >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >> >+ enum aux_ch aux_ch = dig_port->aux_ch; >> >+ >> >+ switch (aux_ch) { >> >+ case AUX_CH_A: >> >+ case AUX_CH_B: >> >+ case AUX_CH_C: >> >+ case AUX_CH_USBC1: >> >+ case AUX_CH_USBC2: >> >+ case AUX_CH_USBC3: >> >+ case AUX_CH_USBC4: >> >+ case AUX_CH_USBC5: >> >+ case AUX_CH_USBC6: >> > return DP_AUX_CH_DATA(aux_ch, index); >> > default: >> > MISSING_CASE(aux_ch); >> >@@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) >> > struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >> > struct intel_encoder *encoder = &dig_port->base; >> > >> >- if (INTEL_GEN(dev_priv) >= 9) { >> >+ if (INTEL_GEN(dev_priv) >= 12) { >> >+ intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; >> >> why is this even a function pointer rather than just the reg? AFAICS it >> only depends on dig_port->aux_ch that is initialized in intel_ddi_init() > >Just for consistency with .aux_ch_data_reg() I guess. Can't remember >a more specific reason at least. even that may be overkill since all the users just use index to do `+ index * 4` The code used to do that but we got rid of it when the i915_reg stuff was introduced to discourage people from doing hand rolled arithmetic on register offsets. I think the tradeoff has been generally worth it because I can't remeber the last time someone messed up the register offsets. Before type safety it was a somewhat regular occurance. ok. Just so patchwork gets it now: Reviewed-by: Lucas De Marchi Lucas De Marchi -- Ville Syrjälä Intel ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
Re: [Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
On Thu, Oct 08, 2020 at 01:52:30AM -0700, Lucas De Marchi wrote: > On Thu, Oct 08, 2020 at 11:40:28AM +0300, Ville Syrjälä wrote: > >On Wed, Oct 07, 2020 at 03:51:11PM -0700, Lucas De Marchi wrote: > >> On Tue, Oct 06, 2020 at 05:33:34PM +0300, Ville Syrjälä wrote: > >> >From: Ville Syrjälä > >> > > >> >Just like with the DDIs tgl+ renamed the AUX CHs to reflect > >> >the type of the DDI. Let's add the aliasing enum values for > >> >the type-C AUX CHs. > >> > > >> >Signed-off-by: Ville Syrjälä > >> >--- > >> > drivers/gpu/drm/i915/display/intel_display.h | 8 +++ > >> > drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- > >> > 2 files changed, 58 insertions(+), 3 deletions(-) > >> > > >> >diff --git a/drivers/gpu/drm/i915/display/intel_display.h > >> >b/drivers/gpu/drm/i915/display/intel_display.h > >> >index a39be3c9e0cf..cba876721ea0 100644 > >> >--- a/drivers/gpu/drm/i915/display/intel_display.h > >> >+++ b/drivers/gpu/drm/i915/display/intel_display.h > >> >@@ -290,6 +290,14 @@ enum aux_ch { > >> > AUX_CH_G, > >> > AUX_CH_H, > >> > AUX_CH_I, > >> >+ > >> >+ /* tgl+ */ > >> >+ AUX_CH_USBC1 = AUX_CH_D, > >> >+ AUX_CH_USBC2, > >> >+ AUX_CH_USBC3, > >> >+ AUX_CH_USBC4, > >> >+ AUX_CH_USBC5, > >> >+ AUX_CH_USBC6, > >> > }; > >> > > >> > #define aux_ch_name(a) ((a) + 'A') > >> >diff --git a/drivers/gpu/drm/i915/display/intel_dp.c > >> >b/drivers/gpu/drm/i915/display/intel_dp.c > >> >index 239016dcd544..a73c354c920e 100644 > >> >--- a/drivers/gpu/drm/i915/display/intel_dp.c > >> >+++ b/drivers/gpu/drm/i915/display/intel_dp.c > >> >@@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp > >> >*intel_dp) > >> > case AUX_CH_D: > >> > case AUX_CH_E: > >> > case AUX_CH_F: > >> >- case AUX_CH_G: > >> > return DP_AUX_CH_CTL(aux_ch); > >> > default: > >> > MISSING_CASE(aux_ch); > >> >@@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp > >> >*intel_dp, int index) > >> > case AUX_CH_D: > >> > case AUX_CH_E: > >> > case AUX_CH_F: > >> >- case AUX_CH_G: > >> >+ return DP_AUX_CH_DATA(aux_ch, index); > >> >+ default: > >> >+ MISSING_CASE(aux_ch); > >> >+ return DP_AUX_CH_DATA(AUX_CH_A, index); > >> >+ } > >> >+} > >> >+ > >> >+static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) > >> >+{ > >> >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); > >> >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > >> >+ enum aux_ch aux_ch = dig_port->aux_ch; > >> >+ > >> >+ switch (aux_ch) { > >> >+ case AUX_CH_A: > >> >+ case AUX_CH_B: > >> >+ case AUX_CH_C: > >> >+ case AUX_CH_USBC1: > >> >+ case AUX_CH_USBC2: > >> >+ case AUX_CH_USBC3: > >> >+ case AUX_CH_USBC4: > >> >+ case AUX_CH_USBC5: > >> >+ case AUX_CH_USBC6: > >> >+ return DP_AUX_CH_CTL(aux_ch); > >> >+ default: > >> >+ MISSING_CASE(aux_ch); > >> >+ return DP_AUX_CH_CTL(AUX_CH_A); > >> >+ } > >> >+} > >> >+ > >> >+static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) > >> >+{ > >> >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); > >> >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > >> >+ enum aux_ch aux_ch = dig_port->aux_ch; > >> >+ > >> >+ switch (aux_ch) { > >> >+ case AUX_CH_A: > >> >+ case AUX_CH_B: > >> >+ case AUX_CH_C: > >> >+ case AUX_CH_USBC1: > >> >+ case AUX_CH_USBC2: > >> >+ case AUX_CH_USBC3: > >> >+ case AUX_CH_USBC4: > >> >+ case AUX_CH_USBC5: > >> >+ case AUX_CH_USBC6: > >> > return DP_AUX_CH_DATA(aux_ch, index); > >> > default: > >> > MISSING_CASE(aux_ch); > >> >@@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) > >> > struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > >> > struct intel_encoder *encoder = &dig_port->base; > >> > > >> >- if (INTEL_GEN(dev_priv) >= 9) { > >> >+ if (INTEL_GEN(dev_priv) >= 12) { > >> >+ intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; > >> > >> why is this even a function pointer rather than just the reg? AFAICS it > >> only depends on dig_port->aux_ch that is initialized in intel_ddi_init() > > > >Just for consistency with .aux_ch_data_reg() I guess. Can't remember > >a more specific reason at least. > > even that may be overkill since all the users just use index to > do `+ index * 4` The code used to do that but we got rid of it when the i915_reg stuff was introduced to discourage people from doing hand rolled arithmetic on register offsets. I think the tradeoff has been generally worth it because I can't remeber the last time someone messed up the register offsets. Before type safety it was a somewhat regular occurance. -- Ville Syrjälä Intel ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
Re: [Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
On Thu, Oct 08, 2020 at 11:40:28AM +0300, Ville Syrjälä wrote: On Wed, Oct 07, 2020 at 03:51:11PM -0700, Lucas De Marchi wrote: On Tue, Oct 06, 2020 at 05:33:34PM +0300, Ville Syrjälä wrote: >From: Ville Syrjälä > >Just like with the DDIs tgl+ renamed the AUX CHs to reflect >the type of the DDI. Let's add the aliasing enum values for >the type-C AUX CHs. > >Signed-off-by: Ville Syrjälä >--- > drivers/gpu/drm/i915/display/intel_display.h | 8 +++ > drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- > 2 files changed, 58 insertions(+), 3 deletions(-) > >diff --git a/drivers/gpu/drm/i915/display/intel_display.h b/drivers/gpu/drm/i915/display/intel_display.h >index a39be3c9e0cf..cba876721ea0 100644 >--- a/drivers/gpu/drm/i915/display/intel_display.h >+++ b/drivers/gpu/drm/i915/display/intel_display.h >@@ -290,6 +290,14 @@ enum aux_ch { >AUX_CH_G, >AUX_CH_H, >AUX_CH_I, >+ >+ /* tgl+ */ >+ AUX_CH_USBC1 = AUX_CH_D, >+ AUX_CH_USBC2, >+ AUX_CH_USBC3, >+ AUX_CH_USBC4, >+ AUX_CH_USBC5, >+ AUX_CH_USBC6, > }; > > #define aux_ch_name(a) ((a) + 'A') >diff --git a/drivers/gpu/drm/i915/display/intel_dp.c b/drivers/gpu/drm/i915/display/intel_dp.c >index 239016dcd544..a73c354c920e 100644 >--- a/drivers/gpu/drm/i915/display/intel_dp.c >+++ b/drivers/gpu/drm/i915/display/intel_dp.c >@@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp *intel_dp) >case AUX_CH_D: >case AUX_CH_E: >case AUX_CH_F: >- case AUX_CH_G: >return DP_AUX_CH_CTL(aux_ch); >default: >MISSING_CASE(aux_ch); >@@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp *intel_dp, int index) >case AUX_CH_D: >case AUX_CH_E: >case AUX_CH_F: >- case AUX_CH_G: >+ return DP_AUX_CH_DATA(aux_ch, index); >+ default: >+ MISSING_CASE(aux_ch); >+ return DP_AUX_CH_DATA(AUX_CH_A, index); >+ } >+} >+ >+static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) >+{ >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >+ enum aux_ch aux_ch = dig_port->aux_ch; >+ >+ switch (aux_ch) { >+ case AUX_CH_A: >+ case AUX_CH_B: >+ case AUX_CH_C: >+ case AUX_CH_USBC1: >+ case AUX_CH_USBC2: >+ case AUX_CH_USBC3: >+ case AUX_CH_USBC4: >+ case AUX_CH_USBC5: >+ case AUX_CH_USBC6: >+ return DP_AUX_CH_CTL(aux_ch); >+ default: >+ MISSING_CASE(aux_ch); >+ return DP_AUX_CH_CTL(AUX_CH_A); >+ } >+} >+ >+static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) >+{ >+ struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); >+ struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >+ enum aux_ch aux_ch = dig_port->aux_ch; >+ >+ switch (aux_ch) { >+ case AUX_CH_A: >+ case AUX_CH_B: >+ case AUX_CH_C: >+ case AUX_CH_USBC1: >+ case AUX_CH_USBC2: >+ case AUX_CH_USBC3: >+ case AUX_CH_USBC4: >+ case AUX_CH_USBC5: >+ case AUX_CH_USBC6: >return DP_AUX_CH_DATA(aux_ch, index); >default: >MISSING_CASE(aux_ch); >@@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) >struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); >struct intel_encoder *encoder = &dig_port->base; > >- if (INTEL_GEN(dev_priv) >= 9) { >+ if (INTEL_GEN(dev_priv) >= 12) { >+ intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; why is this even a function pointer rather than just the reg? AFAICS it only depends on dig_port->aux_ch that is initialized in intel_ddi_init() Just for consistency with .aux_ch_data_reg() I guess. Can't remember a more specific reason at least. even that may be overkill since all the users just use index to do `+ index * 4` Lucas De Marchi but could be orthogonal to the change here. Reviewed-by: Lucas De Marchi Lucas De Marchi >+ intel_dp->aux_ch_data_reg = tgl_aux_data_reg; >+ } else if (INTEL_GEN(dev_priv) >= 9) { >intel_dp->aux_ch_ctl_reg = skl_aux_ctl_reg; >intel_dp->aux_ch_data_reg = skl_aux_data_reg; >} else if (HAS_PCH_SPLIT(dev_priv)) { >-- >2.26.2 > >___ >Intel-gfx mailing list >Intel-gfx@lists.freedesktop.org >https://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Ville Syrjälä Intel ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
Re: [Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
On Wed, Oct 07, 2020 at 03:51:11PM -0700, Lucas De Marchi wrote: > On Tue, Oct 06, 2020 at 05:33:34PM +0300, Ville Syrjälä wrote: > >From: Ville Syrjälä > > > >Just like with the DDIs tgl+ renamed the AUX CHs to reflect > >the type of the DDI. Let's add the aliasing enum values for > >the type-C AUX CHs. > > > >Signed-off-by: Ville Syrjälä > >--- > > drivers/gpu/drm/i915/display/intel_display.h | 8 +++ > > drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- > > 2 files changed, 58 insertions(+), 3 deletions(-) > > > >diff --git a/drivers/gpu/drm/i915/display/intel_display.h > >b/drivers/gpu/drm/i915/display/intel_display.h > >index a39be3c9e0cf..cba876721ea0 100644 > >--- a/drivers/gpu/drm/i915/display/intel_display.h > >+++ b/drivers/gpu/drm/i915/display/intel_display.h > >@@ -290,6 +290,14 @@ enum aux_ch { > > AUX_CH_G, > > AUX_CH_H, > > AUX_CH_I, > >+ > >+/* tgl+ */ > >+AUX_CH_USBC1 = AUX_CH_D, > >+AUX_CH_USBC2, > >+AUX_CH_USBC3, > >+AUX_CH_USBC4, > >+AUX_CH_USBC5, > >+AUX_CH_USBC6, > > }; > > > > #define aux_ch_name(a) ((a) + 'A') > >diff --git a/drivers/gpu/drm/i915/display/intel_dp.c > >b/drivers/gpu/drm/i915/display/intel_dp.c > >index 239016dcd544..a73c354c920e 100644 > >--- a/drivers/gpu/drm/i915/display/intel_dp.c > >+++ b/drivers/gpu/drm/i915/display/intel_dp.c > >@@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp > >*intel_dp) > > case AUX_CH_D: > > case AUX_CH_E: > > case AUX_CH_F: > >-case AUX_CH_G: > > return DP_AUX_CH_CTL(aux_ch); > > default: > > MISSING_CASE(aux_ch); > >@@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp > >*intel_dp, int index) > > case AUX_CH_D: > > case AUX_CH_E: > > case AUX_CH_F: > >-case AUX_CH_G: > >+return DP_AUX_CH_DATA(aux_ch, index); > >+default: > >+MISSING_CASE(aux_ch); > >+return DP_AUX_CH_DATA(AUX_CH_A, index); > >+} > >+} > >+ > >+static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) > >+{ > >+struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); > >+struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > >+enum aux_ch aux_ch = dig_port->aux_ch; > >+ > >+switch (aux_ch) { > >+case AUX_CH_A: > >+case AUX_CH_B: > >+case AUX_CH_C: > >+case AUX_CH_USBC1: > >+case AUX_CH_USBC2: > >+case AUX_CH_USBC3: > >+case AUX_CH_USBC4: > >+case AUX_CH_USBC5: > >+case AUX_CH_USBC6: > >+return DP_AUX_CH_CTL(aux_ch); > >+default: > >+MISSING_CASE(aux_ch); > >+return DP_AUX_CH_CTL(AUX_CH_A); > >+} > >+} > >+ > >+static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) > >+{ > >+struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); > >+struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > >+enum aux_ch aux_ch = dig_port->aux_ch; > >+ > >+switch (aux_ch) { > >+case AUX_CH_A: > >+case AUX_CH_B: > >+case AUX_CH_C: > >+case AUX_CH_USBC1: > >+case AUX_CH_USBC2: > >+case AUX_CH_USBC3: > >+case AUX_CH_USBC4: > >+case AUX_CH_USBC5: > >+case AUX_CH_USBC6: > > return DP_AUX_CH_DATA(aux_ch, index); > > default: > > MISSING_CASE(aux_ch); > >@@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) > > struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); > > struct intel_encoder *encoder = &dig_port->base; > > > >-if (INTEL_GEN(dev_priv) >= 9) { > >+if (INTEL_GEN(dev_priv) >= 12) { > >+intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; > > why is this even a function pointer rather than just the reg? AFAICS it > only depends on dig_port->aux_ch that is initialized in intel_ddi_init() Just for consistency with .aux_ch_data_reg() I guess. Can't remember a more specific reason at least. > > but could be orthogonal to the change here. > > > Reviewed-by: Lucas De Marchi > > Lucas De Marchi > > >+intel_dp->aux_ch_data_reg = tgl_aux_data_reg; > >+} else if (INTEL_GEN(dev_priv) >= 9) { > > intel_dp->aux_ch_ctl_reg = skl_aux_ctl_reg; > > intel_dp->aux_ch_data_reg = skl_aux_data_reg; > > } else if (HAS_PCH_SPLIT(dev_priv)) { > >-- > >2.26.2 > > > >___ > >Intel-gfx mailing list > >Intel-gfx@lists.freedesktop.org > >https://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Ville Syrjälä Intel ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
Re: [Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
On Tue, Oct 06, 2020 at 05:33:34PM +0300, Ville Syrjälä wrote: From: Ville Syrjälä Just like with the DDIs tgl+ renamed the AUX CHs to reflect the type of the DDI. Let's add the aliasing enum values for the type-C AUX CHs. Signed-off-by: Ville Syrjälä --- drivers/gpu/drm/i915/display/intel_display.h | 8 +++ drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- 2 files changed, 58 insertions(+), 3 deletions(-) diff --git a/drivers/gpu/drm/i915/display/intel_display.h b/drivers/gpu/drm/i915/display/intel_display.h index a39be3c9e0cf..cba876721ea0 100644 --- a/drivers/gpu/drm/i915/display/intel_display.h +++ b/drivers/gpu/drm/i915/display/intel_display.h @@ -290,6 +290,14 @@ enum aux_ch { AUX_CH_G, AUX_CH_H, AUX_CH_I, + + /* tgl+ */ + AUX_CH_USBC1 = AUX_CH_D, + AUX_CH_USBC2, + AUX_CH_USBC3, + AUX_CH_USBC4, + AUX_CH_USBC5, + AUX_CH_USBC6, }; #define aux_ch_name(a) ((a) + 'A') diff --git a/drivers/gpu/drm/i915/display/intel_dp.c b/drivers/gpu/drm/i915/display/intel_dp.c index 239016dcd544..a73c354c920e 100644 --- a/drivers/gpu/drm/i915/display/intel_dp.c +++ b/drivers/gpu/drm/i915/display/intel_dp.c @@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp *intel_dp) case AUX_CH_D: case AUX_CH_E: case AUX_CH_F: - case AUX_CH_G: return DP_AUX_CH_CTL(aux_ch); default: MISSING_CASE(aux_ch); @@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp *intel_dp, int index) case AUX_CH_D: case AUX_CH_E: case AUX_CH_F: - case AUX_CH_G: + return DP_AUX_CH_DATA(aux_ch, index); + default: + MISSING_CASE(aux_ch); + return DP_AUX_CH_DATA(AUX_CH_A, index); + } +} + +static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) +{ + struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); + struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); + enum aux_ch aux_ch = dig_port->aux_ch; + + switch (aux_ch) { + case AUX_CH_A: + case AUX_CH_B: + case AUX_CH_C: + case AUX_CH_USBC1: + case AUX_CH_USBC2: + case AUX_CH_USBC3: + case AUX_CH_USBC4: + case AUX_CH_USBC5: + case AUX_CH_USBC6: + return DP_AUX_CH_CTL(aux_ch); + default: + MISSING_CASE(aux_ch); + return DP_AUX_CH_CTL(AUX_CH_A); + } +} + +static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) +{ + struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); + struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); + enum aux_ch aux_ch = dig_port->aux_ch; + + switch (aux_ch) { + case AUX_CH_A: + case AUX_CH_B: + case AUX_CH_C: + case AUX_CH_USBC1: + case AUX_CH_USBC2: + case AUX_CH_USBC3: + case AUX_CH_USBC4: + case AUX_CH_USBC5: + case AUX_CH_USBC6: return DP_AUX_CH_DATA(aux_ch, index); default: MISSING_CASE(aux_ch); @@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); struct intel_encoder *encoder = &dig_port->base; - if (INTEL_GEN(dev_priv) >= 9) { + if (INTEL_GEN(dev_priv) >= 12) { + intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; why is this even a function pointer rather than just the reg? AFAICS it only depends on dig_port->aux_ch that is initialized in intel_ddi_init() but could be orthogonal to the change here. Reviewed-by: Lucas De Marchi Lucas De Marchi + intel_dp->aux_ch_data_reg = tgl_aux_data_reg; + } else if (INTEL_GEN(dev_priv) >= 9) { intel_dp->aux_ch_ctl_reg = skl_aux_ctl_reg; intel_dp->aux_ch_data_reg = skl_aux_data_reg; } else if (HAS_PCH_SPLIT(dev_priv)) { -- 2.26.2 ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx
[Intel-gfx] [PATCH 05/20] drm/i915: Introduce AUX_CH_USBCn
From: Ville Syrjälä Just like with the DDIs tgl+ renamed the AUX CHs to reflect the type of the DDI. Let's add the aliasing enum values for the type-C AUX CHs. Signed-off-by: Ville Syrjälä --- drivers/gpu/drm/i915/display/intel_display.h | 8 +++ drivers/gpu/drm/i915/display/intel_dp.c | 53 ++-- 2 files changed, 58 insertions(+), 3 deletions(-) diff --git a/drivers/gpu/drm/i915/display/intel_display.h b/drivers/gpu/drm/i915/display/intel_display.h index a39be3c9e0cf..cba876721ea0 100644 --- a/drivers/gpu/drm/i915/display/intel_display.h +++ b/drivers/gpu/drm/i915/display/intel_display.h @@ -290,6 +290,14 @@ enum aux_ch { AUX_CH_G, AUX_CH_H, AUX_CH_I, + + /* tgl+ */ + AUX_CH_USBC1 = AUX_CH_D, + AUX_CH_USBC2, + AUX_CH_USBC3, + AUX_CH_USBC4, + AUX_CH_USBC5, + AUX_CH_USBC6, }; #define aux_ch_name(a) ((a) + 'A') diff --git a/drivers/gpu/drm/i915/display/intel_dp.c b/drivers/gpu/drm/i915/display/intel_dp.c index 239016dcd544..a73c354c920e 100644 --- a/drivers/gpu/drm/i915/display/intel_dp.c +++ b/drivers/gpu/drm/i915/display/intel_dp.c @@ -1792,7 +1792,6 @@ static i915_reg_t skl_aux_ctl_reg(struct intel_dp *intel_dp) case AUX_CH_D: case AUX_CH_E: case AUX_CH_F: - case AUX_CH_G: return DP_AUX_CH_CTL(aux_ch); default: MISSING_CASE(aux_ch); @@ -1813,7 +1812,52 @@ static i915_reg_t skl_aux_data_reg(struct intel_dp *intel_dp, int index) case AUX_CH_D: case AUX_CH_E: case AUX_CH_F: - case AUX_CH_G: + return DP_AUX_CH_DATA(aux_ch, index); + default: + MISSING_CASE(aux_ch); + return DP_AUX_CH_DATA(AUX_CH_A, index); + } +} + +static i915_reg_t tgl_aux_ctl_reg(struct intel_dp *intel_dp) +{ + struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); + struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); + enum aux_ch aux_ch = dig_port->aux_ch; + + switch (aux_ch) { + case AUX_CH_A: + case AUX_CH_B: + case AUX_CH_C: + case AUX_CH_USBC1: + case AUX_CH_USBC2: + case AUX_CH_USBC3: + case AUX_CH_USBC4: + case AUX_CH_USBC5: + case AUX_CH_USBC6: + return DP_AUX_CH_CTL(aux_ch); + default: + MISSING_CASE(aux_ch); + return DP_AUX_CH_CTL(AUX_CH_A); + } +} + +static i915_reg_t tgl_aux_data_reg(struct intel_dp *intel_dp, int index) +{ + struct drm_i915_private *dev_priv = dp_to_i915(intel_dp); + struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); + enum aux_ch aux_ch = dig_port->aux_ch; + + switch (aux_ch) { + case AUX_CH_A: + case AUX_CH_B: + case AUX_CH_C: + case AUX_CH_USBC1: + case AUX_CH_USBC2: + case AUX_CH_USBC3: + case AUX_CH_USBC4: + case AUX_CH_USBC5: + case AUX_CH_USBC6: return DP_AUX_CH_DATA(aux_ch, index); default: MISSING_CASE(aux_ch); @@ -1834,7 +1878,10 @@ intel_dp_aux_init(struct intel_dp *intel_dp) struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp); struct intel_encoder *encoder = &dig_port->base; - if (INTEL_GEN(dev_priv) >= 9) { + if (INTEL_GEN(dev_priv) >= 12) { + intel_dp->aux_ch_ctl_reg = tgl_aux_ctl_reg; + intel_dp->aux_ch_data_reg = tgl_aux_data_reg; + } else if (INTEL_GEN(dev_priv) >= 9) { intel_dp->aux_ch_ctl_reg = skl_aux_ctl_reg; intel_dp->aux_ch_data_reg = skl_aux_data_reg; } else if (HAS_PCH_SPLIT(dev_priv)) { -- 2.26.2 ___ Intel-gfx mailing list Intel-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/intel-gfx