blob: 0b93cc48c50dab1e954bb8afc5c6baa4f39f92db [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
wdenkc6097192002-11-03 00:24:07 +00002/*
3 * (C) Copyright 2002
4 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
5 * Marius Groeger <mgroeger@sysgo.de>
6 *
7 * (C) Copyright 2002
8 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
9 * Alex Zuepke <azu@sysgo.de>
wdenkc6097192002-11-03 00:24:07 +000010 */
11
12#ifndef _U_BOOT_ARM_H_
13#define _U_BOOT_ARM_H_ 1
14
Simon Glassac6a6bd2017-05-17 08:22:50 -060015#ifndef __ASSEMBLY__
16
wdenkc6097192002-11-03 00:24:07 +000017/* for the following variables, see start.S */
wdenkc6097192002-11-03 00:24:07 +000018extern ulong IRQ_STACK_START; /* top of IRQ stack */
19extern ulong FIQ_STACK_START; /* top of FIQ stack */
Albert Aribaud92d5ecb2010-10-11 13:13:28 +020020extern ulong _datarel_start_ofs;
21extern ulong _datarelrolocal_start_ofs;
22extern ulong _datarellocal_start_ofs;
23extern ulong _datarelro_start_ofs;
Heiko Schocherf1d2b312010-09-17 13:10:39 +020024extern ulong IRQ_STACK_START_IN; /* 8 bytes in IRQ stack */
wdenkc6097192002-11-03 00:24:07 +000025
Simon Glass6f5fb712019-12-28 10:44:55 -070026void s_init(void);
27
wdenkc6097192002-11-03 00:24:07 +000028/* cpu/.../cpu.c */
wdenkc6097192002-11-03 00:24:07 +000029int cleanup_before_linux(void);
30
Simon Glass80433c92011-11-05 03:56:51 +000031/* Set up ARMv7 MMU, caches and TLBs */
32void cpu_init_cp15(void);
33
Jean-Christophe PLAGNIOL-VILLARDdc39ae92009-04-16 21:30:44 +020034/* cpu/.../arch/cpu.c */
Prafulla Wadaskara24d96e2009-05-31 14:53:20 +020035int arch_misc_init(void);
Jean-Christophe PLAGNIOL-VILLARDdc39ae92009-04-16 21:30:44 +020036
wdenkc6097192002-11-03 00:24:07 +000037/* board/.../... */
38int board_init(void);
wdenkc6097192002-11-03 00:24:07 +000039
Jeroen Hofstee49c4bc32014-10-08 22:57:59 +020040/* calls to c from vectors.S */
Simon Glassc45300b2017-05-17 08:22:59 -060041struct pt_regs;
42
Jeroen Hofstee49c4bc32014-10-08 22:57:59 +020043void bad_mode(void);
44void do_undefined_instruction(struct pt_regs *pt_regs);
45void do_software_interrupt(struct pt_regs *pt_regs);
46void do_prefetch_abort(struct pt_regs *pt_regs);
47void do_data_abort(struct pt_regs *pt_regs);
48void do_not_used(struct pt_regs *pt_regs);
49#ifdef CONFIG_ARM64
50void do_fiq(struct pt_regs *pt_regs, unsigned int esr);
51void do_irq(struct pt_regs *pt_regs, unsigned int esr);
52#else
53void do_fiq(struct pt_regs *pt_regs);
54void do_irq(struct pt_regs *pt_regswq);
55#endif
56
Simon Glass9101a5e2019-12-28 10:45:00 -070057void reset_misc(void);
58
Simon Glassac6a6bd2017-05-17 08:22:50 -060059#endif /* __ASSEMBLY__ */
60
wdenkc6097192002-11-03 00:24:07 +000061#endif /* _U_BOOT_ARM_H_ */