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