Rex-BC Chen | 73e6b8e | 2021-11-02 10:31:53 +0800 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
| 2 | |
| 3 | #include <device/device.h> |
| 4 | #include <soc/emi.h> |
Rex-BC Chen | f8eed65 | 2021-11-11 15:50:42 +0800 | [diff] [blame^] | 5 | #include <soc/mmu_operations.h> |
Rex-BC Chen | 73e6b8e | 2021-11-02 10:31:53 +0800 | [diff] [blame] | 6 | #include <symbols.h> |
| 7 | |
| 8 | static void soc_read_resources(struct device *dev) |
| 9 | { |
| 10 | ram_resource(dev, 0, (uintptr_t)_dram / KiB, sdram_size() / KiB); |
| 11 | } |
| 12 | |
| 13 | static void soc_init(struct device *dev) |
| 14 | { |
Rex-BC Chen | f8eed65 | 2021-11-11 15:50:42 +0800 | [diff] [blame^] | 15 | mtk_mmu_disable_l2c_sram(); |
Rex-BC Chen | 73e6b8e | 2021-11-02 10:31:53 +0800 | [diff] [blame] | 16 | } |
| 17 | |
| 18 | static struct device_operations soc_ops = { |
| 19 | .read_resources = soc_read_resources, |
| 20 | .init = soc_init, |
| 21 | }; |
| 22 | |
| 23 | static void enable_soc_dev(struct device *dev) |
| 24 | { |
| 25 | dev->ops = &soc_ops; |
| 26 | } |
| 27 | |
| 28 | struct chip_operations soc_mediatek_mt8186_ops = { |
| 29 | CHIP_NAME("SOC Mediatek MT8186") |
| 30 | .enable_dev = enable_soc_dev, |
| 31 | }; |