mb/google/corsola: Use common mtk_display_init()

TEST=check FW screen on Steelix, Tentacruel and Starmie

Change-Id: I429218d59389a6ab86b522dd597c07fa5b8ea821
Signed-off-by: Yidi Lin <yidilin@chromium.org>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/79777
Reviewed-by: Yu-Ping Wu <yupingso@google.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Yidi Lin 2024-01-02 17:33:00 +08:00 committed by Felix Held
parent ba604b558e
commit cb7c4fdbd6
13 changed files with 110 additions and 180 deletions

View File

@ -19,8 +19,8 @@ romstage-y += sdram_configs.c
ramstage-y += memlayout.ld ramstage-y += memlayout.ld
ramstage-y += boardid.c ramstage-y += boardid.c
ramstage-y += chromeos.c ramstage-y += chromeos.c
ramstage-y += display.c
ramstage-y += mainboard.c ramstage-y += mainboard.c
ramstage-y += panel.c
ramstage-y += panel_anx7625.c ramstage-y += panel_anx7625.c
ramstage-y += panel_ps8640.c ramstage-y += panel_ps8640.c
ramstage-y += regulator.c ramstage-y += regulator.c

View File

@ -6,7 +6,7 @@
#include <ec/google/chromeec/ec.h> #include <ec/google/chromeec/ec.h>
#include <soc/auxadc.h> #include <soc/auxadc.h>
#include "display.h" #include "panel.h"
/* board_id is provided by ec/google/chromeec/ec_boardid.c */ /* board_id is provided by ec/google/chromeec/ec_boardid.c */

View File

@ -1,131 +0,0 @@
/* SPDX-License-Identifier: GPL-2.0-only */
#include <boardid.h>
#include <cbfs.h>
#include <console/console.h>
#include <device/i2c_simple.h>
#include <edid.h>
#include <gpio.h>
#include <soc/ddp.h>
#include <soc/dsi.h>
#include <soc/gpio_common.h>
#include <soc/mtcmos.h>
#include "display.h"
#include "gpio.h"
void aw37503_init(unsigned int bus)
{
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x00, 0x14, 0x1F, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x01, 0x14, 0x1F, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x21, 0x4C, 0xFF, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x03, 0x43, 0xFF, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x21, 0x00, 0xFF, 0);
}
bool is_pmic_aw37503(unsigned int bus)
{
u8 vendor_id;
return (!i2c_read_field(bus, PMIC_AW37503_SLAVE,
0x04, &vendor_id, 0x0F, 0) && vendor_id == 0x01);
}
static void backlight_control(void)
{
/* Disable backlight before turning on bridge */
gpio_output(GPIO_AP_EDP_BKLTEN, 0);
gpio_output(GPIO_BL_PWM_1V8, 0);
/* For staryu variants, GPIO_EN_PP3300_DISP_X is controlled in
mipi_panel_power_on() */
if (!CONFIG(BOARD_GOOGLE_STARYU_COMMON))
gpio_output(GPIO_EN_PP3300_DISP_X, 1);
}
struct panel_description *get_panel_from_cbfs(struct panel_description *desc)
{
char cbfs_name[64];
static union {
u8 raw[4 * 1024];
struct panel_serializable_data s;
} buffer;
if (!desc->name)
return NULL;
snprintf(cbfs_name, sizeof(cbfs_name), "panel-%s", desc->name);
if (cbfs_load(cbfs_name, buffer.raw, sizeof(buffer)))
desc->s = &buffer.s;
else
printk(BIOS_ERR, "Missing %s in CBFS.\n", cbfs_name);
return desc->s ? desc : NULL;
}
static struct panel_description *get_active_panel(void)
{
/* Board-specific exceptions */
if (CONFIG(BOARD_GOOGLE_STEELIX) && board_id() < 2) /* Early builds use PS8640 */
return get_ps8640_description();
if (CONFIG(DRIVER_ANALOGIX_ANX7625))
return get_anx7625_description();
if (CONFIG(DRIVER_PARADE_PS8640))
return get_ps8640_description();
/* MIPI panels */
return get_panel_description();
}
int configure_display(void)
{
/* Set up backlight control pins as output pin and power-off by default */
backlight_control();
const struct panel_description *panel = get_active_panel();
if (!panel)
return -1;
printk(BIOS_INFO, "%s: Starting display init\n", __func__);
if (panel->power_on)
panel->power_on();
struct edid edid = panel->s->edid;
const char *name = edid.ascii_string;
if (name[0] == '\0')
name = "unknown name";
printk(BIOS_INFO, "%s: '%s %s' %dx%d@%dHz\n", __func__,
edid.manufacturer_name, name, edid.mode.ha, edid.mode.va,
edid.mode.refresh);
mtcmos_display_power_on();
mtcmos_protect_display_bus();
edid_set_framebuffer_bits_per_pixel(&edid, 32, 0);
mtk_ddp_init();
u32 mipi_dsi_flags = (MIPI_DSI_MODE_VIDEO |
MIPI_DSI_MODE_VIDEO_SYNC_PULSE |
MIPI_DSI_MODE_LPM |
MIPI_DSI_MODE_EOT_PACKET);
if (mtk_dsi_init(mipi_dsi_flags, MIPI_DSI_FMT_RGB888, 4, &edid,
panel->s->init) < 0) {
printk(BIOS_ERR, "%s: Failed in DSI init\n", __func__);
return -1;
}
if (panel->post_power_on && panel->post_power_on(BRIDGE_I2C, &edid) < 0) {
printk(BIOS_ERR, "%s: Failed to post power on bridge\n", __func__);
return -1;
}
mtk_ddp_mode_set(&edid);
struct fb_info *info = fb_new_framebuffer_info_from_edid(&edid,
(uintptr_t)0);
if (info)
fb_set_orientation(info, panel->orientation);
return 0;
}

