blob: 7a934e24d4077b2423094cb440b803d7d2cf445f [file] [log] [blame]
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +09001/*
2 * (C) Copyright 2007
3 * Yoshihiro Shimoda <shimoda.yoshihiro@renesas.com>
4 *
5 * (C) Copyright 2007
6 * Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
7 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +09009 */
10
Wolfgang Denk0191e472010-10-26 14:34:52 +020011#include <asm-offsets.h>
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +090012#include <config.h>
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +090013
14 .text
15 .align 2
16
17 .global _start
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090018_sh_start:
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +090019 mov.l ._lowlevel_init, r0
20100: bsrf r0
21 nop
22
23 bsr 1f
24 nop
251: sts pr, r5
26 mov.l ._reloc_dst, r4
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090027 add #(_sh_start-1b), r5
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +090028 mov.l ._reloc_dst_end, r6
29
302: mov.l @r5+, r1
31 mov.l r1, @r4
32 add #4, r4
33 cmp/hs r6, r4
34 bf 2b
35
36 mov.l ._bss_start, r4
37 mov.l ._bss_end, r5
38 mov #0, r1
39
403: mov.l r1, @r4 /* bss clear */
41 add #4, r4
42 cmp/hs r5, r4
43 bf 3b
44
45 mov.l ._gd_init, r13 /* global data */
46 mov.l ._stack_init, r15 /* stack */
47
48 mov.l ._sh_generic_init, r0
49 jsr @r0
50 nop
51
52loop:
53 bra loop
54
55 .align 2
56
57._lowlevel_init: .long (lowlevel_init - (100b + 4))
58._reloc_dst: .long reloc_dst
59._reloc_dst_end: .long reloc_dst_end
60._bss_start: .long bss_start
61._bss_end: .long bss_end
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090062._gd_init: .long (_sh_start - GENERATED_GBL_DATA_SIZE)
63._stack_init: .long (_sh_start - GENERATED_GBL_DATA_SIZE - CONFIG_SYS_MALLOC_LEN - 16)
Yoshihiro Shimodaad1a3a92007-12-03 22:58:45 +090064._sh_generic_init: .long sh_generic_init