]> Git Repo - J-linux.git/blob - drivers/gpu/drm/i915/display/intel_lvds_regs.h
Merge tag 'vfs-6.13-rc7.fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs
[J-linux.git] / drivers / gpu / drm / i915 / display / intel_lvds_regs.h
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__ */
This page took 0.031649 seconds and 4 git commands to generate.