VirtualBox

source: vbox/trunk/include/iprt/asmdefs.mac@ 30736

Last change on this file since 30736 was 30736, checked in by vboxsync, 15 years ago

bootsector2-test1.asm,++: real mode tests.

  • Property eol-style set to native
File size: 15.2 KB
Line 
1;; @file
2; IPRT - Global YASM/NASM macros
3;
4
5;
6; Copyright (C) 2006-2007 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; The contents of this file may alternatively be used under the terms
17; of the Common Development and Distribution License Version 1.0
18; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19; VirtualBox OSE distribution, in which case the provisions of the
20; CDDL are applicable instead of those of the GPL.
21;
22; You may elect to license modified versions of this file under the
23; terms and conditions of either the GPL or the CDDL or both.
24;
25
26%ifndef ___iprt_asmdefs_mac
27%define ___iprt_asmdefs_mac
28
29;;
30; Make the mask for the given bit.
31%define RT_BIT(bit) (1 << bit)
32
33;;
34; Align code, pad with INT3.
35%define ALIGNCODE(alignment) align alignment, db 0cch
36
37;;
38; Align data, pad with ZEROs.
39%define ALIGNDATA(alignment) align alignment, db 0
40
41;;
42; Align BSS, pad with ZEROs.
43%define ALIGNBSS(alignment) align alignment, resb 1
44
45;;
46; NAME_OVERLOAD can be defined by a .asm module to modify all the
47; names created using the name macros in this files.
48; This is handy when you've got some kind of template code.
49%ifndef NAME_OVERLOAD
50 %define NAME_OVERLOAD(name) name
51%endif
52
53;;
54; Mangles the given name so it can be referenced using DECLASM() in the
55; C/C++ world.
56%ifdef RT_ARCH_X86
57 %ifdef RT_OS_OS2
58 %define NAME(name) _ %+ NAME_OVERLOAD(name)
59 %endif
60 %ifdef RT_OS_WINDOWS
61 %define NAME(name) _ %+ NAME_OVERLOAD(name)
62 %endif
63%endif
64%ifdef RT_OS_DARWIN
65 %define NAME(name) _ %+ NAME_OVERLOAD(name)
66%endif
67%ifndef NAME
68 %define NAME(name) NAME_OVERLOAD(name)
69%endif
70
71;;
72; Mangles the given C name so it will _import_ the right symbol.
73%ifdef ASM_FORMAT_PE
74%define IMPNAME(name) __imp_ %+ NAME(name)
75%else
76%define IMPNAME(name) NAME(name)
77%endif
78
79;;
80; Gets the pointer to an imported object.
81%ifdef ASM_FORMAT_PE
82 %ifdef RT_ARCH_AMD64
83 %define IMP(name) qword [IMPNAME(name) wrt rip]
84 %else
85 %define IMP(name) dword [IMPNAME(name)]
86 %endif
87%else
88 %define IMP(name) IMPNAME(name)
89%endif
90
91
92
93;;
94; Global marker which is DECLASM() compatible.
95%macro GLOBALNAME 1,
96%ifndef ASM_FORMAT_BIN
97global NAME(%1)
98%endif
99NAME(%1):
100%endmacro
101
102;;
103; Global exported marker which is DECLASM() compatible.
104%macro EXPORTEDNAME 1,
105 %ifdef ASM_FORMAT_PE
106 export %1=NAME(%1)
107 %endif
108 %ifdef __NASM__
109 %ifdef ASM_FORMAT_OMF
110 export NAME(%1) NAME(%1)
111 %endif
112%endif
113GLOBALNAME %1
114%endmacro
115
116;;
117; Begins a C callable procedure.
118%macro BEGINPROC 1
119GLOBALNAME %1
120%endmacro
121
122;;
123; Begins a C callable exported procedure.
124%macro BEGINPROC_EXPORTED 1
125EXPORTEDNAME %1
126%endmacro
127
128;;
129; Ends a C callable procedure.
130%macro ENDPROC 1
131GLOBALNAME %1_EndProc
132 db 0xCC, 0xCC, 0xCC, 0xCC
133%endmacro
134
135
136;
137; Do OMF and Mach-O/Yasm segment definitions
138;
139; Both format requires this to get the segment order right, in the Mach-O/Yasm case
140; it's only to make sure the .bss section ends up last (it's not declared here).
141;
142%ifdef ASM_FORMAT_OMF
143
144 ; 16-bit segments first (OMF / OS/2 specific).
145 %ifdef RT_INCL_16BIT_SEGMENTS
146 segment DATA16 public CLASS=FAR_DATA align=16 use16
147 segment DATA16_INIT public CLASS=FAR_DATA align=16 use16
148 group DGROUP16 DATA16 DATA16_INIT
149
150 ;;
151 ; Begins 16-bit data
152 %macro BEGINDATA16 0
153 segment DATA16
154 %endmacro
155
156 ;;
157 ; Begins 16-bit init data
158 %macro BEGINDATA16INIT 0
159 segment DATA16_INIT
160 %endmacro
161
162 segment CODE16 public CLASS=FAR_CODE align=16 use16
163 segment CODE16_INIT public CLASS=FAR_CODE align=16 use16
164 group CGROUP16 CODE16 CODE16_INIT
165
166 ;;
167 ; Begins 16-bit code
168 %macro BEGINCODE16 0
169 segment CODE16
170 %endmacro
171
172 ;;
173 ; Begins 16-bit init code
174 %macro BEGINCODE16INIT 0
175 segment CODE16_INIT
176 %endmacro
177
178 %endif
179
180 ; 32-bit segments.
181 segment TEXT32 public CLASS=CODE align=16 use32 flat
182 segment DATA32 public CLASS=DATA align=16 use32 flat
183 segment BSS32 public CLASS=BSS align=16 use32 flat
184
185 ; Make the TEXT32 segment default.
186 segment TEXT32
187%endif
188
189%ifdef ASM_FORMAT_MACHO
190 %ifdef __YASM__
191 [section .text]
192 [section .data]
193 %endif
194%endif
195
196
197;;
198; Begins code
199%ifdef ASM_FORMAT_OMF
200 %macro BEGINCODE 0
201 segment TEXT32
202 %endmacro
203%else
204%macro BEGINCODE 0
205[section .text]
206%endmacro
207%endif
208
209;;
210; Begins constant (read-only) data
211;
212; @remarks This is mapped to the CODE section/segment when there isn't
213; any dedicated const section/segment. (There is code that
214; assumes this, so don't try change it.)
215%ifdef ASM_FORMAT_OMF
216 %macro BEGINCONST 0
217 segment TEXT32
218 %endmacro
219%else
220 %macro BEGINCONST 0
221 %ifdef ASM_FORMAT_MACHO ;; @todo check the other guys too.
222 [section .rodata]
223 %else
224 [section .text]
225 %endif
226 %endmacro
227%endif
228
229;;
230; Begins initialized data
231%ifdef ASM_FORMAT_OMF
232 %macro BEGINDATA 0
233 segment DATA32
234 %endmacro
235%else
236%macro BEGINDATA 0
237[section .data]
238%endmacro
239%endif
240
241;;
242; Begins uninitialized data
243%ifdef ASM_FORMAT_OMF
244 %macro BEGINBSS 0
245 segment BSS32
246 %endmacro
247%else
248%macro BEGINBSS 0
249[section .bss]
250%endmacro
251%endif
252
253
254
255;; @def ARCH_BITS
256; Defines the bit count of the current context.
257%ifndef ARCH_BITS
258 %ifdef RT_ARCH_AMD64
259 %define ARCH_BITS 64
260 %else
261 %define ARCH_BITS 32
262 %endif
263%endif
264
265;; @def HC_ARCH_BITS
266; Defines the host architechture bit count.
267%ifndef HC_ARCH_BITS
268 %ifndef IN_RC
269 %define HC_ARCH_BITS ARCH_BITS
270 %else
271 %define HC_ARCH_BITS 32
272 %endif
273%endif
274
275;; @def R3_ARCH_BITS
276; Defines the host ring-3 architechture bit count.
277%ifndef R3_ARCH_BITS
278 %ifdef IN_RING3
279 %define R3_ARCH_BITS ARCH_BITS
280 %else
281 %define R3_ARCH_BITS HC_ARCH_BITS
282 %endif
283%endif
284
285;; @def R0_ARCH_BITS
286; Defines the host ring-0 architechture bit count.
287%ifndef R0_ARCH_BITS
288 %ifdef IN_RING0
289 %define R0_ARCH_BITS ARCH_BITS
290 %else
291 %define R0_ARCH_BITS HC_ARCH_BITS
292 %endif
293%endif
294
295;; @def GC_ARCH_BITS
296; Defines the guest architechture bit count.
297%ifndef GC_ARCH_BITS
298 %ifdef IN_RC
299 %define GC_ARCH_BITS ARCH_BITS
300 %else
301 %define GC_ARCH_BITS 32
302 %endif
303%endif
304
305
306
307;; @def RTHCPTR_DEF
308; The pesudo-instruction used to declare an initialized pointer variable in the host context.
309%if HC_ARCH_BITS == 64
310 %define RTHCPTR_DEF dq
311%else
312 %define RTHCPTR_DEF dd
313%endif
314
315;; @def RTHCPTR_RES
316; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
317; variable of the host context.
318%if HC_ARCH_BITS == 64
319 %define RTHCPTR_RES resq
320%else
321 %define RTHCPTR_RES resd
322%endif
323
324;; @def RTHCPTR_PRE
325; The memory operand prefix used for a pointer in the host context.
326%if HC_ARCH_BITS == 64
327 %define RTHCPTR_PRE qword
328%else
329 %define RTHCPTR_PRE dword
330%endif
331
332;; @def RTHCPTR_CB
333; The size in bytes of a pointer in the host context.
334%if HC_ARCH_BITS == 64
335 %define RTHCPTR_CB 8
336%else
337 %define RTHCPTR_CB 4
338%endif
339
340
341
342;; @def RTR0PTR_DEF
343; The pesudo-instruction used to declare an initialized pointer variable in the ring-0 host context.
344%if R0_ARCH_BITS == 64
345 %define RTR0PTR_DEF dq
346%else
347 %define RTR0PTR_DEF dd
348%endif
349
350;; @def RTR0PTR_RES
351; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
352; variable of the ring-0 host context.
353%if R0_ARCH_BITS == 64
354 %define RTR0PTR_RES resq
355%else
356 %define RTR0PTR_RES resd
357%endif
358
359;; @def RTR0PTR_PRE
360; The memory operand prefix used for a pointer in the ring-0 host context.
361%if R0_ARCH_BITS == 64
362 %define RTR0PTR_PRE qword
363%else
364 %define RTR0PTR_PRE dword
365%endif
366
367;; @def RTR0PTR_CB
368; The size in bytes of a pointer in the ring-0 host context.
369%if R0_ARCH_BITS == 64
370 %define RTR0PTR_CB 8
371%else
372 %define RTR0PTR_CB 4
373%endif
374
375
376
377;; @def RTR3PTR_DEF
378; The pesudo-instruction used to declare an initialized pointer variable in the ring-3 host context.
379%if R3_ARCH_BITS == 64
380 %define RTR3PTR_DEF dq
381%else
382 %define RTR3PTR_DEF dd
383%endif
384
385;; @def RTR3PTR_RES
386; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
387; variable of the ring-3 host context.
388%if R3_ARCH_BITS == 64
389 %define RTR3PTR_RES resq
390%else
391 %define RTR3PTR_RES resd
392%endif
393
394;; @def RTR3PTR_PRE
395; The memory operand prefix used for a pointer in the ring-3 host context.
396%if R3_ARCH_BITS == 64
397 %define RTR3PTR_PRE qword
398%else
399 %define RTR3PTR_PRE dword
400%endif
401
402;; @def RTR3PTR_CB
403; The size in bytes of a pointer in the ring-3 host context.
404%if R3_ARCH_BITS == 64
405 %define RTR3PTR_CB 8
406%else
407 %define RTR3PTR_CB 4
408%endif
409
410
411
412;; @def RTGCPTR_DEF
413; The pesudo-instruction used to declare an initialized pointer variable in the guest context.
414%if GC_ARCH_BITS == 64
415 %define RTGCPTR_DEF dq
416%else
417 %define RTGCPTR_DEF dd
418%endif
419
420;; @def RTGCPTR_RES
421; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
422; variable of the guest context.
423%if GC_ARCH_BITS == 64
424 %define RTGCPTR_RES resq
425%else
426 %define RTGCPTR_RES resd
427%endif
428
429%define RTGCPTR32_RES resd
430%define RTGCPTR64_RES resq
431
432;; @def RTGCPTR_PRE
433; The memory operand prefix used for a pointer in the guest context.
434%if GC_ARCH_BITS == 64
435 %define RTGCPTR_PRE qword
436%else
437 %define RTGCPTR_PRE dword
438%endif
439
440;; @def RTGCPTR_CB
441; The size in bytes of a pointer in the guest context.
442%if GC_ARCH_BITS == 64
443 %define RTGCPTR_CB 8
444%else
445 %define RTGCPTR_CB 4
446%endif
447
448
449;; @def RTRCPTR_DEF
450; The pesudo-instruction used to declare an initialized pointer variable in the raw mode context.
451%define RTRCPTR_DEF dd
452
453;; @def RTRCPTR_RES
454; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
455; variable of the raw mode context.
456%define RTRCPTR_RES resd
457
458;; @def RTRCPTR_PRE
459; The memory operand prefix used for a pointer in the raw mode context.
460%define RTRCPTR_PRE dword
461
462;; @def RTRCPTR_CB
463; The size in bytes of a pointer in the raw mode context.
464%define RTRCPTR_CB 4
465
466
467;; @def RT_CCPTR_DEF
468; The pesudo-instruction used to declare an initialized pointer variable in the current context.
469
470;; @def RT_CCPTR_RES
471; The pesudo-instruction used to declare (=reserve space for) an uninitialized pointer
472; variable of the current context.
473
474;; @def RT_CCPTR_PRE
475; The memory operand prefix used for a pointer in the current context.
476
477;; @def RT_CCPTR_CB
478; The size in bytes of a pointer in the current context.
479
480%ifdef IN_RC
481 %define RTCCPTR_DEF RTRCPTR_DEF
482 %define RTCCPTR_RES RTRCPTR_RES
483 %define RTCCPTR_PRE RTRCPTR_PRE
484 %define RTCCPTR_CB RTRCPTR_CB
485%else
486 %ifdef IN_RING0
487 %define RTCCPTR_DEF RTR0PTR_DEF
488 %define RTCCPTR_RES RTR0PTR_RES
489 %define RTCCPTR_PRE RTR0PTR_PRE
490 %define RTCCPTR_CB RTR0PTR_CB
491 %else
492 %define RTCCPTR_DEF RTR3PTR_DEF
493 %define RTCCPTR_RES RTR3PTR_RES
494 %define RTCCPTR_PRE RTR3PTR_PRE
495 %define RTCCPTR_CB RTR3PTR_CB
496 %endif
497%endif
498
499
500
501;; @def RTHCPHYS_DEF
502; The pesudo-instruction used to declare an initialized host physical address.
503%define RTHCPHYS_DEF dq
504
505;; @def RTHCPTR_RES
506; The pesudo-instruction used to declare (=reserve space for) an uninitialized
507; host physical address variable
508%define RTHCPHYS_RES resq
509
510;; @def RTHCPTR_PRE
511; The memory operand prefix used for a host physical address.
512%define RTHCPHYS_PRE qword
513
514;; @def RTHCPHYS_CB
515; The size in bytes of a host physical address.
516%define RTHCPHYS_CB 8
517
518
519
520;; @def RTGCPHYS_DEF
521; The pesudo-instruction used to declare an initialized guest physical address.
522%define RTGCPHYS_DEF dq
523
524;; @def RTGCPHYS_RES
525; The pesudo-instruction used to declare (=reserve space for) an uninitialized
526; guest physical address variable
527%define RTGCPHYS_RES resq
528
529;; @def RTGCPTR_PRE
530; The memory operand prefix used for a guest physical address.
531%define RTGCPHYS_PRE qword
532
533;; @def RTGCPHYS_CB
534; The size in bytes of a guest physical address.
535%define RTGCPHYS_CB 8
536
537
538
539;;
540; The size of the long double C/C++ type.
541; On 32-bit Darwin this is 16 bytes, on L4, Linux, OS/2 and Windows
542; it's 12 bytes.
543; @todo figure out what 64-bit Windows does (I don't recall right now).
544%ifdef RT_ARCH_X86
545 %ifdef RT_OS_DARWIN
546 %define RTLRD_CB 16
547 %else
548 %define RTLRD_CB 12
549 %endif
550%else
551 %define RTLRD_CB 16
552%endif
553
554
555
556;; @def ASM_CALL64_GCC
557; Indicates that we're using the GCC 64-bit calling convention.
558; @see @ref sec_vboxrem_amd64_compare (in VBoxREMWrapper.cpp) for an ABI description.
559
560;; @def ASM_CALL64_MSC
561; Indicates that we're using the Microsoft 64-bit calling convention (fastcall on steroids).
562; @see @ref sec_vboxrem_amd64_compare (in VBoxREMWrapper.cpp) for an ABI description.
563
564; Note: On X86 we're using cdecl unconditionally. There is not yet any common
565; calling convention on AMD64, that's why we need to support two different ones.)
566
567%ifdef RT_ARCH_AMD64
568 %ifndef ASM_CALL64_GCC
569 %ifndef ASM_CALL64_MSC
570 ; define it based on the object format.
571 %ifdef ASM_FORMAT_PE
572 %define ASM_CALL64_MSC
573 %else
574 %define ASM_CALL64_GCC
575 %endif
576 %endif
577 %else
578 ; sanity check.
579 %ifdef ASM_CALL64_MSC
580 %error "Only one of the ASM_CALL64_* defines should be defined!"
581 %endif
582 %endif
583%endif
584
585
586;; @def RT_NOCRT
587; Symbol name wrapper for the No-CRT bits.
588;
589; In order to coexist in the same process as other CRTs, we need to
590; decorate the symbols such that they don't conflict the ones in the
591; other CRTs. The result of such conflicts / duplicate symbols can
592; confuse the dynamic loader on unix like systems.
593;
594; @remark Always feed the name to this macro first and then pass the result
595; on to the next *NAME* macro.
596;
597%ifndef RT_WITHOUT_NOCRT_WRAPPERS
598 %define RT_NOCRT(name) nocrt_ %+ name
599%else
600 %define RT_NOCRT(name) name
601%endif
602
603;; @def RT_NOCRT_BEGINPROC
604; Starts a NOCRT procedure, taking care of name wrapping and aliasing.
605;
606; Aliasing (weak ones, if supported) will be created when RT_WITH_NOCRT_ALIASES
607; is defined and RT_WITHOUT_NOCRT_WRAPPERS isn't.
608;
609%macro RT_NOCRT_BEGINPROC 1
610%ifdef RT_WITH_NOCRT_ALIASES
611BEGINPROC RT_NOCRT(%1)
612%ifdef ASM_FORMAT_ELF
613global NAME(%1)
614weak NAME(%1)
615NAME(%1):
616%else
617GLOBALNAME %1
618%endif
619%else ; !RT_WITH_NOCRT_ALIASES
620BEGINPROC RT_NOCRT(%1)
621%endif ; !RT_WITH_NOCRT_ALIASES
622%endmacro ; RT_NOCRT_BEGINPROC
623
624%ifdef RT_WITH_NOCRT_ALIASES
625 %ifdef RT_WITHOUT_NOCRT_WRAPPERS
626 %error "RT_WITH_NOCRT_ALIASES and RT_WITHOUT_NOCRT_WRAPPERS doesn't mix."
627 %endif
628%endif
629
630
631
632;; @def xS
633; The stack unit size / The register unit size.
634
635;; @def xSP
636; The stack pointer register (RSP or ESP).
637
638;; @def xBP
639; The base pointer register (RBP or ESP).
640
641;; @def xAX
642; RAX or EAX depending on context.
643
644;; @def xBX
645; RBX or EBX depending on context.
646
647;; @def xCX
648; RCX or ECX depending on context.
649
650;; @def xDX
651; RDX or EDX depending on context.
652
653;; @def xDI
654; RDI or EDI depending on context.
655
656;; @def xSI
657; RSI or ESI depending on context.
658
659;; @def xWrtRIP
660; 'wrt rip' for AMD64 targets, nothing for x86 ones.
661
662%ifdef RT_ARCH_AMD64
663 %define xS 8
664 %define xSP rsp
665 %define xBP rbp
666 %define xAX rax
667 %define xBX rbx
668 %define xCX rcx
669 %define xDX rdx
670 %define xDI rdi
671 %define xSI rsi
672 %define xWrtRIP wrt rip
673%else
674 %define xS 4
675 %define xSP esp
676 %define xBP ebp
677 %define xAX eax
678 %define xBX ebx
679 %define xCX ecx
680 %define xDX edx
681 %define xDI edi
682 %define xSI esi
683 %define xWrtRIP
684%endif
685
686%endif
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