init.h 3.06 KB
Newer Older
1 2 3 4 5 6 7 8 9
/*
 * Copyright (C) 2015 Masahiro Yamada <yamada.masahiro@socionext.com>
 *
 * SPDX-License-Identifier:	GPL-2.0+
 */

#ifndef __MACH_INIT_H
#define __MACH_INIT_H

10 11 12 13 14 15 16 17
#define UNIPHIER_MAX_NR_DRAM_CH		3

struct uniphier_dram_ch {
	unsigned long base;
	unsigned long size;
	unsigned int width;
};

18
struct uniphier_board_data {
19 20 21
	unsigned int dram_freq;
	unsigned int dram_nr_ch;
	struct uniphier_dram_ch dram_ch[UNIPHIER_MAX_NR_DRAM_CH];
22 23
};

24
const struct uniphier_board_data *uniphier_get_board_param(void);
25 26 27 28 29

int ph1_sld3_init(const struct uniphier_board_data *bd);
int ph1_ld4_init(const struct uniphier_board_data *bd);
int ph1_pro4_init(const struct uniphier_board_data *bd);
int ph1_sld8_init(const struct uniphier_board_data *bd);
30
int ph1_pro5_init(const struct uniphier_board_data *bd);
31
int proxstream2_init(const struct uniphier_board_data *bd);
32 33 34 35 36

#if defined(CONFIG_MICRO_SUPPORT_CARD)
int ph1_sld3_sbc_init(const struct uniphier_board_data *bd);
int ph1_ld4_sbc_init(const struct uniphier_board_data *bd);
int ph1_pro4_sbc_init(const struct uniphier_board_data *bd);
37
int proxstream2_sbc_init(const struct uniphier_board_data *bd);
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
#else
static inline int ph1_sld3_sbc_init(const struct uniphier_board_data *bd)
{
	return 0;
}

static inline int ph1_ld4_sbc_init(const struct uniphier_board_data *bd)
{
	return 0;
}

static inline int ph1_pro4_sbc_init(const struct uniphier_board_data *bd)
{
	return 0;
}
53 54 55 56 57

static inline int proxstream2_sbc_init(const struct uniphier_board_data *bd)
{
	return 0;
}
58 59 60 61 62 63 64
#endif

int ph1_sld3_bcu_init(const struct uniphier_board_data *bd);
int ph1_ld4_bcu_init(const struct uniphier_board_data *bd);

int memconf_init(const struct uniphier_board_data *bd);
int ph1_sld3_memconf_init(const struct uniphier_board_data *bd);
65
int proxstream2_memconf_init(const struct uniphier_board_data *bd);
66 67 68 69 70 71 72 73 74 75

int ph1_sld3_pll_init(const struct uniphier_board_data *bd);
int ph1_ld4_pll_init(const struct uniphier_board_data *bd);
int ph1_pro4_pll_init(const struct uniphier_board_data *bd);
int ph1_sld8_pll_init(const struct uniphier_board_data *bd);

int ph1_sld3_enable_dpll_ssc(const struct uniphier_board_data *bd);
int ph1_ld4_enable_dpll_ssc(const struct uniphier_board_data *bd);

int ph1_ld4_early_clk_init(const struct uniphier_board_data *bd);
76
int ph1_pro5_early_clk_init(const struct uniphier_board_data *bd);
77
int proxstream2_early_clk_init(const struct uniphier_board_data *bd);
78 79 80 81 82 83

int ph1_sld3_early_pin_init(const struct uniphier_board_data *bd);

int ph1_ld4_umc_init(const struct uniphier_board_data *bd);
int ph1_pro4_umc_init(const struct uniphier_board_data *bd);
int ph1_sld8_umc_init(const struct uniphier_board_data *bd);
84
int proxstream2_umc_init(const struct uniphier_board_data *bd);
85 86 87 88 89

void ph1_sld3_pin_init(void);
void ph1_ld4_pin_init(void);
void ph1_pro4_pin_init(void);
void ph1_sld8_pin_init(void);
90
void ph1_pro5_pin_init(void);
91 92
void proxstream2_pin_init(void);
void ph1_ld6b_pin_init(void);
93 94 95

void ph1_ld4_clk_init(void);
void ph1_pro4_clk_init(void);
96
void ph1_pro5_clk_init(void);
97
void proxstream2_clk_init(void);
98 99 100 101

#define pr_err(fmt, args...)	printf(fmt, ##args)

#endif /* __MACH_INIT_H */