blob: 6d2f8bccb50fd0170c8108ee696b7377c29d0ba5 [file] [log] [blame]
wdenkc6097192002-11-03 00:24:07 +00001/*
2 * (C) Copyright 2002
3 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
4 * Marius Groeger <mgroeger@sysgo.de>
5 *
6 * (C) Copyright 2002
7 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
8 * Alex Zuepke <azu@sysgo.de>
9 *
10 * See file CREDITS for list of people who contributed to this
11 * project.
12 *
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License as
15 * published by the Free Software Foundation; either version 2 of
16 * the License, or (at your option) any later version.
17 *
18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
22 *
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
26 * MA 02111-1307 USA
27 */
28
29#ifndef _U_BOOT_ARM_H_
30#define _U_BOOT_ARM_H_ 1
31
32/* for the following variables, see start.S */
33extern ulong _armboot_start; /* code start */
wdenk927034e2004-02-08 19:38:38 +000034extern ulong _bss_start; /* code + data end == BSS start */
35extern ulong _bss_end; /* BSS end */
wdenkc6097192002-11-03 00:24:07 +000036extern ulong IRQ_STACK_START; /* top of IRQ stack */
37extern ulong FIQ_STACK_START; /* top of FIQ stack */
wdenkc6097192002-11-03 00:24:07 +000038
39/* cpu/.../cpu.c */
40int cpu_init(void);
41int cleanup_before_linux(void);
42
Jean-Christophe PLAGNIOL-VILLARD23164f12009-04-16 21:30:44 +020043/* cpu/.../arch/cpu.c */
44int arch_cpu_init(void);
Prafulla Wadaskar98196702009-05-31 14:53:20 +020045int arch_misc_init(void);
Jean-Christophe PLAGNIOL-VILLARD23164f12009-04-16 21:30:44 +020046
wdenkc6097192002-11-03 00:24:07 +000047/* board/.../... */
48int board_init(void);
49int dram_init (void);
wdenkbc01dd52004-01-02 16:05:07 +000050void setup_serial_tag (struct tag **params);
51void setup_revision_tag (struct tag **params);
wdenkc6097192002-11-03 00:24:07 +000052
53/* ------------------------------------------------------------ */
54/* Here is a list of some prototypes which are incompatible to */
55/* the U-Boot implementation */
56/* To be fixed! */
57/* ------------------------------------------------------------ */
58/* common/cmd_nvedit.c */
Steven A. Falco1ce6f992008-06-12 13:22:12 -040059int setenv (char *, char *);
wdenkc6097192002-11-03 00:24:07 +000060
61/* cpu/.../interrupt.c */
Jean-Christophe PLAGNIOL-VILLARDda7b3db2009-05-09 13:21:18 +020062int arch_interrupt_init (void);
wdenkc6097192002-11-03 00:24:07 +000063void reset_timer_masked (void);
64ulong get_timer_masked (void);
65void udelay_masked (unsigned long usec);
66
Jean-Christophe PLAGNIOL-VILLARD8c9fc002009-05-15 23:47:02 +020067/* cpu/.../timer.c */
68int timer_init (void);
69
wdenkc6097192002-11-03 00:24:07 +000070#endif /* _U_BOOT_ARM_H_ */