2  *  linux/arch/m32r/kernel/head.S
 
   6  *  Copyright (c) 2001, 2002  Hiroyuki Kondo, Hirokazu Takata,
 
  12 #include <linux/init.h>
 
  17 #include <linux/config.h>
 
  18 #include <linux/linkage.h>
 
  19 #include <asm/segment.h>
 
  21 #include <asm/pgtable.h>
 
  22 #include <asm/assembler.h>
 
  24 #include <asm/mmu_context.h>
 
  27  * References to members of the boot_cpu_data structure.
 
  36         /* Setup up the stack pointer */
 
  37         LDIMM   (r0, spi_stack_top)
 
  38         LDIMM   (r1, spu_stack_top)
 
  43         ldi     r0, #0x0000             /* use SPI, disable EI */
 
  46         /* Set up the stack pointer */
 
  47         LDIMM   (r0, stack_start)
 
  52  * Clear BSS first so that there are no surprises...
 
  54 #ifdef CONFIG_ISA_DUAL_ISSUE
 
  56         LDIMM   (r2, __bss_start)
 
  58         sub     r3, r2          ; BSS size in bytes
 
  59         ; R4 = BSS size in longwords (rounded down)
 
  60         mv      r4, r3              ||  ldi     r1, #0
 
  61         srli    r4, #4              ||  addi    r2, #-4
 
  64 #ifndef CONFIG_CHIP_M32310
 
  65         ; Touch memory for the no-write-allocating cache.
 
  68         st      r1, @+r2            ||  addi    r4, #-1
 
  71         st      r1, @+r2            ||  cmpeq   r1, r4  ; R4 = 0?
 
  78         stb     r1, @r2             ||  addi    r4, #-1
 
  83 #else /* not CONFIG_ISA_DUAL_ISSUE */
 
  85         LDIMM   (r2, __bss_start)
 
  87         sub     r3, r2          ; BSS size in bytes
 
  89         srli    r4, #2          ; R4 = BSS size in longwords (rounded down)
 
  90         ldi     r1, #0          ; clear R1 for longwords store
 
  91         addi    r2, #-4         ; account for pre-inc store
 
  92         beqz    r4, .Lendloop1  ; any more to go?
 
  94         st      r1, @+r2        ; yep, zero out another longword
 
  95         addi    r4, #-1         ; decrement count
 
  96         bnez    r4, .Lloop1     ; go do some more
 
  98         and3    r4, r3, #3      ; get no. of remaining BSS bytes to clear
 
  99         addi    r2, #4          ; account for pre-inc store
 
 100         beqz    r4, .Lendloop2  ; any more to go?
 
 102         stb     r1, @r2         ; yep, zero out another byte
 
 103         addi    r2, #1          ; bump address
 
 104         addi    r4, #-1         ; decrement count
 
 105         bnez    r4, .Lloop2     ; go do some more
 
 108 #endif /* not CONFIG_ISA_DUAL_ISSUE */
 
 110 #if 0  /* M32R_FIXME */
 
 112  * Copy data segment from ROM to RAM.
 
 114         .global ROM_D, TOP_DATA, END_DATA
 
 129         LDIMM   (r2, start_kernel)
 
 133         bra     1b              ; main should never return here, but
 
 134                                 ; just in case, we know what happens.
 
 144         LDIMM  (r4, eit_vector)
 
 151         or3   r4, r4, #low(MATM)
 
 153         st    r5, @r4            ; Set MATM Reg(T bit ON)
 
 154         ld    r6, @r4            ; MATM Check
 
 161         ld    r6, @r4            ; MATM Check
 
 162         seth  r4, #high(M32R_ICU_ISTS_ADDR)
 
 163         or3   r4, r4, #low(M32R_ICU_ISTS_ADDR)
 
 164         ld    r5, @r4           ; Read ISTSi reg.
 
 166         slli  r5, #13  ; PIML check
 
 168         seth  r4, #high(M32R_ICU_IMASK_ADDR)
 
 169         or3   r4, r4, #low(M32R_ICU_IMASK_ADDR)
 
 170         st    r5, @r4           ; Write IMASKi reg.
 
 171         slli  r6, #4   ; ISN check
 
 173         seth  r4, #high(M32R_IRQ_IPI5)
 
 174         or3   r4, r4, #low(M32R_IRQ_IPI5)
 
 175         bne   r4, r6, 2f  ; if (ISN != CPU_BOOT_IPI) goto sleep;
 
 177 ;; check cpu_bootout_map and set cpu_bootin_map
 
 178         LDIMM (r4, cpu_bootout_map)
 
 180         seth  r5, #high(M32R_CPUID_PORTL)
 
 181         or3   r5, r5, #low(M32R_CPUID_PORTL)
 
 187         LDIMM (r4, cpu_bootin_map)
 
 197         LDIMM (r4, stack_start)
 
 201 ;; setup BPC (start_secondary)
 
 202         LDIMM (r4, start_secondary)
 
 205         rte  ; goto startup_secondary
 
 213         or3   r4, r4, #low(MATM)
 
 215         st    r5, @r4            ; Set MATM Reg(T bit OFF)
 
 216         ld    r6, @r4            ; MATM Check
 
 218         seth  r5, #high(__PAGE_OFFSET)
 
 219         or3   r5, r5, #low(__PAGE_OFFSET)
 
 226         ;; SLEEP and wait IPI
 
 228         seth  r5, #high(__PAGE_OFFSET)
 
 229         or3   r5, r5, #low(__PAGE_OFFSET)
 
 235 #endif  /* CONFIG_SMP */
 
 238         .long   init_thread_union+8192
 
 242  * This is initialized to create a identity-mapping at 0-4M (for bootup
 
 243  * purposes) and another mapping of the 0-4M area at virtual address
 
 248 #define  MOUNT_ROOT_RDONLY    1
 
 249 #define  RAMDISK_FLAGS        0         ; 1024KB
 
 250 #define  ORIG_ROOT_DEV        0x0100    ; /dev/ram0 (major:01, minor:00)
 
 251 #define  LOADER_TYPE          1         ; (??? - non-zero value seems
 
 252                                         ; to be needed to boot from initrd)
 
 254 #define  COMMAND_LINE ""
 
 256         .section        .empty_zero_page, "aw"
 
 257 ENTRY(empty_zero_page)
 
 258         .long   MOUNT_ROOT_RDONLY               /* offset: +0x00 */
 
 262         .long   0       /* INITRD_START */      /* +0x10 */
 
 263         .long   0       /* INITRD_SIZE */
 
 264         .long   0       /* CPU_CLOCK */
 
 265         .long   0       /* BUS_CLOCK */
 
 266         .long   0       /* TIMER_DIVIDE */      /* +0x20 */
 
 272 /*------------------------------------------------------------------------
 
 277         .global spi_stack_top
 
 283         .global spu_stack_top