2018-05-06 21:58:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
2008-12-14 08:47:12 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2004-2008
|
|
|
|
* Texas Instruments, <www.ti.com>
|
|
|
|
* Richard Woodruff <r-woodruff2@ti.com>
|
2013-07-08 07:37:19 +00:00
|
|
|
*/
|
2008-12-14 08:47:12 +00:00
|
|
|
#ifndef _SYS_PROTO_H_
|
|
|
|
#define _SYS_PROTO_H_
|
2013-11-22 11:23:29 +00:00
|
|
|
#include <linux/mtd/omap_gpmc.h>
|
2014-03-28 16:00:06 +00:00
|
|
|
#include <asm/omap_common.h>
|
2008-12-14 08:47:12 +00:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
u32 mtype;
|
|
|
|
char *board_string;
|
|
|
|
char *nand_string;
|
|
|
|
} omap3_sysinfo;
|
|
|
|
|
2011-06-16 23:30:53 +00:00
|
|
|
struct emu_hal_params {
|
|
|
|
u32 num_params;
|
|
|
|
u32 param1;
|
|
|
|
};
|
|
|
|
|
2012-11-13 07:40:28 +00:00
|
|
|
/* Board SDRC timing values */
|
|
|
|
struct board_sdrc_timings {
|
2015-01-16 08:09:48 +00:00
|
|
|
u32 sharing;
|
2012-11-13 07:40:28 +00:00
|
|
|
u32 mcfg;
|
|
|
|
u32 ctrla;
|
|
|
|
u32 ctrlb;
|
|
|
|
u32 rfr_ctrl;
|
|
|
|
u32 mr;
|
|
|
|
};
|
|
|
|
|
2008-12-14 08:47:12 +00:00
|
|
|
void prcm_init(void);
|
|
|
|
void per_clocks_enable(void);
|
2012-02-06 03:55:35 +00:00
|
|
|
void ehci_clocks_enable(void);
|
2008-12-14 08:47:12 +00:00
|
|
|
|
|
|
|
void memif_init(void);
|
|
|
|
void sdrc_init(void);
|
|
|
|
void do_sdrc_init(u32, u32);
|
2012-11-13 07:40:28 +00:00
|
|
|
|
|
|
|
void get_board_mem_timings(struct board_sdrc_timings *timings);
|
2016-07-12 18:28:15 +00:00
|
|
|
int identify_nand_chip(int *mfr, int *id);
|
2010-06-07 19:20:53 +00:00
|
|
|
void emif4_init(void);
|
2008-12-14 08:47:12 +00:00
|
|
|
void gpmc_init(void);
|
2016-07-12 18:28:16 +00:00
|
|
|
void enable_gpmc_cs_config(const u32 *gpmc_config, const struct gpmc_cs *cs,
|
|
|
|
u32 base, u32 size);
|
2016-07-12 18:28:17 +00:00
|
|
|
void set_gpmc_cs0(int flash_type);
|
2008-12-14 08:47:12 +00:00
|
|
|
|
|
|
|
void watchdog_init(void);
|
|
|
|
void set_muxconf_regs(void);
|
|
|
|
|
2010-08-17 21:39:34 +00:00
|
|
|
u32 get_cpu_family(void);
|
2008-12-14 08:47:12 +00:00
|
|
|
u32 get_cpu_rev(void);
|
2010-08-17 21:39:34 +00:00
|
|
|
u32 get_sku_id(void);
|
2008-12-14 08:47:12 +00:00
|
|
|
u32 is_gpmc_muxed(void);
|
|
|
|
u32 get_gpmc0_type(void);
|
|
|
|
u32 get_gpmc0_width(void);
|
|
|
|
u32 is_running_in_sdram(void);
|
|
|
|
u32 is_running_in_sram(void);
|
|
|
|
u32 is_running_in_flash(void);
|
|
|
|
u32 get_device_type(void);
|
|
|
|
u32 get_boot_type(void);
|
2009-09-10 19:27:57 +00:00
|
|
|
void invalidate_dcache(u32);
|
2008-12-14 08:47:12 +00:00
|
|
|
u32 wait_on_value(u32, u32, void *, u32);
|
2014-10-08 20:57:57 +00:00
|
|
|
void cancel_out(u32 *num, u32 *den, u32 den_limit);
|
2008-12-14 08:47:12 +00:00
|
|
|
void sdelay(unsigned long);
|
|
|
|
void make_cs1_contiguous(void);
|
2017-03-06 12:54:30 +00:00
|
|
|
int omap_nand_switch_ecc(uint32_t, uint32_t);
|
2008-12-14 08:47:12 +00:00
|
|
|
void power_init_r(void);
|
2011-06-16 23:30:53 +00:00
|
|
|
void do_omap3_emu_romcode_call(u32 service_id, u32 parameters);
|
2015-03-09 22:12:09 +00:00
|
|
|
void omap3_set_aux_cr_secure(u32 acr);
|
2012-05-29 19:26:41 +00:00
|
|
|
u32 warm_reset(void);
|
2015-07-15 14:02:19 +00:00
|
|
|
|
|
|
|
void save_omap_boot_params(void);
|
2008-12-14 08:47:12 +00:00
|
|
|
#endif
|