1 1.7 rin /* $NetBSD: obs600_locore.S,v 1.7 2021/03/02 07:23:22 rin Exp $ */ 2 1.2 rmind 3 1.1 kiyohara /* 4 1.1 kiyohara * Copyright (c) 2009 KIYOHARA Takashi 5 1.1 kiyohara * All rights reserved. 6 1.1 kiyohara * 7 1.1 kiyohara * Redistribution and use in source and binary forms, with or without 8 1.1 kiyohara * modification, are permitted provided that the following conditions 9 1.1 kiyohara * are met: 10 1.1 kiyohara * 1. Redistributions of source code must retain the above copyright 11 1.1 kiyohara * notice, this list of conditions and the following disclaimer. 12 1.1 kiyohara * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 kiyohara * notice, this list of conditions and the following disclaimer in the 14 1.1 kiyohara * documentation and/or other materials provided with the distribution. 15 1.1 kiyohara * 16 1.1 kiyohara * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17 1.1 kiyohara * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 18 1.1 kiyohara * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 19 1.1 kiyohara * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, 20 1.1 kiyohara * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 21 1.1 kiyohara * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 22 1.1 kiyohara * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 1.1 kiyohara * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 24 1.1 kiyohara * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 25 1.1 kiyohara * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 kiyohara * POSSIBILITY OF SUCH DAMAGE. 27 1.1 kiyohara */ 28 1.1 kiyohara 29 1.1 kiyohara #include "opt_ddb.h" 30 1.1 kiyohara #include "opt_ppcarch.h" 31 1.1 kiyohara #include "opt_ppcparam.h" 32 1.1 kiyohara #include "assym.h" 33 1.1 kiyohara #include "ksyms.h" 34 1.1 kiyohara 35 1.1 kiyohara #include <machine/param.h> 36 1.1 kiyohara #include <machine/psl.h> 37 1.1 kiyohara #include <machine/trap.h> 38 1.1 kiyohara #include <machine/asm.h> 39 1.1 kiyohara 40 1.1 kiyohara #include <powerpc/ibm4xx/spr.h> 41 1.1 kiyohara 42 1.1 kiyohara /* 43 1.1 kiyohara * This symbol is here for the benefit of kvm_mkdb, and is supposed to 44 1.1 kiyohara * mark the start of kernel text. 45 1.1 kiyohara */ 46 1.1 kiyohara .text 47 1.1 kiyohara .globl _C_LABEL(kernel_text) 48 1.1 kiyohara _C_LABEL(kernel_text): 49 1.1 kiyohara 50 1.1 kiyohara /* 51 1.1 kiyohara * Kernel start routine for OpenBlockS600 52 1.1 kiyohara * this code is excuted at the very first after the kernel is loaded 53 1.1 kiyohara * by U-Boot. 54 1.1 kiyohara */ 55 1.1 kiyohara .text 56 1.1 kiyohara .globl __start 57 1.1 kiyohara __start: 58 1.1 kiyohara mr %r31, %r3 /* argc of 'go's */ 59 1.1 kiyohara mr %r30, %r4 /* argv of 'go's */ 60 1.1 kiyohara mr %r29, %r6 /* arg string of 'bootm's */ 61 1.1 kiyohara 62 1.1 kiyohara li %r0, 0 63 1.1 kiyohara mtmsr %r0 /* Disable FPU/MMU/exceptions */ 64 1.1 kiyohara isync 65 1.1 kiyohara 66 1.1 kiyohara #ifdef PPC_4XX_NOCACHE 67 1.1 kiyohara /* Disable all caches for physical addresses */ 68 1.1 kiyohara li %r0, 0 69 1.1 kiyohara #else 70 1.1 kiyohara /* Allow cacheing for only the first 2GB of RAM */ 71 1.1 kiyohara lis %r0, 0xffff 72 1.1 kiyohara #endif 73 1.1 kiyohara mtdccr %r0 74 1.1 kiyohara mticcr %r0 75 1.1 kiyohara 76 1.1 kiyohara /* Invalidate all TLB entries */ 77 1.1 kiyohara tlbia 78 1.1 kiyohara sync 79 1.1 kiyohara isync 80 1.1 kiyohara 81 1.1 kiyohara /* get start of bss */ 82 1.1 kiyohara lis %r3, _C_LABEL(_edata)-4@ha 83 1.1 kiyohara addi %r3, %r3, _C_LABEL(_edata)-4@l 84 1.1 kiyohara /* get end of kernel memory */ 85 1.1 kiyohara lis %r8, _C_LABEL(end)@ha 86 1.1 kiyohara addi %r8, %r8, _C_LABEL(end)@l 87 1.1 kiyohara /* zero bss */ 88 1.1 kiyohara li %r4, 0 89 1.6 joerg 2: stwu %r4, 4(%r3) 90 1.1 kiyohara cmpw %r3, %r8 91 1.1 kiyohara bne+ 2b 92 1.1 kiyohara 93 1.1 kiyohara #if NKSYMS || defined(DDB) || defined(MODULAR) 94 1.1 kiyohara /* If we had symbol table location we'd store it here and would've adjusted r8 here */ 95 1.1 kiyohara lis %r7, _C_LABEL(startsym)@ha 96 1.1 kiyohara addi %r7, %r7, _C_LABEL(startsym)@l 97 1.1 kiyohara stw %r8, 0(%r7) 98 1.1 kiyohara lis %r7, _C_LABEL(endsym)@ha 99 1.1 kiyohara addi %r7, %r7, _C_LABEL(endsym)@l 100 1.1 kiyohara stw %r8, 0(%r7) 101 1.1 kiyohara #endif 102 1.1 kiyohara 103 1.1 kiyohara /* Set kernel MMU context. */ 104 1.1 kiyohara li %r0, KERNEL_PID 105 1.1 kiyohara mtpid %r0 106 1.1 kiyohara sync 107 1.1 kiyohara 108 1.1 kiyohara INIT_CPUINFO(8,1,9,0) 109 1.1 kiyohara mr %r4, %r8 110 1.1 kiyohara 111 1.1 kiyohara lis %r3, __start@ha 112 1.1 kiyohara addi %r3, %r3, __start@l 113 1.1 kiyohara 114 1.5 kiyohara mr %r5, %r31 /* argc of 'go's */ 115 1.5 kiyohara mr %r6, %r30 /* argv of 'go's */ 116 1.5 kiyohara mr %r7, %r29 /* arg strings of 'bootm's */ 117 1.1 kiyohara 118 1.1 kiyohara bl _C_LABEL(initppc) 119 1.1 kiyohara bl _C_LABEL(main) 120 1.1 kiyohara 121 1.1 kiyohara not_reached: 122 1.1 kiyohara b not_reached 123 1.1 kiyohara 124 1.1 kiyohara #include <powerpc/ibm4xx/4xx_locore.S> 125