blob: ff893e0aaa08d1e876047a18f3fc8f11a10b046f [file] [log] [blame]
Rex-BC Chendb8442b2022-07-01 17:37:37 +08001/* SPDX-License-Identifier: GPL-2.0-only */
2
Bo-Chen Chenc1345d62022-09-29 17:32:02 +08003#include <bootmode.h>
Rex-BC Chendb8442b2022-07-01 17:37:37 +08004#include <device/device.h>
Bo-Chen Chenbc18fb32022-09-06 14:41:57 +08005#include <soc/bl31.h>
Andy-ld Lu05c48ec2022-07-15 15:55:29 +08006#include <soc/msdc.h>
Shaocheng Wang1ad10ee2022-07-05 15:42:21 +08007#include <soc/usb.h>
Rex-BC Chendb8442b2022-07-01 17:37:37 +08008
Bo-Chen Chenc1345d62022-09-29 17:32:02 +08009#include "display.h"
Bo-Chen Chenbc18fb32022-09-06 14:41:57 +080010#include "gpio.h"
11
Rex-BC Chendb8442b2022-07-01 17:37:37 +080012static void mainboard_init(struct device *dev)
13{
Bo-Chen Chenc1345d62022-09-29 17:32:02 +080014 if (display_init_required()) {
15 if (configure_display() < 0)
16 printk(BIOS_ERR, "%s: Failed to init display\n", __func__);
17 } else {
18 printk(BIOS_INFO, "%s: Skipped display initialization\n", __func__);
19 }
20
Andy-ld Lu05c48ec2022-07-15 15:55:29 +080021 mtk_msdc_configure_emmc(true);
Liju-Clr Chenaa9bb442022-12-20 15:52:50 +080022
23 if (CONFIG(SDCARD_INIT))
24 mtk_msdc_configure_sdcard();
25
Shaocheng Wang1ad10ee2022-07-05 15:42:21 +080026 setup_usb_host();
Bo-Chen Chenbc18fb32022-09-06 14:41:57 +080027
28 if (CONFIG(ARM64_USE_ARM_TRUSTED_FIRMWARE))
29 register_reset_to_bl31(GPIO_AP_EC_WARM_RST_REQ.id, true);
Rex-BC Chendb8442b2022-07-01 17:37:37 +080030}
31
32static void mainboard_enable(struct device *dev)
33{
34 dev->ops->init = &mainboard_init;
35}
36
37struct chip_operations mainboard_ops = {
38 .name = CONFIG_MAINBOARD_PART_NUMBER,
39 .enable_dev = mainboard_enable,
40};