]> git.proxmox.com Git - mirror_qemu.git/blame - target-i386/opreg_template.h
Disable 64-bit instructions on 32-bit CPU, by Aurelien Jarno.
[mirror_qemu.git] / target-i386 / opreg_template.h
CommitLineData
2c0262af
FB
1/*
2 * i386 micro operations (templates for various register related
3 * operations)
4 *
5 * Copyright (c) 2003 Fabrice Bellard
6 *
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
11 *
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 */
21void OPPROTO glue(op_movl_A0,REGNAME)(void)
22{
14ce26e7 23 A0 = (uint32_t)REG;
2c0262af
FB
24}
25
26void OPPROTO glue(op_addl_A0,REGNAME)(void)
27{
14ce26e7 28 A0 = (uint32_t)(A0 + REG);
2c0262af
FB
29}
30
31void OPPROTO glue(glue(op_addl_A0,REGNAME),_s1)(void)
32{
14ce26e7 33 A0 = (uint32_t)(A0 + (REG << 1));
2c0262af
FB
34}
35
36void OPPROTO glue(glue(op_addl_A0,REGNAME),_s2)(void)
37{
14ce26e7 38 A0 = (uint32_t)(A0 + (REG << 2));
2c0262af
FB
39}
40
41void OPPROTO glue(glue(op_addl_A0,REGNAME),_s3)(void)
42{
14ce26e7
FB
43 A0 = (uint32_t)(A0 + (REG << 3));
44}
45
46#ifdef TARGET_X86_64
47void OPPROTO glue(op_movq_A0,REGNAME)(void)
48{
49 A0 = REG;
50}
51
52void OPPROTO glue(op_addq_A0,REGNAME)(void)
53{
54 A0 = (A0 + REG);
55}
56
57void OPPROTO glue(glue(op_addq_A0,REGNAME),_s1)(void)
58{
59 A0 = (A0 + (REG << 1));
60}
61
62void OPPROTO glue(glue(op_addq_A0,REGNAME),_s2)(void)
63{
64 A0 = (A0 + (REG << 2));
2c0262af
FB
65}
66
14ce26e7
FB
67void OPPROTO glue(glue(op_addq_A0,REGNAME),_s3)(void)
68{
69 A0 = (A0 + (REG << 3));
70}
71#endif
72
2c0262af
FB
73void OPPROTO glue(op_movl_T0,REGNAME)(void)
74{
75 T0 = REG;
76}
77
78void OPPROTO glue(op_movl_T1,REGNAME)(void)
79{
80 T1 = REG;
81}
82
83void OPPROTO glue(op_movh_T0,REGNAME)(void)
84{
85 T0 = REG >> 8;
86}
87
88void OPPROTO glue(op_movh_T1,REGNAME)(void)
89{
90 T1 = REG >> 8;
91}
92
93void OPPROTO glue(glue(op_movl,REGNAME),_T0)(void)
94{
14ce26e7 95 REG = (uint32_t)T0;
2c0262af
FB
96}
97
98void OPPROTO glue(glue(op_movl,REGNAME),_T1)(void)
99{
14ce26e7 100 REG = (uint32_t)T1;
2c0262af
FB
101}
102
103void OPPROTO glue(glue(op_movl,REGNAME),_A0)(void)
14ce26e7
FB
104{
105 REG = (uint32_t)A0;
106}
107
108#ifdef TARGET_X86_64
109void OPPROTO glue(glue(op_movq,REGNAME),_T0)(void)
110{
111 REG = T0;
112}
113
114void OPPROTO glue(glue(op_movq,REGNAME),_T1)(void)
115{
116 REG = T1;
117}
118
119void OPPROTO glue(glue(op_movq,REGNAME),_A0)(void)
2c0262af
FB
120{
121 REG = A0;
122}
14ce26e7 123#endif
2c0262af
FB
124
125/* mov T1 to REG if T0 is true */
126void OPPROTO glue(glue(op_cmovw,REGNAME),_T1_T0)(void)
127{
128 if (T0)
14ce26e7 129 REG = (REG & ~0xffff) | (T1 & 0xffff);
128b346e 130 FORCE_RET();
2c0262af
FB
131}
132
133void OPPROTO glue(glue(op_cmovl,REGNAME),_T1_T0)(void)
14ce26e7
FB
134{
135 if (T0)
136 REG = (uint32_t)T1;
137 FORCE_RET();
138}
139
140#ifdef TARGET_X86_64
141void OPPROTO glue(glue(op_cmovq,REGNAME),_T1_T0)(void)
2c0262af
FB
142{
143 if (T0)
144 REG = T1;
128b346e 145 FORCE_RET();
2c0262af 146}
14ce26e7 147#endif
2c0262af
FB
148
149/* NOTE: T0 high order bits are ignored */
150void OPPROTO glue(glue(op_movw,REGNAME),_T0)(void)
151{
14ce26e7 152 REG = (REG & ~0xffff) | (T0 & 0xffff);
2c0262af
FB
153}
154
155/* NOTE: T0 high order bits are ignored */
156void OPPROTO glue(glue(op_movw,REGNAME),_T1)(void)
157{
14ce26e7 158 REG = (REG & ~0xffff) | (T1 & 0xffff);
2c0262af
FB
159}
160
161/* NOTE: A0 high order bits are ignored */
162void OPPROTO glue(glue(op_movw,REGNAME),_A0)(void)
163{
14ce26e7 164 REG = (REG & ~0xffff) | (A0 & 0xffff);
2c0262af
FB
165}
166
167/* NOTE: T0 high order bits are ignored */
168void OPPROTO glue(glue(op_movb,REGNAME),_T0)(void)
169{
14ce26e7 170 REG = (REG & ~0xff) | (T0 & 0xff);
2c0262af
FB
171}
172
173/* NOTE: T0 high order bits are ignored */
174void OPPROTO glue(glue(op_movh,REGNAME),_T0)(void)
175{
14ce26e7 176 REG = (REG & ~0xff00) | ((T0 & 0xff) << 8);
2c0262af
FB
177}
178
179/* NOTE: T1 high order bits are ignored */
180void OPPROTO glue(glue(op_movb,REGNAME),_T1)(void)
181{
14ce26e7 182 REG = (REG & ~0xff) | (T1 & 0xff);
2c0262af
FB
183}
184
185/* NOTE: T1 high order bits are ignored */
186void OPPROTO glue(glue(op_movh,REGNAME),_T1)(void)
187{
14ce26e7 188 REG = (REG & ~0xff00) | ((T1 & 0xff) << 8);
2c0262af 189}
14ce26e7 190