diff options
author | Julius Werner <jwerner@chromium.org> | 2021-08-12 16:48:12 -0700 |
---|---|---|
committer | Felix Held <felix-coreboot@felixheld.de> | 2021-08-18 14:21:28 +0000 |
commit | b2a14801916ad9dfa2a6b4fa9ceb6de7d2d03e24 (patch) | |
tree | 75788742da59525637ea977bcb419891f98d0c2e /src/device/mipi/panel-CMN_P097PFG_SSD2858.c | |
parent | 4080e08c09a4f063ed1df280e74fa2b87d304b87 (diff) |
device: Move MIPI panel library from mainboard/google/kukui into common
All boards that are trying to use MIPI panels eventually run into the
problem that they need to store physical parameters and a list of DCS
initialization commands for each panel, and these commands can be very
different (e.g. a large amount of very short commands, a few very large
commands, etc.). Finding a data format to fit all these different cases
efficiently into the same structures keeps being a challenge, and the
Kukui mainboard already once put a lot of effort into designing a
clean, flexible and efficient solution for this. This patch moves that
framework into a common src/device/mipi/ library where it can be used by
other boards as well. (Also, this will hopefully allow us to save some
duplicated work when using the same panel on different boards at some
point.)
Signed-off-by: Julius Werner <jwerner@chromium.org>
Change-Id: I877f2b0c7ab984412b288e2ed27f37cd93c70863
Reviewed-on: https://review.coreboot.org/c/coreboot/+/56965
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Yu-Ping Wu <yupingso@google.com>
Reviewed-by: Hung-Te Lin <hungte@chromium.org>
Diffstat (limited to 'src/device/mipi/panel-CMN_P097PFG_SSD2858.c')
-rw-r--r-- | src/device/mipi/panel-CMN_P097PFG_SSD2858.c | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/src/device/mipi/panel-CMN_P097PFG_SSD2858.c b/src/device/mipi/panel-CMN_P097PFG_SSD2858.c new file mode 100644 index 0000000000..89154b8221 --- /dev/null +++ b/src/device/mipi/panel-CMN_P097PFG_SSD2858.c @@ -0,0 +1,72 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#include <device/mipi_panel.h> + +struct panel_serializable_data P097PFG_SSD2858 = { + .edid = { + .ascii_string = "P097PFG", + .manufacturer_name = "CMN", + .panel_bits_per_color = 8, + .panel_bits_per_pixel = 24, + .mode = { + .pixel_clock = 211660, + .lvds_dual_channel = 0, + .refresh = 60, + .ha = 1536, .hbl = 160, .hso = 140, .hspw = 10, + .va = 2048, .vbl = 32, .vso = 20, .vspw = 2, + .phsync = '-', .pvsync = '-', + .x_mm = 147, .y_mm = 196, + }, + }, + .orientation = LB_FB_ORIENTATION_NORMAL, + .init = { + PANEL_GENERIC(0xff, 0x00), + /* LOCKCNT=0x1f4, MRX=0, POSTDIV=1 (/2} }, MULT=0x49 + * 27 Mhz => 985.5 Mhz */ + PANEL_GENERIC(0x00, 0x08, 0x01, 0xf4, 0x01, 0x49), + /* MTXDIV=1, SYSDIV=3 (=> 4) */ + PANEL_GENERIC(0x00, 0x0c, 0x00, 0x00, 0x00, 0x03), + /* MTXVPF=24bpp, MRXLS=4 lanes, MRXVB=bypass, MRXECC=1, + * MRXEOT=1, MRXEE=1 */ + PANEL_GENERIC(0x00, 0x14, 0x0c, 0x3d, 0x80, 0x0f), + PANEL_GENERIC(0x00, 0x20, 0x15, 0x92, 0x56, 0x7d), + PANEL_GENERIC(0x00, 0x24, 0x00, 0x00, 0x30, 0x00), + + PANEL_GENERIC(0x10, 0x08, 0x01, 0x20, 0x08, 0x45), + PANEL_GENERIC(0x10, 0x1c, 0x00, 0x00, 0x00, 0x00), + PANEL_GENERIC(0x20, 0x0c, 0x00, 0x00, 0x00, 0x04), + /* Pixel clock 985.5 Mhz * 0x49/0x4b = 959 Mhz */ + PANEL_GENERIC(0x20, 0x10, 0x00, 0x4b, 0x00, 0x49), + PANEL_GENERIC(0x20, 0xa0, 0x00, 0x00, 0x00, 0x00), + /* EOT=1, LPE = 0, LSOUT=4 lanes, LPD=25 */ + PANEL_GENERIC(0x60, 0x08, 0x00, 0xd9, 0x00, 0x08), + PANEL_GENERIC(0x60, 0x14, 0x01, 0x00, 0x01, 0x06), + /* DSI0 enable (default: probably not needed) */ + PANEL_GENERIC(0x60, 0x80, 0x00, 0x00, 0x00, 0x0f), + /* DSI1 enable */ + PANEL_GENERIC(0x60, 0xa0, 0x00, 0x00, 0x00, 0x0f), + + /* HSA=0x18, VSA=0x02, HBP=0x50, VBP=0x0c */ + PANEL_GENERIC(0x60, 0x0c, 0x0c, 0x50, 0x02, 0x18), + /* VACT= 0x800 (2048} }, VFP= 0x14, HFP=0x50 */ + PANEL_GENERIC(0x60, 0x10, 0x08, 0x00, 0x14, 0x50), + /* HACT=0x300 (768) */ + PANEL_GENERIC(0x60, 0x84, 0x00, 0x00, 0x03, 0x00), + PANEL_GENERIC(0x60, 0xa4, 0x00, 0x00, 0x03, 0x00), + + /* Take panel out of sleep. */ + PANEL_GENERIC(0xff, 0x01), + PANEL_DCS(0x11), + PANEL_DELAY(120), + PANEL_DCS(0x29), + PANEL_DELAY(20), + PANEL_GENERIC(0xff, 0x00), + + PANEL_DELAY(120), + PANEL_DCS(0x11), + PANEL_DELAY(120), + PANEL_DCS(0x29), + PANEL_DELAY(20), + PANEL_END, + }, +}; |