blob: 1980f1a7b7800405816a5e5c3be00499eb8b628b [file] [log] [blame]
wdenk591dda52002-11-18 00:14:45 +00001/*
wdenk57b2d802003-06-27 21:31:46 +00002 * U-boot - i386 Startup Code
wdenk591dda52002-11-18 00:14:45 +00003 *
4 * Copyright (c) 2002 Omicron Ceti AB, Daniel Engström <denaiel@omicron.se>
5 *
6 * See file CREDITS for list of people who contributed to this
7 * project.
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License as
11 * published by the Free Software Foundation; either version 2 of
12 * the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
22 * MA 02111-1307 USA
23 */
24
25
26#include <config.h>
27#include <version.h>
28
wdenk57b2d802003-06-27 21:31:46 +000029
wdenk591dda52002-11-18 00:14:45 +000030.section .text
31.code32
32.globl _start
wdenk57b2d802003-06-27 21:31:46 +000033.type _start, @function
wdenk591dda52002-11-18 00:14:45 +000034.globl _i386boot_start
35_i386boot_start:
wdenk57b2d802003-06-27 21:31:46 +000036_start:
Wolfgang Denka1be4762008-05-20 16:00:29 +020037 movl $0x18,%eax /* Load our segement registes, the
38 * gdt have already been loaded by start16.S */
wdenk57b2d802003-06-27 21:31:46 +000039 movw %ax,%fs
wdenk591dda52002-11-18 00:14:45 +000040 movw %ax,%ds
wdenk57b2d802003-06-27 21:31:46 +000041 movw %ax,%gs
42 movw %ax,%es
43 movw %ax,%ss
44
wdenk591dda52002-11-18 00:14:45 +000045 /* We call a few functions in the board support package
46 * since we have no stack yet we'll have to use %ebp
47 * to store the return address */
wdenk57b2d802003-06-27 21:31:46 +000048
wdenk591dda52002-11-18 00:14:45 +000049 /* Early platform init (setup gpio, etc ) */
50 mov $early_board_init_ret, %ebp
51 jmp early_board_init
52early_board_init_ret:
wdenk57b2d802003-06-27 21:31:46 +000053
wdenk591dda52002-11-18 00:14:45 +000054 /* The __port80 entry-point should be usabe by now */
55 /* so we try to indicate progress */
wdenk57b2d802003-06-27 21:31:46 +000056 movw $0x01, %ax
wdenk591dda52002-11-18 00:14:45 +000057 movl $.progress0, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +100058 jmp show_boot_progress_asm
wdenk57b2d802003-06-27 21:31:46 +000059.progress0:
wdenk591dda52002-11-18 00:14:45 +000060
61 /* size memory */
62 mov $mem_init_ret, %ebp
wdenk57b2d802003-06-27 21:31:46 +000063 jmp mem_init
wdenk591dda52002-11-18 00:14:45 +000064mem_init_ret:
wdenk57b2d802003-06-27 21:31:46 +000065
Graeme Russb39f12f2010-04-24 00:05:41 +100066 /* fetch memory size (into %eax) */
67 mov $get_mem_size_ret, %ebp
68 jmp get_mem_size
69get_mem_size_ret:
70
Graeme Russ078395c2009-11-24 20:04:21 +110071 /* Check we have enough memory for stack */
72 movl $CONFIG_SYS_STACK_SIZE, %ecx
wdenk57b2d802003-06-27 21:31:46 +000073 cmpl %ecx, %eax
wdenk591dda52002-11-18 00:14:45 +000074 jae mem_ok
wdenk57b2d802003-06-27 21:31:46 +000075
wdenk591dda52002-11-18 00:14:45 +000076 /* indicate (lack of) progress */
wdenk57b2d802003-06-27 21:31:46 +000077 movw $0x81, %ax
wdenk591dda52002-11-18 00:14:45 +000078 movl $.progress0a, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +100079 jmp show_boot_progress_asm
wdenk57b2d802003-06-27 21:31:46 +000080.progress0a:
Wolfgang Denka1be4762008-05-20 16:00:29 +020081 jmp die
wdenk57b2d802003-06-27 21:31:46 +000082mem_ok:
Graeme Russ078395c2009-11-24 20:04:21 +110083 /* Set stack pointer to upper memory limit*/
84 movl %eax, %esp
wdenk591dda52002-11-18 00:14:45 +000085
86 /* indicate progress */
wdenk57b2d802003-06-27 21:31:46 +000087 movw $0x02, %ax
wdenk591dda52002-11-18 00:14:45 +000088 movl $.progress1, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +100089 jmp show_boot_progress_asm
wdenk57b2d802003-06-27 21:31:46 +000090.progress1:
wdenk591dda52002-11-18 00:14:45 +000091
Graeme Russ078395c2009-11-24 20:04:21 +110092 /* Test the stack */
wdenk591dda52002-11-18 00:14:45 +000093 pushl $0
94 popl %eax
95 cmpl $0, %eax
96 jne no_stack
97 push $0x55aa55aa
98 popl %ebx
99 cmpl $0x55aa55aa, %ebx
100 je stack_ok
101
102no_stack:
103 /* indicate (lack of) progress */
wdenk57b2d802003-06-27 21:31:46 +0000104 movw $0x82, %ax
wdenk591dda52002-11-18 00:14:45 +0000105 movl $.progress1a, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +1000106 jmp show_boot_progress_asm
wdenk57b2d802003-06-27 21:31:46 +0000107.progress1a:
wdenk591dda52002-11-18 00:14:45 +0000108 jmp die
wdenk57b2d802003-06-27 21:31:46 +0000109
110
111stack_ok:
wdenk591dda52002-11-18 00:14:45 +0000112 /* indicate progress */
wdenk57b2d802003-06-27 21:31:46 +0000113 movw $0x03, %ax
wdenk591dda52002-11-18 00:14:45 +0000114 movl $.progress2, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +1000115 jmp show_boot_progress_asm
wdenk57b2d802003-06-27 21:31:46 +0000116.progress2:
wdenk591dda52002-11-18 00:14:45 +0000117
wdenk57b2d802003-06-27 21:31:46 +0000118 wbinvd
wdenk591dda52002-11-18 00:14:45 +0000119
Graeme Russ078395c2009-11-24 20:04:21 +1100120 /* Get upper memory limit */
121 movl %esp, %ecx
122 subl $CONFIG_SYS_STACK_SIZE, %ecx
wdenk591dda52002-11-18 00:14:45 +0000123
Graeme Russ078395c2009-11-24 20:04:21 +1100124 /* Create a Stack Frame */
125 pushl %ebp
126 movl %esp, %ebp
wdenk591dda52002-11-18 00:14:45 +0000127
Graeme Russ078395c2009-11-24 20:04:21 +1100128 /* stack_limit parameter */
129 pushl %ecx
130 call board_init_f /* Enter, U-boot! */
wdenk591dda52002-11-18 00:14:45 +0000131
132 /* indicate (lack of) progress */
wdenk57b2d802003-06-27 21:31:46 +0000133 movw $0x85, %ax
wdenk591dda52002-11-18 00:14:45 +0000134 movl $.progress4a, %ebp
Graeme Russ4e30d962008-09-29 23:03:14 +1000135 jmp show_boot_progress_asm
wdenk591dda52002-11-18 00:14:45 +0000136.progress4a:
137
138die: hlt
139 jmp die
wdenk57b2d802003-06-27 21:31:46 +0000140 hlt