summaryrefslogtreecommitdiff
path: root/src/soc/mediatek/mt8188/soc.c
diff options
context:
space:
mode:
authorRex-BC Chen <rex-bc.chen@mediatek.com>2022-05-24 19:45:59 +0800
committerHung-Te Lin <hungte@chromium.org>2022-07-04 08:35:53 +0000
commit3f83c6ff858b53f0fd9ebb76ebaf9292ee5e222f (patch)
tree94362256aee11f5ead38ff166946bdf649cee0c7 /src/soc/mediatek/mt8188/soc.c
parente88bee7219c215120624a07b681a7e0ccc646411 (diff)
soc/mediatek/mt8188: Add a stub implementation of the MT8188 SoC
Add new folder and basic drivers for Mediatek SoC 'MT8188'. Difference of modules including in this patch between MT8188 and existing SoCs: Timer: Similar to MT8195 and MT8186, MT8188 uses v2 timer. EMI/PLL/SPI: Different from existing SoCs. The implementation is based on these files: MT8188G_Application Processor Technical Brief_v0.4.pdf MT8188G_Functional Specification v0.4.pdf MT8188 Application Processor Registers-1.pdf MT8188 Application Processor Registers-2.pdf TEST=saw the coreboot uart log to bootblock BUG=b:233720142 Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com> Change-Id: I3320f3d49a9b9ed781ceb812e4341e379db4ac20 Reviewed-on: https://review.coreboot.org/c/coreboot/+/65585 Reviewed-by: Yu-Ping Wu <yupingso@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Yidi Lin <yidilin@chromium.org>
Diffstat (limited to 'src/soc/mediatek/mt8188/soc.c')
-rw-r--r--src/soc/mediatek/mt8188/soc.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/soc/mediatek/mt8188/soc.c b/src/soc/mediatek/mt8188/soc.c
new file mode 100644
index 0000000000..cce21a0b0c
--- /dev/null
+++ b/src/soc/mediatek/mt8188/soc.c
@@ -0,0 +1,30 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+
+#include <device/device.h>
+#include <soc/emi.h>
+#include <symbols.h>
+
+static void soc_read_resources(struct device *dev)
+{
+ ram_range(dev, 0, (uintptr_t)_dram, sdram_size());
+}
+
+static void soc_init(struct device *dev)
+{
+}
+
+static struct device_operations soc_ops = {
+ .read_resources = soc_read_resources,
+ .set_resources = noop_set_resources,
+ .init = soc_init,
+};
+
+static void enable_soc_dev(struct device *dev)
+{
+ dev->ops = &soc_ops;
+}
+
+struct chip_operations soc_mediatek_mt8188_ops = {
+ CHIP_NAME("SOC Mediatek MT8188")
+ .enable_dev = enable_soc_dev,
+};