1*54fd6939SJiyong Park /* 2*54fd6939SJiyong Park * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved. 3*54fd6939SJiyong Park * 4*54fd6939SJiyong Park * SPDX-License-Identifier: BSD-3-Clause 5*54fd6939SJiyong Park */ 6*54fd6939SJiyong Park 7*54fd6939SJiyong Park #ifndef HIKEY_PRIVATE_H 8*54fd6939SJiyong Park #define HIKEY_PRIVATE_H 9*54fd6939SJiyong Park 10*54fd6939SJiyong Park #include <common/bl_common.h> 11*54fd6939SJiyong Park 12*54fd6939SJiyong Park #define RANDOM_MAX 0x7fffffffffffffff 13*54fd6939SJiyong Park #define RANDOM_MAGIC 0x9a4dbeaf 14*54fd6939SJiyong Park 15*54fd6939SJiyong Park enum { 16*54fd6939SJiyong Park DDR_FREQ_150M = 150 * 1000, 17*54fd6939SJiyong Park DDR_FREQ_266M = 266 * 1000, 18*54fd6939SJiyong Park DDR_FREQ_400M = 400 * 1000, 19*54fd6939SJiyong Park DDR_FREQ_533M = 533 * 1000, 20*54fd6939SJiyong Park DDR_FREQ_800M = 800 * 1000 21*54fd6939SJiyong Park }; 22*54fd6939SJiyong Park 23*54fd6939SJiyong Park struct random_serial_num { 24*54fd6939SJiyong Park uint64_t magic; 25*54fd6939SJiyong Park uint64_t data; 26*54fd6939SJiyong Park char serialno[32]; 27*54fd6939SJiyong Park }; 28*54fd6939SJiyong Park 29*54fd6939SJiyong Park /* 30*54fd6939SJiyong Park * Function and variable prototypes 31*54fd6939SJiyong Park */ 32*54fd6939SJiyong Park void hikey_init_mmu_el1(unsigned long total_base, 33*54fd6939SJiyong Park unsigned long total_size, 34*54fd6939SJiyong Park unsigned long ro_start, 35*54fd6939SJiyong Park unsigned long ro_limit, 36*54fd6939SJiyong Park unsigned long coh_start, 37*54fd6939SJiyong Park unsigned long coh_limit); 38*54fd6939SJiyong Park void hikey_init_mmu_el3(unsigned long total_base, 39*54fd6939SJiyong Park unsigned long total_size, 40*54fd6939SJiyong Park unsigned long ro_start, 41*54fd6939SJiyong Park unsigned long ro_limit, 42*54fd6939SJiyong Park unsigned long coh_start, 43*54fd6939SJiyong Park unsigned long coh_limit); 44*54fd6939SJiyong Park 45*54fd6939SJiyong Park void hikey_ddr_init(unsigned int ddr_freq); 46*54fd6939SJiyong Park void hikey_io_setup(void); 47*54fd6939SJiyong Park 48*54fd6939SJiyong Park void hikey_sp804_init(void); 49*54fd6939SJiyong Park void hikey_gpio_init(void); 50*54fd6939SJiyong Park void hikey_pmussi_init(void); 51*54fd6939SJiyong Park void hikey_hi6553_init(void); 52*54fd6939SJiyong Park void init_mmc0_pll(void); 53*54fd6939SJiyong Park void reset_mmc0_clk(void); 54*54fd6939SJiyong Park void init_media_clk(void); 55*54fd6939SJiyong Park void init_mmc1_pll(void); 56*54fd6939SJiyong Park void reset_mmc1_clk(void); 57*54fd6939SJiyong Park void hikey_mmc_pll_init(void); 58*54fd6939SJiyong Park void hikey_rtc_init(void); 59*54fd6939SJiyong Park 60*54fd6939SJiyong Park int hikey_get_partition_size(const char *arg, int left, char *response); 61*54fd6939SJiyong Park int hikey_get_partition_type(const char *arg, int left, char *response); 62*54fd6939SJiyong Park 63*54fd6939SJiyong Park int hikey_erase(const char *arg); 64*54fd6939SJiyong Park int hikey_flash(const char *arg); 65*54fd6939SJiyong Park int hikey_oem(const char *arg); 66*54fd6939SJiyong Park int hikey_reboot(const char *arg); 67*54fd6939SJiyong Park void hikey_security_setup(void); 68*54fd6939SJiyong Park 69*54fd6939SJiyong Park const char *hikey_init_serialno(void); 70*54fd6939SJiyong Park int hikey_read_serialno(struct random_serial_num *serialno); 71*54fd6939SJiyong Park int hikey_write_serialno(struct random_serial_num *serialno); 72*54fd6939SJiyong Park 73*54fd6939SJiyong Park void init_acpu_dvfs(void); 74*54fd6939SJiyong Park 75*54fd6939SJiyong Park int hikey_set_fip_addr(unsigned int image_id, const char *name); 76*54fd6939SJiyong Park 77*54fd6939SJiyong Park #endif /* HIKEY_PRIVATE_H */ 78