uboot/arch/arm/mach-uniphier/init.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0+ */
   2/*
   3 * Copyright (C) 2015-2016 Socionext Inc.
   4 *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
   5 */
   6
   7#ifndef __MACH_INIT_H
   8#define __MACH_INIT_H
   9
  10#include <linux/bitops.h>
  11#include <linux/types.h>
  12
  13#define UNIPHIER_MAX_NR_DRAM_CH         3
  14
  15struct uniphier_dram_ch {
  16        unsigned long size;
  17        unsigned int width;
  18};
  19
  20struct uniphier_board_data {
  21        unsigned int dram_freq;
  22        struct uniphier_dram_ch dram_ch[UNIPHIER_MAX_NR_DRAM_CH];
  23        unsigned int flags;
  24
  25#define UNIPHIER_BD_DRAM_SPARSE                 BIT(9)
  26#define UNIPHIER_BD_DDR3PLUS                    BIT(8)
  27};
  28
  29const struct uniphier_board_data *uniphier_get_board_param(void);
  30
  31int uniphier_ld4_init(const struct uniphier_board_data *bd);
  32int uniphier_pro4_init(const struct uniphier_board_data *bd);
  33int uniphier_sld8_init(const struct uniphier_board_data *bd);
  34int uniphier_pro5_init(const struct uniphier_board_data *bd);
  35int uniphier_pxs2_init(const struct uniphier_board_data *bd);
  36
  37void uniphier_ld4_bcu_init(const struct uniphier_board_data *bd);
  38
  39int uniphier_memconf_2ch_init(const struct uniphier_board_data *bd);
  40int uniphier_memconf_3ch_init(const struct uniphier_board_data *bd);
  41
  42int uniphier_ld4_dpll_init(const struct uniphier_board_data *bd);
  43int uniphier_pro4_dpll_init(const struct uniphier_board_data *bd);
  44int uniphier_sld8_dpll_init(const struct uniphier_board_data *bd);
  45int uniphier_pro5_dpll_init(const struct uniphier_board_data *bd);
  46int uniphier_pxs2_dpll_init(const struct uniphier_board_data *bd);
  47
  48void uniphier_ld4_early_clk_init(void);
  49
  50void uniphier_ld4_dram_clk_init(void);
  51void uniphier_pro5_dram_clk_init(void);
  52void uniphier_pxs2_dram_clk_init(void);
  53
  54int uniphier_ld4_umc_init(const struct uniphier_board_data *bd);
  55int uniphier_pro4_umc_init(const struct uniphier_board_data *bd);
  56int uniphier_sld8_umc_init(const struct uniphier_board_data *bd);
  57int uniphier_pro5_umc_init(const struct uniphier_board_data *bd);
  58int uniphier_pxs2_umc_init(const struct uniphier_board_data *bd);
  59
  60void uniphier_ld4_pll_init(void);
  61void uniphier_pro4_pll_init(void);
  62void uniphier_ld11_pll_init(void);
  63void uniphier_ld20_pll_init(void);
  64void uniphier_pxs3_pll_init(void);
  65
  66void uniphier_pro4_clk_init(void);
  67void uniphier_pro5_clk_init(void);
  68void uniphier_pxs2_clk_init(void);
  69void uniphier_ld11_clk_init(void);
  70void uniphier_ld20_clk_init(void);
  71void uniphier_pxs3_clk_init(void);
  72
  73unsigned int uniphier_boot_device_raw(void);
  74int uniphier_have_internal_stm(void);
  75int uniphier_boot_from_backend(void);
  76
  77#ifdef CONFIG_ARM64
  78void uniphier_mem_map_init(unsigned long dram_base, unsigned long dram_size);
  79#else
  80static inline void uniphier_mem_map_init(unsigned long dram_base,
  81                                         unsigned long dram_size)
  82{
  83}
  84#endif
  85
  86#endif /* __MACH_INIT_H */
  87