source: mainline/arch/ppc32/src/boot/boot.S@ a33c990

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since a33c990 was 762a824, checked in by Martin Decky <martin@…>, 19 years ago

ppc32: proper exception handling from user-space
code cleanup

  • Property mode set to 100644
File size: 2.2 KB
RevLine 
[2e5365f3]1#
2# Copyright (C) 2005 Jakub Jermar
3# All rights reserved.
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions
7# are met:
8#
9# - Redistributions of source code must retain the above copyright
10# notice, this list of conditions and the following disclaimer.
11# - Redistributions in binary form must reproduce the above copyright
12# notice, this list of conditions and the following disclaimer in the
13# documentation and/or other materials provided with the distribution.
14# - The name of the author may not be used to endorse or promote products
15# derived from this software without specific prior written permission.
16#
17# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27#
28
[37c8975]29#include <arch/asm/regname.h>
[06e6805]30#include <arch/boot/boot.h>
[10caad0]31
[edc89bd0]32.section K_TEXT_START, "ax"
[2e5365f3]33
34.global kernel_image_start
35kernel_image_start:
[e4ddfa8]36
[762a824]37 # load temporal kernel stack
[e4ddfa8]38
[762a824]39 lis sp, kernel_stack@ha
40 addi sp, sp, kernel_stack@l
41
42 # set kernel stack for interrupt handling
43
44 mr r31, sp
45 subis r31, r31, 0x8000
46 mtsprg0 r31
[06e6805]47
[4037847]48 # r3 contains physical address of bootinfo_t
49 # r4 contains size of bootinfo_t
[06e6805]50
[762a824]51 addis r3, r3, 0x8000
[06e6805]52
[4037847]53 lis r31, bootinfo@ha
54 addi r31, r31, bootinfo@l # r31 = bootinfo
[06e6805]55
[4037847]56 cmpwi r4, 0
57 beq bootinfo_end
[06e6805]58
[4037847]59 bootinfo_loop:
[06e6805]60
[4037847]61 lwz r30, 0(r3)
62 stw r30, 0(r31)
63
64 addi r3, r3, 4
65 addi r31, r31, 4
66 subi r4, r4, 4
67
68 cmpwi r4, 0
69 bgt bootinfo_loop
70
71 bootinfo_end:
[06e6805]72
[12c7f27]73 bl arch_pre_main
[dfbc229]74 b main_bsp
[e4ddfa8]75
76.section K_DATA_START, "aw", @progbits
[8965838e]77
[762a824]78.align 12
79kernel_stack_bottom:
[e4ddfa8]80 .space TEMP_STACK_SIZE
[762a824]81kernel_stack:
Note: See TracBrowser for help on using the repository browser.