-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcrt0.s
109 lines (90 loc) · 2.67 KB
/
crt0.s
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
;--------------------------------------------------------------------------
; crt0.s - adopted for a KC85(5)
;
; Copyright (C) 2014, Andreas Ziermann (Z1013)
; 2015, Bert Lange
;
; This library is free software; you can redistribute it and/or modify it
; under the terms of the GNU General Public License as published by the
; Free Software Foundation; either version 2, or (at your option) any
; later version.
;
; This library is distributed in the hope that it will be useful,
; but WITHOUT ANY WARRANTY; without even the implied warranty of
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
; GNU General Public License for more details.
;
; You should have received a copy of the GNU General Public License
; along with this library; see the file COPYING. If not, write to the
; Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
; MA 02110-1301, USA.
;
; As a special exception, if you link this library with other files,
; some of which are compiled with SDCC, to produce an executable,
; this library does not by itself cause the resulting executable to
; be covered by the GNU General Public License. This exception does
; not however invalidate any other reasons why the executable file
; might be covered by the GNU General Public License.
;--------------------------------------------------------------------------
.module crt0
.globl _main
.area _HEADER (ABS)
.org 0x200
;; Ordering of segments for the linker.
.area _HOME
.area _CODE
.area _INITIALIZER
.area _GSINIT
.area _GSFINAL
.area _GSEXIT
.area _GSEXITFINAL
.area _DATA
.area _INITIALIZED
.area _BSEG
.area _BSS
.area _STACK
.area _HEAP
.area _CODE
.globl init
init:
;; Initialise global variables
call gsinit
call _main
;call gsexit
; use call LOOP instead of ret, works also
; with direct load+start on simulator
call #0xF003
.db #0x12
.area _GSINIT
gsinit::
; copy initialized variables to 'RAM'
ld bc, #l__INITIALIZER
ld a, b
or a, c
jr Z, gsinit_zero
ld de, #s__INITIALIZED
ld hl, #s__INITIALIZER
ldir
gsinit_zero:
; did we have data to zero?
ld bc, #l__DATA
ld a, b
or a, c
;jr Z, gsinit_next
ret Z
; zero uninitialized stuff
xor a ; clear a and carry
ld bc, #l__DATA ; ram size left
ld hl, #s__DATA
ld de, #s__DATA+1
ld ( hl), a
ldir
gsinit_next:
.area _GSFINAL
ret
.area _GSEXIT
gsexit::
.area _GSEXITFINAL
;ret
.area _STACK
; stack is usally located at 0x01c4