sh: sh2: Remove CPU support
[oweals/u-boot.git] / arch / sh / lib / start.S
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Copyright (C) 2016 Vladimir Zapolskiy <vz@mleia.com>
4  * Copyright (C) 2007, 2010 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
5  */
6
7 #include <asm-offsets.h>
8 #include <config.h>
9
10         .text
11         .align  2
12
13         .global _start
14 _start:
15         mov.l   ._lowlevel_init, r0
16 100:    bsrf    r0
17         nop
18
19         bsr     1f
20         nop
21 1:      sts     pr, r5
22         mov.l   ._reloc_dst, r4
23         add     #(_start-1b), r5
24         mov.l   ._reloc_dst_end, r6
25
26 2:      mov.l   @r5+, r1
27         mov.l   r1, @r4
28         add     #4, r4
29         cmp/hs  r6, r4
30         bf      2b
31
32         mov.l   ._bss_start, r4
33         mov.l   ._bss_end, r5
34         mov     #0, r1
35
36 3:      mov.l   r1, @r4                 /* bss clear */
37         add     #4, r4
38         cmp/hs  r5, r4
39         bf      3b
40
41         mov.l   ._gd_init, r13          /* global data */
42         mov.l   ._stack_init, r15       /* stack */
43
44         mov.l   ._sh_generic_init, r0
45         jsr     @r0
46         mov     #0, r4
47
48 loop:
49         bra     loop
50
51         .align  2
52
53 ._lowlevel_init:        .long   (lowlevel_init - (100b + 4))
54 ._reloc_dst:            .long   _start
55 ._reloc_dst_end:        .long   reloc_dst_end
56 ._bss_start:            .long   bss_start
57 ._bss_end:              .long   bss_end
58 ._gd_init:              .long   (_start - GENERATED_GBL_DATA_SIZE)
59 ._stack_init:           .long   (_start - GENERATED_GBL_DATA_SIZE - CONFIG_SYS_MALLOC_LEN - 16)
60 ._sh_generic_init:      .long   board_init_f