xref: /rk3399_ARM-atf/plat/hisilicon/hikey/hikey_private.h (revision 3d5d9f5aa87b3468fb931562f46c93e4840da8c1)
108b167e9SHaojian Zhuang /*
208b167e9SHaojian Zhuang  * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved.
308b167e9SHaojian Zhuang  *
408b167e9SHaojian Zhuang  * SPDX-License-Identifier: BSD-3-Clause
508b167e9SHaojian Zhuang  */
608b167e9SHaojian Zhuang 
708b167e9SHaojian Zhuang #ifndef __HIKEY_PRIVATE_H__
808b167e9SHaojian Zhuang #define __HIKEY_PRIVATE_H__
908b167e9SHaojian Zhuang 
1008b167e9SHaojian Zhuang #include <bl_common.h>
1108b167e9SHaojian Zhuang 
1208b167e9SHaojian Zhuang #define RANDOM_MAX		0x7fffffffffffffff
1308b167e9SHaojian Zhuang #define RANDOM_MAGIC		0x9a4dbeaf
1408b167e9SHaojian Zhuang 
1508b167e9SHaojian Zhuang struct random_serial_num {
1608b167e9SHaojian Zhuang 	uint64_t	magic;
1708b167e9SHaojian Zhuang 	uint64_t	data;
1808b167e9SHaojian Zhuang 	char		serialno[32];
1908b167e9SHaojian Zhuang };
2008b167e9SHaojian Zhuang 
2108b167e9SHaojian Zhuang /*
2208b167e9SHaojian Zhuang  * Function and variable prototypes
2308b167e9SHaojian Zhuang  */
2408b167e9SHaojian Zhuang void hikey_init_mmu_el1(unsigned long total_base,
2508b167e9SHaojian Zhuang 			unsigned long total_size,
2608b167e9SHaojian Zhuang 			unsigned long ro_start,
2708b167e9SHaojian Zhuang 			unsigned long ro_limit,
2808b167e9SHaojian Zhuang 			unsigned long coh_start,
2908b167e9SHaojian Zhuang 			unsigned long coh_limit);
3008b167e9SHaojian Zhuang void hikey_init_mmu_el3(unsigned long total_base,
3108b167e9SHaojian Zhuang 			unsigned long total_size,
3208b167e9SHaojian Zhuang 			unsigned long ro_start,
3308b167e9SHaojian Zhuang 			unsigned long ro_limit,
3408b167e9SHaojian Zhuang 			unsigned long coh_start,
3508b167e9SHaojian Zhuang 			unsigned long coh_limit);
3608b167e9SHaojian Zhuang 
3708b167e9SHaojian Zhuang void hikey_ddr_init(void);
3808b167e9SHaojian Zhuang void hikey_io_setup(void);
3908b167e9SHaojian Zhuang 
4008b167e9SHaojian Zhuang int hikey_get_partition_size(const char *arg, int left, char *response);
4108b167e9SHaojian Zhuang int hikey_get_partition_type(const char *arg, int left, char *response);
4208b167e9SHaojian Zhuang 
4308b167e9SHaojian Zhuang int hikey_erase(const char *arg);
4408b167e9SHaojian Zhuang int hikey_flash(const char *arg);
4508b167e9SHaojian Zhuang int hikey_oem(const char *arg);
4608b167e9SHaojian Zhuang int hikey_reboot(const char *arg);
47*3d5d9f5aSJerome Forissier void hikey_security_setup(void);
4808b167e9SHaojian Zhuang 
4908b167e9SHaojian Zhuang const char *hikey_init_serialno(void);
5008b167e9SHaojian Zhuang int hikey_read_serialno(struct random_serial_num *serialno);
5108b167e9SHaojian Zhuang int hikey_write_serialno(struct random_serial_num *serialno);
5208b167e9SHaojian Zhuang 
5308b167e9SHaojian Zhuang void init_acpu_dvfs(void);
5408b167e9SHaojian Zhuang 
5508b167e9SHaojian Zhuang #endif /* __HIKEY_PRIVATE_H__ */
56