View File

@ -6,13 +6,14 @@
#include <fw_config.h> #include <fw_config.h>
#include <gpio.h> #include <gpio.h>
#include <soc/bl31.h> #include <soc/bl31.h>
#include <soc/display.h>
#include <soc/i2c.h> #include <soc/i2c.h>
#include <soc/msdc.h> #include <soc/msdc.h>
#include <soc/spm.h> #include <soc/spm.h>
#include <soc/usb.h> #include <soc/usb.h>
#include "display.h"
#include "gpio.h" #include "gpio.h"
#include "panel.h"
static void configure_alc1019(void) static void configure_alc1019(void)
{ {
@ -65,7 +66,7 @@ static void mainboard_init(struct device *dev)
register_reset_to_bl31(GPIO_RESET.id, true); register_reset_to_bl31(GPIO_RESET.id, true);
if (display_init_required()) { if (display_init_required()) {
if (configure_display() < 0) if (mtk_display_init() < 0)
printk(BIOS_ERR, "%s: Failed to init display\n", __func__); printk(BIOS_ERR, "%s: Failed to init display\n", __func__);
} else { } else {
if (CONFIG(BOARD_GOOGLE_STARYU_COMMON)) { if (CONFIG(BOARD_GOOGLE_STARYU_COMMON)) {

View File

@ -0,0 +1,54 @@
/* SPDX-License-Identifier: GPL-2.0-only */
#include <boardid.h>
#include <cbfs.h>
#include <console/console.h>
#include <device/i2c_simple.h>
#include <edid.h>
#include <gpio.h>
#include <soc/ddp.h>
#include <soc/dsi.h>
#include <soc/gpio_common.h>
#include <soc/mtcmos.h>
#include "gpio.h"
#include "panel.h"
void aw37503_init(unsigned int bus)
{
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x00, 0x14, 0x1F, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x01, 0x14, 0x1F, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x21, 0x4C, 0xFF, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x03, 0x43, 0xFF, 0);
i2c_write_field(bus, PMIC_AW37503_SLAVE, 0x21, 0x00, 0xFF, 0);
}
bool is_pmic_aw37503(unsigned int bus)
{
u8 vendor_id;
return (!i2c_read_field(bus, PMIC_AW37503_SLAVE,
0x04, &vendor_id, 0x0F, 0) && vendor_id == 0x01);
}
void backlight_control(void)
{
/* Set up backlight control pins as output pin and power-off by default */
gpio_output(GPIO_AP_EDP_BKLTEN, 0);
gpio_output(GPIO_BL_PWM_1V8, 0);
}
struct panel_description *get_active_panel(void)
{
/* Board-specific exceptions */
if (CONFIG(BOARD_GOOGLE_STEELIX) && board_id() < 2) /* Early builds use PS8640 */
return get_ps8640_description();
if (CONFIG(DRIVER_ANALOGIX_ANX7625))
return get_anx7625_description();
if (CONFIG(DRIVER_PARADE_PS8640))
return get_ps8640_description();
/* MIPI panels */
return get_panel_description();
}

View File

@ -3,26 +3,17 @@
#ifndef __MAINBOARD_GOOGLE_CORSOLA_DISPLAY_H__ #ifndef __MAINBOARD_GOOGLE_CORSOLA_DISPLAY_H__
#define __MAINBOARD_GOOGLE_CORSOLA_DISPLAY_H__ #define __MAINBOARD_GOOGLE_CORSOLA_DISPLAY_H__
#include <edid.h> #include <soc/display.h>
#include <mipi/panel.h>
#include <soc/i2c.h> #include <soc/i2c.h>
#define BRIDGE_I2C I2C0 #define BRIDGE_I2C I2C0
#define PMIC_AW37503_SLAVE 0x3E #define PMIC_AW37503_SLAVE 0x3E
#define PMIC_I2C_BUS I2C6 #define PMIC_I2C_BUS I2C6
struct panel_description {
void (*power_on)(void); /* Callback to turn on panel */
int (*post_power_on)(u8 i2c_bus, struct edid *edid);
const char *name; /* Panel name in CBFS */
struct panel_serializable_data *s;
enum lb_fb_orientation orientation;
};
void aw37503_init(unsigned int bus); void aw37503_init(unsigned int bus);
bool is_pmic_aw37503(unsigned int bus); bool is_pmic_aw37503(unsigned int bus);
int configure_display(void);
uint32_t panel_id(void); uint32_t panel_id(void);
void backlight_control(void);
/* Return the mipi panel description from given panel id */ /* Return the mipi panel description from given panel id */
struct panel_description *get_panel_description(void); struct panel_description *get_panel_description(void);
@ -33,7 +24,4 @@ struct panel_description *get_anx7625_description(void);
/* Return the PS8640 bridge description */ /* Return the PS8640 bridge description */
struct panel_description *get_ps8640_description(void); struct panel_description *get_ps8640_description(void);
/* Load panel serializable data from CBFS */
struct panel_description *get_panel_from_cbfs(struct panel_description *desc);
#endif #endif

View File

@ -7,8 +7,8 @@
#include <gpio.h> #include <gpio.h>
#include <soc/i2c.h> #include <soc/i2c.h>
#include "display.h"
#include "gpio.h" #include "gpio.h"
#include "panel.h"
static void bridge_anx7625_power_on(void) static void bridge_anx7625_power_on(void)
{ {
@ -23,39 +23,42 @@ static void bridge_anx7625_power_on(void)
gpio_output(GPIO_EDPBRDG_RST_L, 1); gpio_output(GPIO_EDPBRDG_RST_L, 1);
} }
static int bridge_anx7625_get_edid(u8 i2c_bus, struct edid *edid) static int bridge_anx7625_get_edid(struct edid *edid)
{ {
if (anx7625_init(i2c_bus) < 0) { if (anx7625_init(BRIDGE_I2C) < 0) {
printk(BIOS_ERR, "%s: Can't init ANX7625 bridge\n", __func__); printk(BIOS_ERR, "%s: Can't init ANX7625 bridge\n", __func__);
return -1; return -1;
} }
if (anx7625_dp_get_edid(i2c_bus, edid) < 0) { if (anx7625_dp_get_edid(BRIDGE_I2C, edid) < 0) {
printk(BIOS_ERR, "%s: Can't get panel's edid\n", __func__); printk(BIOS_ERR, "%s: Can't get panel's edid\n", __func__);
return -1; return -1;
} }
return 0; return 0;
} }
static int bridge_anx7625_post_power_on(u8 i2c_bus, struct edid *edid) static int bridge_anx7625_post_power_on(const struct edid *edid)
{ {
return anx7625_dp_start(i2c_bus, edid); return anx7625_dp_start(BRIDGE_I2C, edid);
} }
static struct panel_serializable_data anx7625_data; static void panel_power_on(void)
{
/* Turn on the panel */
gpio_output(GPIO_EN_PP3300_DISP_X, 1);
bridge_anx7625_power_on();
}
static struct panel_description anx7625_bridge = { static struct panel_description anx7625_bridge = {
.s = &anx7625_data, .configure_backlight = backlight_control,
.power_on = panel_power_on,
.get_edid = bridge_anx7625_get_edid,
.post_power_on = bridge_anx7625_post_power_on, .post_power_on = bridge_anx7625_post_power_on,
.disp_path = DISP_PATH_MIPI,
.orientation = LB_FB_ORIENTATION_NORMAL, .orientation = LB_FB_ORIENTATION_NORMAL,
}; };
struct panel_description *get_anx7625_description(void) struct panel_description *get_anx7625_description(void)
{ {
mtk_i2c_bus_init(BRIDGE_I2C, I2C_SPEED_FAST); mtk_i2c_bus_init(BRIDGE_I2C, I2C_SPEED_FAST);
bridge_anx7625_power_on();
if (bridge_anx7625_get_edid(BRIDGE_I2C, &anx7625_bridge.s->edid) < 0) {
printk(BIOS_ERR, "Can't get panel's edid\n");
return NULL;
}
return &anx7625_bridge; return &anx7625_bridge;
} }

View File

@ -8,8 +8,8 @@
#include <soc/i2c.h> #include <soc/i2c.h>
#include <soc/regulator.h> #include <soc/regulator.h>
#include "display.h"
#include "gpio.h" #include "gpio.h"
#include "panel.h"
static void bridge_ps8640_power_on(void) static void bridge_ps8640_power_on(void)
{ {
@ -45,35 +45,38 @@ static void bridge_ps8640_power_on(void)
gpio_output(GPIO_EDPBRDG_RST_L, 1); gpio_output(GPIO_EDPBRDG_RST_L, 1);
} }
static int bridge_ps8640_get_edid(u8 i2c_bus, struct edid *edid) static void panel_power_on(void)
{
/* Turn on the panel */
gpio_output(GPIO_EN_PP3300_DISP_X, 1);
bridge_ps8640_power_on();
}
static int bridge_ps8640_get_edid(struct edid *edid)
{ {
const u8 chip = 0x8; const u8 chip = 0x8;
if (ps8640_init(i2c_bus, chip) < 0) { if (ps8640_init(BRIDGE_I2C, chip) < 0) {
printk(BIOS_ERR, "%s: Can't init PS8640 bridge\n", __func__); printk(BIOS_ERR, "%s: Can't init PS8640 bridge\n", __func__);
return -1; return -1;
} }
if (ps8640_get_edid(i2c_bus, chip, edid) < 0) { if (ps8640_get_edid(BRIDGE_I2C, chip, edid) < 0) {
printk(BIOS_ERR, "%s: Can't get panel's edid\n", __func__); printk(BIOS_ERR, "%s: Can't get panel's edid\n", __func__);
return -1; return -1;
} }
return 0; return 0;
} }
static struct panel_serializable_data ps8640_data;
static struct panel_description ps8640_bridge = { static struct panel_description ps8640_bridge = {
.s = &ps8640_data, .configure_backlight = backlight_control,
.power_on = panel_power_on,
.get_edid = bridge_ps8640_get_edid,
.disp_path = DISP_PATH_MIPI,
.orientation = LB_FB_ORIENTATION_NORMAL, .orientation = LB_FB_ORIENTATION_NORMAL,
}; };
struct panel_description *get_ps8640_description(void) struct panel_description *get_ps8640_description(void)
{ {
mtk_i2c_bus_init(BRIDGE_I2C, I2C_SPEED_FAST); mtk_i2c_bus_init(BRIDGE_I2C, I2C_SPEED_FAST);
bridge_ps8640_power_on();
if (bridge_ps8640_get_edid(BRIDGE_I2C, &ps8640_bridge.s->edid) < 0) {
printk(BIOS_ERR, "Can't get panel's edid\n");
return NULL;
}
return &ps8640_bridge; return &ps8640_bridge;
} }

View File

@ -6,8 +6,8 @@
#include <soc/regulator.h> #include <soc/regulator.h>
#include <soc/tps65132s.h> #include <soc/tps65132s.h>
#include "display.h"
#include "gpio.h" #include "gpio.h"
#include "panel.h"
static void mipi_panel_power_on(void) static void mipi_panel_power_on(void)
{ {
@ -51,20 +51,26 @@ static struct panel_description starmie_panels[] = {
/* K&D panel vendor and ILI9882T chip, /* K&D panel vendor and ILI9882T chip,
K&D and STA panel are identical except manufacturer_name. */ K&D and STA panel are identical except manufacturer_name. */
[6] = { [6] = {
.configure_backlight = backlight_control,
.power_on = mipi_panel_power_on, .power_on = mipi_panel_power_on,
.name = "STA_ILI9882T", .name = "STA_ILI9882T",
.disp_path = DISP_PATH_MIPI,
.orientation = LB_FB_ORIENTATION_LEFT_UP, .orientation = LB_FB_ORIENTATION_LEFT_UP,
}, },
/* STA panel vendor and ILI9882T chip */ /* STA panel vendor and ILI9882T chip */
[9] = { [9] = {
.configure_backlight = backlight_control,
.power_on = mipi_panel_power_on, .power_on = mipi_panel_power_on,
.name = "STA_ILI9882T", .name = "STA_ILI9882T",
.disp_path = DISP_PATH_MIPI,
.orientation = LB_FB_ORIENTATION_LEFT_UP, .orientation = LB_FB_ORIENTATION_LEFT_UP,
}, },
/* STA panel vendor and HIMAX83102_J02 chip */ /* STA panel vendor and HIMAX83102_J02 chip */
[10] = { [10] = {
.configure_backlight = backlight_control,
.power_on = mipi_panel_power_on, .power_on = mipi_panel_power_on,
.name = "STA_HIMAX83102_J02", .name = "STA_HIMAX83102_J02",
.disp_path = DISP_PATH_MIPI,
.orientation = LB_FB_ORIENTATION_LEFT_UP, .orientation = LB_FB_ORIENTATION_LEFT_UP,
}, },
}; };
@ -75,5 +81,5 @@ struct panel_description *get_panel_description(void)
if (id >= ARRAY_SIZE(starmie_panels)) if (id >= ARRAY_SIZE(starmie_panels))
return NULL; return NULL;
return get_panel_from_cbfs(&starmie_panels[id]); return &starmie_panels[id];
} }

View File

@ -37,6 +37,12 @@ static struct panel_serializable_data *get_mipi_cmd_from_cbfs(struct panel_descr
return NULL; return NULL;
} }
__weak int mtk_edp_init(struct edid *edid)
{
printk(BIOS_WARNING, "%s: Not supported\n", __func__);
return -1;
}
int mtk_display_init(void) int mtk_display_init(void)
{ {
struct edid edid; struct edid edid;

View File

@ -38,6 +38,7 @@ ramstage-$(CONFIG_ARM64_USE_ARM_TRUSTED_FIRMWARE) += ../common/bl31.c
ramstage-y += ../common/ddp.c ddp.c ramstage-y += ../common/ddp.c ddp.c
ramstage-y += ../common/devapc.c devapc.c ramstage-y += ../common/devapc.c devapc.c
ramstage-y += ../common/dfd.c ramstage-y += ../common/dfd.c
ramstage-y += ../common/display.c
ramstage-y += ../common/dsi.c ../common/mtk_mipi_dphy.c ramstage-y += ../common/dsi.c ../common/mtk_mipi_dphy.c
ramstage-y += ../common/emi.c ramstage-y += ../common/emi.c
ramstage-y += ../common/mcu.c ramstage-y += ../common/mcu.c
@ -53,6 +54,7 @@ ramstage-y += ../common/tps65132s.c
ramstage-y += ../common/usb.c usb.c ramstage-y += ../common/usb.c usb.c
CPPFLAGS_common += -Isrc/soc/mediatek/mt8186/include CPPFLAGS_common += -Isrc/soc/mediatek/mt8186/include
CPPFLAGS_common += -Isrc/soc/mediatek/common/dp/include
CPPFLAGS_common += -Isrc/soc/mediatek/common/include CPPFLAGS_common += -Isrc/soc/mediatek/common/include
BL31_MAKEARGS += PLAT=mt8186 BL31_MAKEARGS += PLAT=mt8186

View File

@ -141,7 +141,7 @@ void mtk_ddp_init(void)
write32((void *)(SMI_LARB0 + SMI_LARB_PORT_L0_OVL_RDMA0), 0); write32((void *)(SMI_LARB0 + SMI_LARB_PORT_L0_OVL_RDMA0), 0);
} }
void mtk_ddp_mode_set(const struct edid *edid) void mtk_ddp_mode_set(const struct edid *edid, enum disp_path_sel path)
{ {
u32 fmt = OVL_INFMT_RGBA8888; u32 fmt = OVL_INFMT_RGBA8888;
u32 bpp = edid->framebuffer_bits_per_pixel / 8; u32 bpp = edid->framebuffer_bits_per_pixel / 8;

View File

@ -11,6 +11,7 @@
#include <device/mmio.h> #include <device/mmio.h>
#include <soc/addressmap.h> #include <soc/addressmap.h>
#include <soc/ddp_common.h> #include <soc/ddp_common.h>
#include <soc/display.h>
#include <types.h> #include <types.h>
#define SMI_LARB_PORT_L0_OVL_RDMA0 0x388 #define SMI_LARB_PORT_L0_OVL_RDMA0 0x388
@ -254,7 +255,4 @@ static struct disp_gamma_regs *const disp_gamma = (void *)DISP_GAMMA0_BASE;
static struct disp_postmask_regs *const disp_postmask = (void *)DISP_POSTMASK0_BASE; static struct disp_postmask_regs *const disp_postmask = (void *)DISP_POSTMASK0_BASE;
static struct disp_dither_regs *const disp_dither = (void *)DISP_DITHER0_BASE; static struct disp_dither_regs *const disp_dither = (void *)DISP_DITHER0_BASE;
void mtk_ddp_init(void);
void mtk_ddp_mode_set(const struct edid *edid);
#endif #endif