VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/BIOS/inlines.h@ 61583

Last change on this file since 61583 was 60422, checked in by vboxsync, 9 years ago

VGABIOS,PCBIOS: Build variants for 80286 and 8086 in addition to the default 80386 one. Added build time checking of the BIOSORG results (sed + map file). Fixed shutdown code 0ah jump.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.0 KB
Line 
1/** @file
2 * Inline routines for Watcom C.
3 */
4
5/*
6 * Copyright (C) 2010-2015 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 */
16
17
18extern unsigned inp(unsigned port);
19extern unsigned outp(unsigned port, unsigned value);
20extern unsigned inpw(unsigned port);
21extern unsigned outpw(unsigned port, unsigned value);
22#pragma intrinsic(inp,outp,inpw,outpw)
23#define inb(p) inp(p)
24#define outb(p, v) outp(p, v)
25#define inw(p) inpw(p)
26#define outw(p, v) outpw(p, v)
27
28extern uint8_t read_byte(uint16_t seg, uint16_t offset);
29extern uint16_t read_word(uint16_t seg, uint16_t offset);
30extern uint32_t read_dword(uint16_t seg, uint16_t offset);
31extern void write_byte(uint16_t seg, uint16_t offset, uint8_t data);
32extern void write_word(uint16_t seg, uint16_t offset, uint16_t data);
33extern void write_dword(uint16_t seg, uint16_t offset, uint32_t data);
34
35void int_enable(void);
36#pragma aux int_enable = "sti" modify exact [] nomemory;
37
38void int_disable(void);
39#pragma aux int_disable = "cli" modify exact [] nomemory;
40
41uint16_t int_query(void);
42#pragma aux int_query = \
43 "pushf" \
44 "pop ax" \
45 value [ax] modify exact [ax] nomemory;
46
47void int_restore(uint16_t old_flags);
48#pragma aux int_restore = \
49 "push ax" \
50 "popf" \
51 parm [ax] modify exact [] nomemory;
52
53void halt(void);
54#pragma aux halt = "hlt" modify exact [] nomemory;
55
56void halt_forever(void);
57#pragma aux halt_forever = \
58 "forever:" \
59 "hlt" \
60 "jmp forever" \
61 modify exact [] nomemory aborts;
62
63void rep_movsw(void __far *d, void __far *s, int nwords);
64#pragma aux rep_movsw = \
65 "push ds" \
66 "mov ds, dx" \
67 "rep movsw" \
68 "pop ds" \
69 parm [es di] [dx si] [cx];
70
71char __far *rep_insb(char __far *buffer, unsigned nbytes, unsigned port);
72#pragma aux rep_insb = ".286" "rep insb" parm [es di] [cx] [dx] value [es di] modify exact [cx di];
73
74char __far *rep_insw(char __far *buffer, unsigned nwords, unsigned port);
75#pragma aux rep_insw = ".286" "rep insw" parm [es di] [cx] [dx] value [es di] modify exact [cx di];
76
77#if VBOX_BIOS_CPU >= 80386
78char __far *rep_insd(char __far *buffer, unsigned ndwords, unsigned port);
79# pragma aux rep_insd = ".386" "rep insd" parm [es di] [cx] [dx] value [es di] modify exact [cx di];
80#endif
81
82char __far *rep_outsb(char __far *buffer, unsigned nbytes, unsigned port);
83#pragma aux rep_outsb = ".286" "rep outs dx,byte ptr es:[si]" parm [es si] [cx] [dx] value [es si] modify exact [cx si];
84
85char __far *rep_outsw(char __far *buffer, unsigned nwords, unsigned port);
86#pragma aux rep_outsw = ".286" "rep outs dx,word ptr es:[si]" parm [es si] [cx] [dx] value [es si] modify exact [cx si];
87
88#if VBOX_BIOS_CPU >= 80386
89char __far *rep_outsd(char __far *buffer, unsigned ndwords, unsigned port);
90# pragma aux rep_outsd = ".386" "rep outs dx,dword ptr es:[si]" parm [es si] [cx] [dx] value [es si] modify exact [cx si];
91#endif
92
93uint16_t __far swap_16(uint16_t val);
94#pragma aux swap_16 = "xchg ah,al" parm [ax] value [ax] modify exact [ax] nomemory;
95
96uint32_t __far swap_32(uint32_t val);
97#pragma aux swap_32 = \
98 "xchg ah, al" \
99 "xchg dh, dl" \
100 "xchg ax, dx" \
101 parm [dx ax] value [dx ax] modify exact [dx ax] nomemory;
102
103//@todo: Do CLD elsewhere!
104extern void memsetb(uint16_t seg, uint16_t offset, uint16_t value, uint16_t count);
105#pragma aux memsetb = \
106 "cld" \
107 "jcxz no_copy" \
108 "rep stosb" \
109 "no_copy:" \
110 parm [es] [di] [ax] [cx];
111
112//@todo: Do CLD elsewhere!
113extern void memsetw(uint16_t seg, uint16_t offset, uint16_t value, uint16_t count);
114#pragma aux memsetw = \
115 "cld" \
116 "jcxz no_copy" \
117 "rep stosw" \
118 "no_copy:" \
119 parm [es] [di] [ax] [cx];
120
121//@todo: Do CLD elsewhere!
122extern void memcpyb(uint16_t dseg, uint16_t doffset, uint16_t sseg, uint16_t soffset, uint16_t count);
123#pragma aux memcpyb = \
124 "cld" \
125 "jcxz no_copy" \
126 "push ds" \
127 "mov ds, dx" \
128 "rep movsb" \
129 "pop ds" \
130 "no_copy:" \
131 parm [es] [di] [dx] [si] [cx];
132
133//@todo: Do CLD elsewhere!
134extern void memcpyw(uint16_t dseg, uint16_t doffset, uint16_t sseg, uint16_t soffset, uint16_t count);
135#pragma aux memcpyw = \
136 "cld" \
137 "jcxz no_copy" \
138 "push ds" \
139 "mov ds, dx" \
140 "rep movsw" \
141 "pop ds" \
142 "no_copy:" \
143 parm [es] [di] [dx] [si] [cx];
144
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette