blob: cc5f13ec7e76f1cb95f6dcac4f7886919de20a2c [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
wdenke2211742002-11-02 23:30:20 +00002/*
Simon Glassec1fa182019-08-02 09:44:27 -06003 * Common header file for U-Boot
4 *
5 * This file still includes quite a bit of stuff that should be in separate
Simon Glass10453152019-11-14 12:57:30 -07006 * headers like command.h and cpu.h. Please think before adding more things.
7 * Patches to remove things are welcome.
Simon Glassec1fa182019-08-02 09:44:27 -06008 *
Wolfgang Denk3b74e7e2009-05-16 10:47:45 +02009 * (C) Copyright 2000-2009
wdenke2211742002-11-02 23:30:20 +000010 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenke2211742002-11-02 23:30:20 +000011 */
12
13#ifndef __COMMON_H_
Wolfgang Denkd0b8fee2012-01-06 07:36:44 +010014#define __COMMON_H_ 1
wdenke2211742002-11-02 23:30:20 +000015
Wolfgang Denkfcd3c872009-07-24 00:17:48 +020016#ifndef __ASSEMBLY__ /* put C only stuff in this section */
17
wdenke2211742002-11-02 23:30:20 +000018typedef unsigned char uchar;
19typedef volatile unsigned long vu_long;
wdenk180d3f72004-01-04 16:28:35 +000020typedef volatile unsigned short vu_short;
wdenke2211742002-11-02 23:30:20 +000021typedef volatile unsigned char vu_char;
22
23#include <config.h>
Joe Hershberger2307ea42016-04-04 04:07:33 -050024#include <errno.h>
Masahiro Yamadaa7b81762016-12-28 00:36:00 +090025#include <time.h>
Wolfgang Denk25ddd1f2010-10-26 14:34:52 +020026#include <asm-offsets.h>
wdenke2211742002-11-02 23:30:20 +000027#include <linux/bitops.h>
Masahiro Yamada0a70fb42017-09-16 14:10:45 +090028#include <linux/bug.h>
Masahiro Yamada5bc516e2016-12-28 00:35:59 +090029#include <linux/delay.h>
wdenke2211742002-11-02 23:30:20 +000030#include <linux/types.h>
Masahiro Yamadab44b3022017-09-16 14:10:40 +090031#include <linux/printk.h>
wdenke2211742002-11-02 23:30:20 +000032#include <linux/string.h>
Marek Vasut9aed5082012-09-27 17:08:15 +020033#include <linux/stringify.h>
wdenke2211742002-11-02 23:30:20 +000034#include <asm/ptrace.h>
35#include <stdarg.h>
Masahiro Yamada7fea7b12017-09-16 14:10:39 +090036#include <stdio.h>
Masahiro Yamadacba1da42014-11-07 03:03:28 +090037#include <linux/kernel.h>
Simon Glass85043152017-05-17 08:23:05 -060038
wdenke2211742002-11-02 23:30:20 +000039#include <part.h>
40#include <flash.h>
41#include <image.h>
42
York Sun4d1fd7f2014-02-26 17:03:19 -080043#ifdef __LP64__
44#define CONFIG_SYS_SUPPORT_64BIT_DATA
45#endif
46
Simon Glass0e98b0a2017-12-04 13:48:20 -070047#include <log.h>
Simon Glass21726a72011-06-29 09:49:34 +000048
wdenkc83bf6a2004-01-06 22:38:14 +000049typedef void (interrupt_handler_t)(void *);
wdenke2211742002-11-02 23:30:20 +000050
wdenkc83bf6a2004-01-06 22:38:14 +000051#include <asm/u-boot.h> /* boot information for Linux kernel */
wdenke2211742002-11-02 23:30:20 +000052#include <asm/global_data.h> /* global data used for startup functions */
53
Patrick Delaunayd6f87712018-03-13 13:57:00 +010054/* startup functions, used in:
55 * common/board_f.c
Patrick Delaunay11f86cb2018-03-13 13:57:01 +010056 * common/init/board_init.c
Patrick Delaunaye2c219c2018-03-13 13:57:02 +010057 * common/board_r.c
Patrick Delaunayfc22ee22018-03-13 13:57:03 +010058 * common/board_info.c
Patrick Delaunayd6f87712018-03-13 13:57:00 +010059 */
Patrick Delaunaydafa84d2018-03-09 18:28:12 +010060#include <init.h>
61
wdenkc7de8292002-11-19 11:04:11 +000062/*
wdenke2211742002-11-02 23:30:20 +000063 * Function Prototypes
64 */
wdenkc83bf6a2004-01-06 22:38:14 +000065void hang (void) __attribute__ ((noreturn));
wdenke2211742002-11-02 23:30:20 +000066
Wolfgang Denkf6c019c2011-07-30 12:32:45 +000067int cpu_init(void);
68
Simon Glass2ea09c82015-04-28 20:25:07 -060069#include <display_options.h>
wdenke2211742002-11-02 23:30:20 +000070
71/* common/main.c */
72void main_loop (void);
Simon Glass009dde12012-02-14 19:59:20 +000073int run_command(const char *cmd, int flag);
Thomas Betker1d43bfd2014-06-05 20:07:57 +020074int run_command_repeatable(const char *cmd, int flag);
Simon Glassd51004a2012-03-30 21:30:55 +000075
76/**
77 * Run a list of commands separated by ; or even \0
78 *
79 * Note that if 'len' is not -1, then the command does not need to be nul
80 * terminated, Memory will be allocated for the command in that case.
81 *
82 * @param cmd List of commands to run, each separated bu semicolon
83 * @param len Length of commands excluding terminator if known (-1 if not)
84 * @param flag Execution flags (CMD_FLAG_...)
85 * @return 0 on success, or != 0 on error.
86 */
87int run_command_list(const char *cmd, int len, int flag);
wdenke2211742002-11-02 23:30:20 +000088
Patrick Delaunaye2c219c2018-03-13 13:57:02 +010089int checkflash(void);
90int checkdram(void);
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090091extern u8 __dtb_dt_begin[]; /* embedded device tree blob */
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000092extern u8 __dtb_dt_spl_begin[]; /* embedded device tree blob for SPL/TPL */
Patrick Delaunayd6f87712018-03-13 13:57:00 +010093int mdm_init(void);
wdenke2211742002-11-02 23:30:20 +000094
Simon Glass15a33e42012-11-30 13:01:20 +000095/**
96 * Show the DRAM size in a board-specific way
97 *
98 * This is used by boards to display DRAM information in their own way.
99 *
100 * @param size Size of DRAM (which should be displayed along with other info)
101 */
Andrew Bradfordea11b402015-05-22 08:30:14 -0400102void board_show_dram(phys_size_t size);
Simon Glass15a33e42012-11-30 13:01:20 +0000103
Simon Glass13d06982013-05-08 08:06:01 +0000104/**
Alexander Graf7b78d642018-11-30 21:24:56 +0100105 * Get the uppermost pointer that is valid to access
106 *
107 * Some systems may not map all of their address space. This function allows
108 * boards to indicate what their highest support pointer value is for DRAM
109 * access.
110 *
111 * @param total_size Size of U-Boot (unused?)
112 */
113ulong board_get_usable_ram_top(ulong total_size);
114
115/**
Ma Haijune29607e2014-07-12 14:24:06 +0100116 * arch_fixup_fdt() - Write arch-specific information to fdt
Simon Glass13d06982013-05-08 08:06:01 +0000117 *
Ma Haijune29607e2014-07-12 14:24:06 +0100118 * Defined in arch/$(ARCH)/lib/bootm-fdt.c
Simon Glass13d06982013-05-08 08:06:01 +0000119 *
120 * @blob: FDT blob to write to
121 * @return 0 if ok, or -ve FDT_ERR_... on failure
122 */
Ma Haijune29607e2014-07-12 14:24:06 +0100123int arch_fixup_fdt(void *blob);
Simon Glass13d06982013-05-08 08:06:01 +0000124
wdenke2211742002-11-02 23:30:20 +0000125/* common/flash.c */
126void flash_perror (int);
127
Wolfgang Denk74de7ae2009-04-01 23:34:12 +0200128/* common/cmd_source.c */
129int source (ulong addr, const char *fit_uname);
wdenke2211742002-11-02 23:30:20 +0000130
wdenkc83bf6a2004-01-06 22:38:14 +0000131extern ulong load_addr; /* Default Load Address */
Simon Glass1aec2442011-10-21 18:51:38 +0000132extern ulong save_addr; /* Default Save Address */
133extern ulong save_size; /* Default Save Size */
wdenke2211742002-11-02 23:30:20 +0000134
Jason Hobbs06283a62011-08-31 10:37:30 -0500135/* common/cmd_net.c */
136int do_tftpb(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]);
137
Rob Herring669df7e2012-05-25 10:47:39 +0000138/* common/cmd_fat.c */
139int do_fat_fsload(cmd_tbl_t *, int, int, char * const []);
140
141/* common/cmd_ext2.c */
142int do_ext2load(cmd_tbl_t *, int, int, char * const []);
143
wdenkc83bf6a2004-01-06 22:38:14 +0000144void pci_init_board(void);
wdenke2211742002-11-02 23:30:20 +0000145
wdenk27b207f2003-07-24 23:38:38 +0000146/* common/exports.c */
147void jumptable_init(void);
148
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400149/* common/kallsysm.c */
150const char *symbol_lookup(unsigned long addr, unsigned long *caddr);
151
wdenkc83bf6a2004-01-06 22:38:14 +0000152/* common/memsize.c */
Albert ARIBAUDa55d23c2011-07-03 05:55:33 +0000153long get_ram_size (long *, long);
York Sune3866162014-02-11 11:57:26 -0800154phys_size_t get_effective_memsize(void);
wdenkc83bf6a2004-01-06 22:38:14 +0000155
wdenke2211742002-11-02 23:30:20 +0000156/* $(BOARD)/$(BOARD).c */
157void reset_phy (void);
wdenkc83bf6a2004-01-06 22:38:14 +0000158void fdc_hw_init (void);
wdenke2211742002-11-02 23:30:20 +0000159
160/* $(BOARD)/eeprom.c */
Simon Glasseb5ba3a2017-05-12 21:09:49 -0600161#ifdef CONFIG_CMD_EEPROM
Marek Vasut354e3ed2015-11-10 20:53:31 +0100162void eeprom_init (int bus);
wdenke2211742002-11-02 23:30:20 +0000163int eeprom_read (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cnt);
164int eeprom_write (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cnt);
Simon Glasseb5ba3a2017-05-12 21:09:49 -0600165#else
166/*
167 * Some EEPROM code is depecated because it used the legacy I2C interface. Add
168 * some macros here so we don't have to touch every one of those uses
169 */
170#define eeprom_init(bus)
171#define eeprom_read(dev_addr, offset, buffer, cnt) ((void)-ENOSYS)
172#define eeprom_write(dev_addr, offset, buffer, cnt) ((void)-ENOSYS)
173#endif
wdenke2211742002-11-02 23:30:20 +0000174
Adam Fordf1b1f772018-04-15 13:51:26 -0400175#if !defined(CONFIG_ENV_EEPROM_IS_ON_I2C) && defined(CONFIG_SYS_I2C_EEPROM_ADDR)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200176# define CONFIG_SYS_DEF_EEPROM_ADDR CONFIG_SYS_I2C_EEPROM_ADDR
Heiko Schocher548738b2010-01-07 08:55:40 +0100177#endif
wdenke2211742002-11-02 23:30:20 +0000178
wdenke2211742002-11-02 23:30:20 +0000179/* $(BOARD)/$(BOARD).c */
wdenkc837dcb2004-01-20 23:12:12 +0000180int board_early_init_f (void);
mario.six@gdsys.cc2a792752017-02-22 16:07:22 +0100181int board_fix_fdt (void *rw_fdt_blob); /* manipulate the U-Boot fdt before its relocation */
wdenkc837dcb2004-01-20 23:12:12 +0000182int board_late_init (void);
wdenke2211742002-11-02 23:30:20 +0000183int board_postclk_init (void); /* after clocks/timebase, before env/serial */
wdenkc837dcb2004-01-20 23:12:12 +0000184int board_early_init_r (void);
wdenke2211742002-11-02 23:30:20 +0000185
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200186#if defined(CONFIG_SYS_DRAM_TEST)
wdenke2211742002-11-02 23:30:20 +0000187int testdram(void);
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200188#endif /* CONFIG_SYS_DRAM_TEST */
wdenke2211742002-11-02 23:30:20 +0000189
190/* $(CPU)/start.S */
wdenke2211742002-11-02 23:30:20 +0000191int icache_status (void);
192void icache_enable (void);
193void icache_disable(void);
194int dcache_status (void);
195void dcache_enable (void);
196void dcache_disable(void);
Aneesh V2c451f72011-06-16 23:30:47 +0000197void mmu_disable(void);
Benoît Thébaudeau5c6db122013-04-11 09:35:53 +0000198#if defined(CONFIG_ARM)
199void relocate_code(ulong);
200#else
201void relocate_code(ulong, gd_t *, ulong) __attribute__ ((noreturn));
Benoît Thébaudeau959eaa72013-04-11 09:35:43 +0000202#endif
wdenke2211742002-11-02 23:30:20 +0000203ulong get_endaddr (void);
204void trap_init (ulong);
Simon Glass6e2941d2017-05-17 08:23:06 -0600205
wdenke2211742002-11-02 23:30:20 +0000206/* $(CPU)/cpu.c */
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500207static inline int cpumask_next(int cpu, unsigned int mask)
208{
209 for (cpu++; !((1 << cpu) & mask); cpu++)
210 ;
211
212 return cpu;
213}
214
215#define for_each_cpu(iter, cpu, num_cpus, mask) \
216 for (iter = 0, cpu = cpumask_next(-1, mask); \
217 iter < num_cpus; \
218 iter++, cpu = cpumask_next(cpu, mask)) \
219
Poonam Aggrwal0e870982009-07-31 12:08:14 +0530220int cpu_numcores (void);
Shaveta Leekhab8bf0ad2015-01-19 12:46:54 +0530221int cpu_num_dspcores(void);
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500222u32 cpu_mask (void);
Shaveta Leekhab8bf0ad2015-01-19 12:46:54 +0530223u32 cpu_dsp_mask(void);
Timur Tabifbb9ecf2011-08-05 16:15:24 -0500224int is_core_valid (unsigned int);
Simon Glasscbcbf712017-01-23 13:31:22 -0700225
Diego Dorta026d7952017-10-05 09:13:38 -0300226void s_init(void);
227
wdenke2211742002-11-02 23:30:20 +0000228int checkcpu (void);
229int checkicache (void);
230int checkdcache (void);
231void upmconfig (unsigned int, unsigned int *, unsigned int);
232ulong get_tbclk (void);
Przemyslaw Marczak1fb4dab2014-09-01 13:50:48 +0200233void reset_misc (void);
wdenk3ec924a2005-04-03 17:23:39 +0000234void reset_cpu (ulong addr);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500235void ft_cpu_setup(void *blob, bd_t *bd);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500236void ft_pci_setup(void *blob, bd_t *bd);
Kim Phillips6a16e0d2007-08-15 22:30:26 -0500237
Andre Przywaraba6a1692013-09-19 18:06:44 +0200238void smp_set_core_boot_addr(unsigned long addr, int corenr);
239void smp_kick_all_cpus(void);
wdenke2211742002-11-02 23:30:20 +0000240
wdenke2211742002-11-02 23:30:20 +0000241/* $(CPU)/speed.c */
242int get_clocks (void);
wdenke2211742002-11-02 23:30:20 +0000243ulong get_bus_freq (ulong);
Stefan Roese550650d2010-09-20 16:05:31 +0200244int get_serial_clock(void);
wdenke2211742002-11-02 23:30:20 +0000245
wdenke2211742002-11-02 23:30:20 +0000246/* $(CPU)/interrupts.c */
wdenkc83bf6a2004-01-06 22:38:14 +0000247int interrupt_init (void);
248void timer_interrupt (struct pt_regs *);
wdenke2211742002-11-02 23:30:20 +0000249void external_interrupt (struct pt_regs *);
250void irq_install_handler(int, interrupt_handler_t *, void *);
251void irq_free_handler (int);
252void reset_timer (void);
Simon Glassb2e16a82013-06-11 11:14:39 -0700253
wdenke2211742002-11-02 23:30:20 +0000254void enable_interrupts (void);
255int disable_interrupts (void);
256
wdenke2211742002-11-02 23:30:20 +0000257/* $(CPU)/.../<eth> */
Wolfgang Denkc5bded32007-08-29 14:05:30 +0200258void mii_init (void);
wdenke2211742002-11-02 23:30:20 +0000259
Peter Tyserea0364f2010-04-12 22:28:04 -0500260/* arch/$(ARCH)/lib/cache.c */
Aneesh Vcba4b182011-08-16 04:33:05 +0000261void enable_caches(void);
wdenke2211742002-11-02 23:30:20 +0000262void flush_cache (unsigned long, unsigned long);
Aneesh V2c451f72011-06-16 23:30:47 +0000263void flush_dcache_all(void);
Stefan Roese03d3bfb2009-01-21 17:20:20 +0100264void flush_dcache_range(unsigned long start, unsigned long stop);
265void invalidate_dcache_range(unsigned long start, unsigned long stop);
Aneesh V2c451f72011-06-16 23:30:47 +0000266void invalidate_dcache_all(void);
267void invalidate_icache_all(void);
wdenk0db5bca2003-03-31 17:27:09 +0000268
Simon Glass4d24a112015-05-13 07:02:25 -0600269enum {
270 /* Disable caches (else flush caches but leave them active) */
271 CBL_DISABLE_CACHES = 1 << 0,
272 CBL_SHOW_BOOTSTAGE_REPORT = 1 << 1,
273
274 CBL_ALL = 3,
275};
276
277/**
278 * Clean up ready for linux
279 *
280 * @param flags Flags to control what is done
281 */
282int cleanup_before_linux_select(int flags);
283
Jason Hobbse11938e2011-08-23 11:06:56 +0000284/* lib/uuid.c */
Przemyslaw Marczakd718ded2014-04-02 10:20:03 +0200285#include <uuid.h>
Jason Hobbse11938e2011-08-23 11:06:56 +0000286
Peter Tyser78acc472010-04-12 22:28:05 -0500287/* lib/vsprintf.c */
Simon Glass9785c902011-11-02 09:52:07 +0000288#include <vsprintf.h>
wdenke2211742002-11-02 23:30:20 +0000289
Joe Hershberger4ef8d532012-05-23 08:01:04 +0000290/* lib/net_utils.c */
291#include <net.h>
Joe Hershberger4ef8d532012-05-23 08:01:04 +0000292
Simon Glass097e1782012-01-14 15:24:44 +0000293#include <bootstage.h>
wdenke2211742002-11-02 23:30:20 +0000294
Andre Przywara2a6713b2017-01-02 11:48:30 +0000295#else /* __ASSEMBLY__ */
296
Andre Przywara2a6713b2017-01-02 11:48:30 +0000297#endif /* __ASSEMBLY__ */
Wolfgang Denkfcd3c872009-07-24 00:17:48 +0200298
299/* Put only stuff here that the assembler can digest */
300
301#ifdef CONFIG_POST
302#define CONFIG_HAS_POST
Michael Zaidman800eb092010-09-20 08:51:53 +0200303#ifndef CONFIG_POST_ALT_LIST
304#define CONFIG_POST_STD_LIST
305#endif
Wolfgang Denkfcd3c872009-07-24 00:17:48 +0200306#endif
307
Anton Staaf155cfb52011-09-02 13:45:28 +0000308#define ROUND(a,b) (((a) + (b) - 1) & ~((b) - 1))
Andy Fleming4b03ac82008-06-16 13:58:53 -0500309
Anton Staaf1e41f5a2011-10-17 16:46:13 -0700310/*
Simon Glassc9689ca2015-06-23 15:38:31 -0600311 * check_member() - Check the offset of a structure member
312 *
313 * @structure: Name of structure (e.g. global_data)
314 * @member: Name of member (e.g. baudrate)
315 * @offset: Expected offset in bytes
316 */
317#define check_member(structure, member, offset) _Static_assert( \
318 offsetof(struct structure, member) == offset, \
319 "`struct " #structure "` offset for `" #member "` is not " #offset)
320
Simon Glass476476e2015-08-04 12:33:52 -0600321/* Avoid using CONFIG_EFI_STUB directly as we may boot from other loaders */
322#ifdef CONFIG_EFI_STUB
323#define ll_boot_init() false
324#else
325#define ll_boot_init() true
326#endif
327
Mike Frysingerc3eb3fe2011-07-08 10:44:25 +0000328/* Pull in stuff for the build system */
329#ifdef DO_DEPS_ONLY
Simon Glassf3998fd2019-08-02 09:44:25 -0600330# include <env_internal.h>
Mike Frysingerc3eb3fe2011-07-08 10:44:25 +0000331#endif
332
wdenke2211742002-11-02 23:30:20 +0000333#endif /* __COMMON_H_ */