Subversion Repositories HelenOS-historic

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 jermar 1
#
2
# Copyright (C) 2001-2004 Jakub Jermar
3
# All rights reserved.
4
#
5
# Redistribution and use in source and binary forms, with or without
6
# modification, are permitted provided that the following conditions
7
# are met:
8
#
9
# - Redistributions of source code must retain the above copyright
10
#   notice, this list of conditions and the following disclaimer.
11
# - Redistributions in binary form must reproduce the above copyright
12
#   notice, this list of conditions and the following disclaimer in the
13
#   documentation and/or other materials provided with the distribution.
14
# - The name of the author may not be used to endorse or promote products
15
#   derived from this software without specific prior written permission.
16
#
17
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20
# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
#
28
 
29
.text
30
 
31
.macro cp0_read reg
32
    mfc0 $2,\reg
33
    j $31
34
    nop
35
.endm
36
 
37
.macro cp0_write reg
38
    mtc0 $4,\reg
39
    j $31
40
    nop
41
.endm
42
 
43
.set noat
44
.set noreorder
45
.set nomacro
46
 
47
.global cp0_index_read
48
.global cp0_index_write
49
.global cp0_random_read
50
.global cp0_entry_lo0_read
51
.global cp0_entry_lo0_write
52
.global cp0_entry_lo1_read
53
.global cp0_entry_lo1_write
54
.global cp0_context_read
55
.global cp0_context_write
56
.global cp0_pagemask_read
57
.global cp0_pagemask_write
58
.global cp0_wired_read
59
.global cp0_wired_write
60
.global cp0_badvaddr_read
61
.global cp0_count_read
62
.global cp0_count_write
63
.global cp0_hi_read
64
.global cp0_hi_write
65
.global cp0_compare_read
66
.global cp0_compare_write
67
.global cp0_status_read
68
.global cp0_status_write
69
.global cp0_cause_read
70
.global cp0_epc_read
71
.global cp0_epc_write
72
.global cp0_prid_read
73
 
74
cp0_index_read:		cp0_read $0
75
cp0_index_write:	cp0_write $0
76
 
77
cp0_random_read:	cp0_read $1
78
 
79
cp0_entry_lo0_read:	cp0_read $2
80
cp0_entry_lo0_write:	cp0_write $2
81
 
82
cp0_entry_lo1_read:	cp0_read $3
83
cp0_entry_lo1_write:	cp0_write $3
84
 
85
cp0_context_read:	cp0_read $4
86
cp0_context_write:	cp0_write $4
87
 
88
cp0_pagemask_read:	cp0_read $5
89
cp0_pagemask_write:	cp0_write $5
90
 
91
cp0_wired_read:		cp0_read $6
92
cp0_wired_write:	cp0_write $6
93
 
94
cp0_badvaddr_read:	cp0_read $8
95
 
96
cp0_count_read:		cp0_read $9
97
cp0_count_write:	cp0_write $9
98
 
99
cp0_entry_hi_read:	cp0_read $10
100
cp0_entry_hi_write:	cp0_write $10
101
 
102
cp0_compare_read:	cp0_read $11
103
cp0_compare_write:	cp0_write $11
104
 
105
cp0_status_read:	cp0_read $12
106
cp0_status_write:	cp0_write $12
107
 
108
cp0_cause_read:		cp0_read $13
109
 
110
cp0_epc_read:		cp0_read $14
111
cp0_epc_write:		cp0_write $14
112
 
113
cp0_prid_read:		cp0_read $15
114
 
115
 
116
.global tlbp
117
tlbp:
118
	tlbp
119
	j $31
120
	nop
121
 
122
.global tlbr
123
tlbr:
124
	tlbr
125
	j $31
126
	nop
127
 
128
.global tlbwi
129
tlbwi:
130
	tlbwi
131
	j $31
132
	nop
133
 
134
.global tlbwr
135
tlbwr:
136
	tlbwr
137
	j $31
138
	nop
139
 
140
.global cpu_halt
141
cpu_halt:
142
	j cpu_halt
143
	nop
144
 
145
 
146
# THIS IS USERSPACE CODE
147
.global utext
148
utext:
149
	j $31
150
	nop
151
utext_end:
152
 
153
.data
154
.global utext_size
155
utext_size:
156
	.long utext_end-utext
157