hikey_private.h 1.81 KB
Newer Older
Haojian Zhuang's avatar
Haojian Zhuang committed
1
2
3
4
5
6
/*
 * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

7
8
#ifndef HIKEY_PRIVATE_H
#define HIKEY_PRIVATE_H
Haojian Zhuang's avatar
Haojian Zhuang committed
9
10
11
12
13
14

#include <bl_common.h>

#define RANDOM_MAX		0x7fffffffffffffff
#define RANDOM_MAGIC		0x9a4dbeaf

15
16
17
18
19
20
21
22
enum {
	DDR_FREQ_150M = 150 * 1000,
	DDR_FREQ_266M = 266 * 1000,
	DDR_FREQ_400M = 400 * 1000,
	DDR_FREQ_533M = 533 * 1000,
	DDR_FREQ_800M = 800 * 1000
};

Haojian Zhuang's avatar
Haojian Zhuang committed
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
struct random_serial_num {
	uint64_t	magic;
	uint64_t	data;
	char		serialno[32];
};

/*
 * Function and variable prototypes
 */
void hikey_init_mmu_el1(unsigned long total_base,
			unsigned long total_size,
			unsigned long ro_start,
			unsigned long ro_limit,
			unsigned long coh_start,
			unsigned long coh_limit);
void hikey_init_mmu_el3(unsigned long total_base,
			unsigned long total_size,
			unsigned long ro_start,
			unsigned long ro_limit,
			unsigned long coh_start,
			unsigned long coh_limit);

45
void hikey_ddr_init(unsigned int ddr_freq);
Haojian Zhuang's avatar
Haojian Zhuang committed
46
47
void hikey_io_setup(void);

48
49
50
51
52
53
54
55
56
57
58
59
void hikey_sp804_init(void);
void hikey_gpio_init(void);
void hikey_pmussi_init(void);
void hikey_hi6553_init(void);
void init_mmc0_pll(void);
void reset_mmc0_clk(void);
void init_media_clk(void);
void init_mmc1_pll(void);
void reset_mmc1_clk(void);
void hikey_mmc_pll_init(void);
void hikey_rtc_init(void);

Haojian Zhuang's avatar
Haojian Zhuang committed
60
61
62
63
64
65
66
int hikey_get_partition_size(const char *arg, int left, char *response);
int hikey_get_partition_type(const char *arg, int left, char *response);

int hikey_erase(const char *arg);
int hikey_flash(const char *arg);
int hikey_oem(const char *arg);
int hikey_reboot(const char *arg);
67
void hikey_security_setup(void);
Haojian Zhuang's avatar
Haojian Zhuang committed
68
69
70
71
72
73
74

const char *hikey_init_serialno(void);
int hikey_read_serialno(struct random_serial_num *serialno);
int hikey_write_serialno(struct random_serial_num *serialno);

void init_acpu_dvfs(void);

75
#endif /* HIKEY_PRIVATE_H */