| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * linux/arch/sh/boot/compressed/head.S |
| * |
| * Copyright (C) 1999 Stuart Menefy |
| * Copyright (C) 2003 SUGIOKA Toshinobu |
| */ |
| |
| .text |
| |
| #include <asm/page.h> |
| |
| .global startup |
| startup: |
| /* Load initial status register */ |
| mov.l init_sr, r1 |
| ldc r1, sr |
| |
| /* Move myself to proper location if necessary */ |
| mova 1f, r0 |
| mov.l 1f, r2 |
| cmp/eq r2, r0 |
| bt clear_bss |
| sub r0, r2 |
| mov.l bss_start_addr, r0 |
| mov #0xffffffe0, r1 |
| and r1, r0 ! align cache line |
| mov.l text_start_addr, r3 |
| mov r0, r1 |
| sub r2, r1 |
| 3: |
| mov.l @r1, r4 |
| mov.l @(4,r1), r5 |
| mov.l @(8,r1), r6 |
| mov.l @(12,r1), r7 |
| mov.l @(16,r1), r8 |
| mov.l @(20,r1), r9 |
| mov.l @(24,r1), r10 |
| mov.l @(28,r1), r11 |
| mov.l r4, @r0 |
| mov.l r5, @(4,r0) |
| mov.l r6, @(8,r0) |
| mov.l r7, @(12,r0) |
| mov.l r8, @(16,r0) |
| mov.l r9, @(20,r0) |
| mov.l r10, @(24,r0) |
| mov.l r11, @(28,r0) |
| #ifdef CONFIG_CPU_SH4 |
| ocbwb @r0 |
| #endif |
| cmp/hi r3, r0 |
| add #-32, r0 |
| bt/s 3b |
| add #-32, r1 |
| mov.l 2f, r0 |
| jmp @r0 |
| nop |
| |
| .align 2 |
| 1: .long 1b |
| 2: .long clear_bss |
| text_start_addr: |
| .long startup |
| |
| /* Clear BSS */ |
| clear_bss: |
| mov.l end_addr, r1 |
| mov.l bss_start_addr, r2 |
| mov #0, r0 |
| l1: |
| mov.l r0, @-r1 |
| cmp/eq r1,r2 |
| bf l1 |
| |
| /* Set the initial pointer. */ |
| mov.l init_stack_addr, r0 |
| mov.l @r0, r15 |
| |
| /* Decompress the kernel */ |
| mov.l decompress_kernel_addr, r0 |
| jsr @r0 |
| nop |
| |
| /* Jump to the start of the decompressed kernel */ |
| mov.l kernel_start_addr, r0 |
| jmp @r0 |
| nop |
| |
| .align 2 |
| bss_start_addr: |
| .long __bss_start |
| end_addr: |
| .long _end |
| init_sr: |
| .long 0x500000F0 /* Privileged mode, Bank=0, Block=1, IMASK=0xF */ |
| kexec_magic: |
| .long 0x400000F0 /* magic used by kexec to parse zImage format */ |
| init_stack_addr: |
| .long stack_start |
| decompress_kernel_addr: |
| .long decompress_kernel |
| kernel_start_addr: |
| #ifdef CONFIG_32BIT |
| .long ___pa(_text+PAGE_SIZE) |
| #else |
| .long _text+PAGE_SIZE |
| #endif |
| |
| .align 9 |
| fake_headers_as_bzImage: |
| .word 0 |
| .ascii "HdrS" ! header signature |
| .word 0x0202 ! header version number (>= 0x0105) |
| ! or else old loadlin-1.5 will fail) |
| .word 0 ! default_switch |
| .word 0 ! SETUPSEG |
| .word 0x1000 |
| .word 0 ! pointing to kernel version string |
| .byte 0 ! = 0, old one (LILO, Loadlin, |
| ! 0xTV: T=0 for LILO |
| ! V = version |
| .byte 1 ! Load flags bzImage=1 |
| .word 0x8000 ! size to move, when setup is not |
| .long 0x100000 ! 0x100000 = default for big kernel |
| .long 0 ! address of loaded ramdisk image |
| .long 0 # its size in bytes |