On Fri, 15 Jun 2018, Madhav Chauhan <madhav.chauhan@xxxxxxxxx> wrote: > This register used to power down individual lanes for > DDI/DSI ports. Bitfields to power up/down various > combinations of lanes are also added in this patch. > > Signed-off-by: Madhav Chauhan <madhav.chauhan@xxxxxxxxx> > --- > drivers/gpu/drm/i915/i915_reg.h | 19 +++++++++++++++++++ > 1 file changed, 19 insertions(+) > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h > index 0d268d1..1b91e73 100644 > --- a/drivers/gpu/drm/i915/i915_reg.h > +++ b/drivers/gpu/drm/i915/i915_reg.h > @@ -1666,6 +1666,25 @@ enum i915_power_well_id { > #define ICL_PORT_CL_DW5(port) _MMIO_PORT(port, _ICL_PORT_CL_DW5_A, \ > _ICL_PORT_CL_DW5_B) > > +#define _CNL_PORT_CL_DW10_A 0x162028 > +#define _ICL_PORT_CL_DW10_B 0x6c028 > +#define ICL_PORT_CL_DW10(port) _MMIO_PORT(port, \ > + _CNL_PORT_CL_DW10_A, \ > + _ICL_PORT_CL_DW10_B) > +#define PG_SEQ_DELAY_OVRRIDE (3 << 25) _OVERRIDE_MASK? > +#define PG_SEQ_DELAY_OVRRIDE_ENABLE (1 << 24) OVERRIDE > +#define PWR_UP_ALL_LANES 0x0 > +#define PWR_DOWN_LN_3_2_1 0xe > +#define PWR_DOWN_LN_3_2 0xc > +#define PWR_DOWN_LN_3 0x8 > +#define PWR_DOWN_LN_2_1_0 0x7 > +#define PWR_DOWN_LN_1_0 0x3 > +#define PWR_DOWN_LN_1 0x2 > +#define PWR_DOWN_LN_3_1 0xa > +#define PWR_DOWN_LN_3_1_0 0xb We define the values of fields shifted to position, so they can be directly OR'd in place. Effectively you could do this: #define PWR_UP_LANES(x) (GENMASK(3, x) << 4) #define PWR_UP_LANES_REVERSE(x) (GENMASK(3 - (x), 0) << 4) and use them like PWR_UP_LANES(intel_dsi->lane_count), saving tens of lines of code. BR, Jani. > +#define PWR_DOWN_LN_MASK 0xf0 > +#define PWR_DOWN_LN_SHIFT 4 > + > #define _PORT_CL1CM_DW9_A 0x162024 > #define _PORT_CL1CM_DW9_BC 0x6C024 > #define IREF0RC_OFFSET_SHIFT 8 -- Jani Nikula, Intel Open Source Graphics Center _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx