VirtualBox

source: vbox/trunk/src/VBox/Runtime/include/internal/alignmentchecks.h@ 31960

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

iprt/asm*.h: split out asm-math.h, don't include asm-*.h from asm.h, don't include asm.h from sup.h. Fixed a couple file headers.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.4 KB
Line 
1/* $Id: alignmentchecks.h 29250 2010-05-09 17:53:58Z vboxsync $ */
2/** @file
3 * IPRT - Internal header for hacking alignment checks on x86 and AMD64.
4 */
5
6/*
7 * Copyright (C) 2009 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28#ifndef ___internal_alignmentchecks_h
29#define ___internal_alignmentchecks_h
30
31/** @def IPRT_WITH_ALIGNMENT_CHECKS
32 * Enables or disables the alignment check feature and related hacks. */
33
34#ifndef IPRT_WITH_ALIGNMENT_CHECKS
35# if ( defined(DEBUG) && !defined(IN_GUEST) ) || defined(DOXYGEN_RUNNING)
36# define IPRT_WITH_ALIGNMENT_CHECKS 1
37# endif
38#endif
39
40/** @def IPRT_ALIGNMENT_CHECKS_DISABLE
41 * Disables alignment checks.
42 * Typically used before calling problematic library functions.
43 */
44
45/** @def IPRT_ALIGNMENT_CHECKS_ENABLE
46 * (re-)Enables alignment checks if they are supposed to be active.
47 * This is used to counter IPRT_ALIGNMENT_CHECKS_DISABLE as well as enabling
48 * them for the first time.
49 */
50
51#if defined(IPRT_WITH_ALIGNMENT_CHECKS) \
52 && ( defined(RT_ARCH_AMD64) \
53 || defined(RT_ARCH_X86) )
54# include <iprt/asm-amd64-x86.h>
55
56RT_C_DECLS_BEGIN
57extern RTDATADECL(bool) g_fRTAlignmentChecks;
58RT_C_DECLS_END
59
60# define IPRT_ALIGNMENT_CHECKS_DISABLE() \
61 do { if (g_fRTAlignmentChecks) ASMSetFlags(ASMGetFlags() & ~RT_BIT_32(18)); } while (0)
62
63# define IPRT_ALIGNMENT_CHECKS_ENABLE() \
64 do { if (g_fRTAlignmentChecks) ASMSetFlags(ASMGetFlags() | RT_BIT_32(18)); } while (0)
65
66#else
67# define IPRT_ALIGNMENT_CHECKS_DISABLE() do {} while (0)
68# define IPRT_ALIGNMENT_CHECKS_ENABLE() do {} while (0)
69#endif
70
71#endif
72
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