[Intel-gfx] [PATCH 05/20] drm/i915/icl: Define PORT_CL_DW_10 register
Jani Nikula
jani.nikula at intel.com
Fri Jun 29 13:53:44 UTC 2018
On Fri, 15 Jun 2018, Madhav Chauhan <madhav.chauhan at intel.com> 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 at intel.com>
> ---
> 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
More information about the Intel-gfx
mailing list