huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 1 | /* |
| 2 | * This file is part of the coreboot project. |
| 3 | * |
| 4 | * Copyright 2015 MediaTek Inc. |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License as published by |
| 8 | * the Free Software Foundation; version 2 of the License. |
| 9 | * |
| 10 | * This program is distributed in the hope that it will be useful, |
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | * GNU General Public License for more details. |
| 14 | */ |
| 15 | |
Shunqian Zheng | d1cec75 | 2016-05-04 16:21:36 +0800 | [diff] [blame] | 16 | #include <bootmode.h> |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 17 | #include <console/console.h> |
Lin Huang | 19eb750 | 2016-03-26 11:50:05 +0800 | [diff] [blame] | 18 | #include <cpu/cpu.h> |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 19 | #include <device/device.h> |
Lin Huang | 19eb750 | 2016-03-26 11:50:05 +0800 | [diff] [blame] | 20 | #include <soc/addressmap.h> |
Julius Werner | 7f96589 | 2016-08-29 15:07:58 -0700 | [diff] [blame] | 21 | #include <soc/clock.h> |
Shunqian Zheng | d1cec75 | 2016-05-04 16:21:36 +0800 | [diff] [blame] | 22 | #include <soc/display.h> |
Lin Huang | f00af58 | 2016-11-15 11:40:58 +0800 | [diff] [blame] | 23 | #include <soc/sdram.h> |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 24 | #include <stddef.h> |
Lin Huang | 19eb750 | 2016-03-26 11:50:05 +0800 | [diff] [blame] | 25 | #include <stdlib.h> |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 26 | #include <string.h> |
| 27 | #include <symbols.h> |
Xing Zheng | 53d6d84 | 2016-12-06 17:12:21 +0800 | [diff] [blame] | 28 | #include <arm-trusted-firmware/plat/rockchip/rk3399/include/shared/bl31_param.h> |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 29 | |
Elyes HAOUAS | f3ca88b | 2018-05-25 09:52:45 +0200 | [diff] [blame^] | 30 | static void soc_read_resources(struct device *dev) |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 31 | { |
Lin Huang | f00af58 | 2016-11-15 11:40:58 +0800 | [diff] [blame] | 32 | ram_resource(dev, 0, (uintptr_t)_dram / KiB, sdram_size_mb() * KiB); |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 33 | } |
| 34 | |
Elyes HAOUAS | f3ca88b | 2018-05-25 09:52:45 +0200 | [diff] [blame^] | 35 | static void soc_init(struct device *dev) |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 36 | { |
Xing Zheng | 53d6d84 | 2016-12-06 17:12:21 +0800 | [diff] [blame] | 37 | /* |
| 38 | * Reserve the whole TZRAM area because it will be marked as secure-only |
| 39 | * by BL31 and can not be accessed by the non-secure kernel. |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 40 | */ |
Xing Zheng | 53d6d84 | 2016-12-06 17:12:21 +0800 | [diff] [blame] | 41 | mmio_resource(dev, 1, (TZRAM_BASE / KiB), (TZRAM_SIZE / KiB)); |
Shunqian Zheng | d1cec75 | 2016-05-04 16:21:36 +0800 | [diff] [blame] | 42 | |
| 43 | if (IS_ENABLED(CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT) && display_init_required()) |
Lin Huang | 152e675 | 2016-10-20 14:22:11 -0700 | [diff] [blame] | 44 | rk_display_init(dev); |
Shunqian Zheng | d1cec75 | 2016-05-04 16:21:36 +0800 | [diff] [blame] | 45 | else |
| 46 | printk(BIOS_INFO, "Display initialization disabled.\n"); |
Julius Werner | 7f96589 | 2016-08-29 15:07:58 -0700 | [diff] [blame] | 47 | |
| 48 | /* We don't need big CPUs, but bring them up as a courtesy to Linux. */ |
| 49 | rkclk_configure_cpu(APLL_600_MHZ, CPU_CLUSTER_BIG); |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 50 | } |
| 51 | |
| 52 | static struct device_operations soc_ops = { |
| 53 | .read_resources = soc_read_resources, |
| 54 | .init = soc_init, |
| 55 | }; |
| 56 | |
Elyes HAOUAS | f3ca88b | 2018-05-25 09:52:45 +0200 | [diff] [blame^] | 57 | static void enable_soc_dev(struct device *dev) |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 58 | { |
| 59 | dev->ops = &soc_ops; |
| 60 | } |
| 61 | |
| 62 | struct chip_operations soc_rockchip_rk3399_ops = { |
Paul Menzel | 3727776 | 2016-07-03 09:45:26 +0200 | [diff] [blame] | 63 | CHIP_NAME("SOC Rockchip RK3399") |
huang lin | c14b54d | 2016-03-02 18:38:40 +0800 | [diff] [blame] | 64 | .enable_dev = enable_soc_dev, |
| 65 | }; |