1/* SPDX-License-Identifier: MIT */
2/*
3 * Copyright �� 2023 Intel Corporation
4 */
5
6#ifndef __INTEL_LVDS_REGS_H__
7#define __INTEL_LVDS_REGS_H__
8
9#include "intel_display_reg_defs.h"
10
11/* LVDS port control */
12#define LVDS		_MMIO(0x61180)
13/*
14 * Enables the LVDS port.  This bit must be set before DPLLs are enabled, as
15 * the DPLL semantics change when the LVDS is assigned to that pipe.
16 */
17#define   LVDS_PORT_EN			REG_BIT(31)
18/* Selects pipe B for LVDS data.  Must be set on pre-965. */
19#define   LVDS_PIPE_SEL_MASK		REG_BIT(30)
20#define   LVDS_PIPE_SEL(pipe)		REG_FIELD_PREP(LVDS_PIPE_SEL_MASK, (pipe))
21#define   LVDS_PIPE_SEL_MASK_CPT	REG_GENMASK(30, 29)
22#define   LVDS_PIPE_SEL_CPT(pipe)	REG_FIELD_PREP(LVDS_PIPE_SEL_MASK_CPT, (pipe))
23/* LVDS dithering flag on 965/g4x platform */
24#define   LVDS_ENABLE_DITHER		REG_BIT(25)
25/* LVDS sync polarity flags. Set to invert (i.e. negative) */
26#define   LVDS_VSYNC_POLARITY		REG_BIT(21)
27#define   LVDS_HSYNC_POLARITY		REG_BIT(20)
28
29/* Enable border for unscaled (or aspect-scaled) display */
30#define   LVDS_BORDER_ENABLE		REG_BIT(15)
31/*
32 * Enables the A0-A2 data pairs and CLKA, containing 18 bits of color data per
33 * pixel.
34 */
35#define   LVDS_A0A2_CLKA_POWER_MASK	REG_GENMASK(9, 8)
36#define   LVDS_A0A2_CLKA_POWER_DOWN	REG_FIELD_PREP(LVDS_A0A2_CLKA_POWER_MASK, 0)
37#define   LVDS_A0A2_CLKA_POWER_UP	REG_FIELD_PREP(LVDS_A0A2_CLKA_POWER_MASK, 3)
38/*
39 * Controls the A3 data pair, which contains the additional LSBs for 24 bit
40 * mode.  Only enabled if LVDS_A0A2_CLKA_POWER_UP also indicates it should be
41 * on.
42 */
43#define   LVDS_A3_POWER_MASK		REG_GENMASK(7, 6)
44#define   LVDS_A3_POWER_DOWN		REG_FIELD_PREP(LVDS_A3_POWER_MASK, 0)
45#define   LVDS_A3_POWER_UP		REG_FIELD_PREP(LVDS_A3_POWER_MASK, 3)
46/*
47 * Controls the CLKB pair.  This should only be set when LVDS_B0B3_POWER_UP
48 * is set.
49 */
50#define   LVDS_CLKB_POWER_MASK		REG_GENMASK(5, 4)
51#define   LVDS_CLKB_POWER_DOWN		REG_FIELD_PREP(LVDS_CLKB_POWER_MASK, 0)
52#define   LVDS_CLKB_POWER_UP		REG_FIELD_PREP(LVDS_CLKB_POWER_MASK, 3)
53/*
54 * Controls the B0-B3 data pairs.  This must be set to match the DPLL p2
55 * setting for whether we are in dual-channel mode.  The B3 pair will
56 * additionally only be powered up when LVDS_A3_POWER_UP is set.
57 */
58#define   LVDS_B0B3_POWER_MASK		REG_GENMASK(3, 2)
59#define   LVDS_B0B3_POWER_DOWN		REG_FIELD_PREP(LVDS_B0B3_POWER_MASK, 0)
60#define   LVDS_B0B3_POWER_UP		REG_FIELD_PREP(LVDS_B0B3_POWER_MASK, 3)
61
62#define PCH_LVDS	_MMIO(0xe1180)
63#define   LVDS_DETECTED			REG_BIT(1)
64
65#endif /* __INTEL_LVDS_REGS_H__ */
66