VirtualBox

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

Last change on this file since 81106 was 76585, checked in by vboxsync, 6 years ago

*: scm --fix-header-guard-endif

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.5 KB
Line 
1/* $Id: alignmentchecks.h 76585 2019-01-01 06:31:29Z vboxsync $ */
2/** @file
3 * IPRT - Internal header for hacking alignment checks on x86 and AMD64.
4 */
5
6/*
7 * Copyright (C) 2009-2019 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#ifndef IPRT_INCLUDED_INTERNAL_alignmentchecks_h
28#define IPRT_INCLUDED_INTERNAL_alignmentchecks_h
29#ifndef RT_WITHOUT_PRAGMA_ONCE
30# pragma once
31#endif
32
33/** @def IPRT_WITH_ALIGNMENT_CHECKS
34 * Enables or disables the alignment check feature and related hacks. */
35
36#ifndef IPRT_WITH_ALIGNMENT_CHECKS
37# if ( defined(DEBUG) && !defined(IN_GUEST) ) || defined(DOXYGEN_RUNNING)
38# define IPRT_WITH_ALIGNMENT_CHECKS 1
39# endif
40#endif
41
42/** @def IPRT_ALIGNMENT_CHECKS_DISABLE
43 * Disables alignment checks.
44 * Typically used before calling problematic library functions.
45 */
46
47/** @def IPRT_ALIGNMENT_CHECKS_ENABLE
48 * (re-)Enables alignment checks if they are supposed to be active.
49 * This is used to counter IPRT_ALIGNMENT_CHECKS_DISABLE as well as enabling
50 * them for the first time.
51 */
52
53#if defined(IPRT_WITH_ALIGNMENT_CHECKS) \
54 && ( defined(RT_ARCH_AMD64) \
55 || defined(RT_ARCH_X86) )
56# include <iprt/asm-amd64-x86.h>
57
58RT_C_DECLS_BEGIN
59extern RTDATADECL(bool) g_fRTAlignmentChecks;
60RT_C_DECLS_END
61
62# define IPRT_ALIGNMENT_CHECKS_DISABLE() \
63 do { if (g_fRTAlignmentChecks) ASMSetFlags(ASMGetFlags() & ~RT_BIT_32(18)); } while (0)
64
65# define IPRT_ALIGNMENT_CHECKS_ENABLE() \
66 do { if (g_fRTAlignmentChecks) ASMSetFlags(ASMGetFlags() | RT_BIT_32(18)); } while (0)
67
68#else
69# define IPRT_ALIGNMENT_CHECKS_DISABLE() do {} while (0)
70# define IPRT_ALIGNMENT_CHECKS_ENABLE() do {} while (0)
71#endif
72
73#endif /* !IPRT_INCLUDED_INTERNAL_alignmentchecks_h */
74
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