xref: /openbmc/qemu/target/mips/tcg/system_helper.h.inc (revision 65cb7129f4160c7e07a0da107f888ec73ae96776)
1*32cad1ffSPhilippe Mathieu-Daudé/*
2*32cad1ffSPhilippe Mathieu-Daudé *  QEMU MIPS TCG system helpers
3*32cad1ffSPhilippe Mathieu-Daudé *
4*32cad1ffSPhilippe Mathieu-Daudé *  Copyright (c) 2004-2005 Jocelyn Mayer
5*32cad1ffSPhilippe Mathieu-Daudé *  Copyright (c) 2006 Marius Groeger (FPU operations)
6*32cad1ffSPhilippe Mathieu-Daudé *  Copyright (c) 2006 Thiemo Seufer (MIPS32R2 support)
7*32cad1ffSPhilippe Mathieu-Daudé *  Copyright (c) 2009 CodeSourcery (MIPS16 and microMIPS support)
8*32cad1ffSPhilippe Mathieu-Daudé *
9*32cad1ffSPhilippe Mathieu-Daudé * SPDX-License-Identifier: LGPL-2.1-or-later
10*32cad1ffSPhilippe Mathieu-Daudé */
11*32cad1ffSPhilippe Mathieu-Daudé
12*32cad1ffSPhilippe Mathieu-Daudé/* CP0 helpers */
13*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_mvpcontrol, tl, env)
14*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_mvpconf0, tl, env)
15*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_mvpconf1, tl, env)
16*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_vpecontrol, tl, env)
17*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_vpeconf0, tl, env)
18*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_random, tl, env)
19*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tcstatus, tl, env)
20*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tcstatus, tl, env)
21*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tcbind, tl, env)
22*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tcbind, tl, env)
23*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tcrestart, tl, env)
24*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tcrestart, tl, env)
25*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tchalt, tl, env)
26*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tchalt, tl, env)
27*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tccontext, tl, env)
28*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tccontext, tl, env)
29*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tcschedule, tl, env)
30*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tcschedule, tl, env)
31*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_tcschefback, tl, env)
32*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_tcschefback, tl, env)
33*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_count, tl, env)
34*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_entryhi, tl, env)
35*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_status, tl, env)
36*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_cause, tl, env)
37*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_epc, tl, env)
38*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_ebase, tl, env)
39*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mftc0_configx, tl, env, tl)
40*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_lladdr, tl, env)
41*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_maar, tl, env)
42*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfhc0_maar, tl, env)
43*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mfc0_watchlo, tl, env, i32)
44*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mfc0_watchhi, tl, env, i32)
45*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mfhc0_watchhi, tl, env, i32)
46*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mfc0_debug, tl, env)
47*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftc0_debug, tl, env)
48*32cad1ffSPhilippe Mathieu-Daudé#ifdef TARGET_MIPS64
49*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_tcrestart, tl, env)
50*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_tchalt, tl, env)
51*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_tccontext, tl, env)
52*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_tcschedule, tl, env)
53*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_tcschefback, tl, env)
54*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_lladdr, tl, env)
55*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dmfc0_maar, tl, env)
56*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(dmfc0_watchlo, tl, env, i32)
57*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(dmfc0_watchhi, tl, env, i32)
58*32cad1ffSPhilippe Mathieu-Daudé#endif /* TARGET_MIPS64 */
59*32cad1ffSPhilippe Mathieu-Daudé
60*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_index, void, env, tl)
61*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_mvpcontrol, void, env, tl)
62*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_vpecontrol, void, env, tl)
63*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_vpecontrol, void, env, tl)
64*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_vpeconf0, void, env, tl)
65*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_vpeconf0, void, env, tl)
66*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_vpeconf1, void, env, tl)
67*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_yqmask, void, env, tl)
68*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_vpeopt, void, env, tl)
69*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_entrylo0, void, env, tl)
70*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tcstatus, void, env, tl)
71*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tcstatus, void, env, tl)
72*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tcbind, void, env, tl)
73*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tcbind, void, env, tl)
74*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tcrestart, void, env, tl)
75*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tcrestart, void, env, tl)
76*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tchalt, void, env, tl)
77*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tchalt, void, env, tl)
78*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tccontext, void, env, tl)
79*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tccontext, void, env, tl)
80*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tcschedule, void, env, tl)
81*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tcschedule, void, env, tl)
82*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_tcschefback, void, env, tl)
83*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_tcschefback, void, env, tl)
84*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_entrylo1, void, env, tl)
85*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_context, void, env, tl)
86*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_memorymapid, void, env, tl)
87*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_pagemask, void, env, tl)
88*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_pagegrain, void, env, tl)
89*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_segctl0, void, env, tl)
90*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_segctl1, void, env, tl)
91*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_segctl2, void, env, tl)
92*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_pwfield, void, env, tl)
93*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_pwsize, void, env, tl)
94*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_wired, void, env, tl)
95*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsconf0, void, env, tl)
96*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsconf1, void, env, tl)
97*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsconf2, void, env, tl)
98*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsconf3, void, env, tl)
99*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsconf4, void, env, tl)
100*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_hwrena, void, env, tl)
101*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_pwctl, void, env, tl)
102*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_count, void, env, tl)
103*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_entryhi, void, env, tl)
104*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_entryhi, void, env, tl)
105*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_compare, void, env, tl)
106*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_status, void, env, tl)
107*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_status, void, env, tl)
108*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_intctl, void, env, tl)
109*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_srsctl, void, env, tl)
110*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_cause, void, env, tl)
111*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_cause, void, env, tl)
112*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_ebase, void, env, tl)
113*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_ebase, void, env, tl)
114*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_config0, void, env, tl)
115*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_config2, void, env, tl)
116*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_config3, void, env, tl)
117*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_config4, void, env, tl)
118*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_config5, void, env, tl)
119*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_lladdr, void, env, tl)
120*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_maar, void, env, tl)
121*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mthc0_maar, void, env, tl)
122*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_maari, void, env, tl)
123*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mtc0_watchlo, void, env, tl, i32)
124*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mtc0_watchhi, void, env, tl, i32)
125*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mthc0_watchhi, void, env, tl, i32)
126*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_xcontext, void, env, tl)
127*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_framemask, void, env, tl)
128*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_debug, void, env, tl)
129*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttc0_debug, void, env, tl)
130*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_performance0, void, env, tl)
131*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_errctl, void, env, tl)
132*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_taglo, void, env, tl)
133*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_datalo, void, env, tl)
134*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_taghi, void, env, tl)
135*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mtc0_datahi, void, env, tl)
136*32cad1ffSPhilippe Mathieu-Daudé
137*32cad1ffSPhilippe Mathieu-Daudé#if defined(TARGET_MIPS64)
138*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(dmtc0_entrylo0, void, env, i64)
139*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(dmtc0_entrylo1, void, env, i64)
140*32cad1ffSPhilippe Mathieu-Daudé#endif
141*32cad1ffSPhilippe Mathieu-Daudé
142*32cad1ffSPhilippe Mathieu-Daudé/* MIPS MT functions */
143*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mftgpr, tl, env, i32)
144*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mftlo, tl, env, i32)
145*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mfthi, tl, env, i32)
146*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mftacx, tl, env, i32)
147*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(mftdsp, tl, env)
148*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mttgpr, void, env, tl, i32)
149*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mttlo, void, env, tl, i32)
150*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mtthi, void, env, tl, i32)
151*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(mttacx, void, env, tl, i32)
152*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(mttdsp, void, env, tl)
153*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_0(dmt, tl)
154*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_0(emt, tl)
155*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dvpe, tl, env)
156*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(evpe, tl, env)
157*32cad1ffSPhilippe Mathieu-Daudé
158*32cad1ffSPhilippe Mathieu-Daudé/* R6 Multi-threading */
159*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(dvp, tl, env)
160*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(evp, tl, env)
161*32cad1ffSPhilippe Mathieu-Daudé
162*32cad1ffSPhilippe Mathieu-Daudé/* TLB */
163*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbwi, void, env)
164*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbwr, void, env)
165*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbp, void, env)
166*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbr, void, env)
167*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbinv, void, env)
168*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(tlbinvf, void, env)
169*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(ginvt, void, env, tl, i32)
170*32cad1ffSPhilippe Mathieu-Daudé
171*32cad1ffSPhilippe Mathieu-Daudé/* Special */
172*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(di, tl, env)
173*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(ei, tl, env)
174*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(eret, void, env)
175*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(eretnc, void, env)
176*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_1(deret, void, env)
177*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(cache, void, env, tl, i32)
178*32cad1ffSPhilippe Mathieu-Daudé
179*32cad1ffSPhilippe Mathieu-Daudé#ifdef TARGET_MIPS64
180*32cad1ffSPhilippe Mathieu-Daudé/* Longson CSR */
181*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(lcsr_rdcsr, i64, env, tl)
182*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_2(lcsr_drdcsr, i64, env, tl)
183*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(lcsr_wrcsr, void, env, tl, tl)
184*32cad1ffSPhilippe Mathieu-DaudéDEF_HELPER_3(lcsr_dwrcsr, void, env, tl, tl)
185*32cad1ffSPhilippe Mathieu-Daudé#endif
186