| 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 |  | 
|---|