Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / nanojit / njconfig.h
1 /* -*- Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil; tab-width: 4 -*- */
2 /* vi: set ts=4 sw=4 expandtab: (add to ~/.vimrc: set modeline modelines=5) */
3 /* ***** BEGIN LICENSE BLOCK *****
4  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5  *
6  * The contents of this file are subject to the Mozilla Public License Version
7  * 1.1 (the "License"); you may not use this file except in compliance with
8  * the License. You may obtain a copy of the License at
9  * http://www.mozilla.org/MPL/
10  *
11  * Software distributed under the License is distributed on an "AS IS" basis,
12  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13  * for the specific language governing rights and limitations under the
14  * License.
15  *
16  * The Original Code is [Open Source Virtual Machine].
17  *
18  * The Initial Developer of the Original Code is
19  * Adobe System Incorporated.
20  * Portions created by the Initial Developer are Copyright (C) 2004-2007
21  * the Initial Developer. All Rights Reserved.
22  *
23  * Contributor(s):
24  *   Adobe AS3 Team
25  *
26  * Alternatively, the contents of this file may be used under the terms of
27  * either the GNU General Public License Version 2 or later (the "GPL"), or
28  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29  * in which case the provisions of the GPL or the LGPL are applicable instead
30  * of those above. If you wish to allow use of your version of this file only
31  * under the terms of either the GPL or the LGPL, and not to allow others to
32  * use your version of this file under the terms of the MPL, indicate your
33  * decision by deleting the provisions above and replace them with the notice
34  * and other provisions required by the GPL or the LGPL. If you do not delete
35  * the provisions above, a recipient may use your version of this file under
36  * the terms of any one of the MPL, the GPL or the LGPL.
37  *
38  * ***** END LICENSE BLOCK ***** */
39
40 #ifndef __njconfig_h__
41 #define __njconfig_h__
42
43 #include "avmplus.h"
44
45 // Do not include nanojit.h here; this file should be usable without it.
46
47 #ifdef FEATURE_NANOJIT
48
49 namespace nanojit
50 {
51     /***
52      * A struct used to configure the assumptions that Assembler can make when
53      * generating code. The ctor will fill in all fields with the most reasonable
54      * values it can derive from compiler flags and/or runtime detection, but
55      * the embedder is free to override any or all of them as it sees fit.
56      * Using the ctor-provided default setup is guaranteed to provide a safe
57      * runtime environment (though perhaps suboptimal in some cases), so an embedder
58      * should replace these values with great care.
59      *
60      * Note that although many fields are used on only specific architecture(s),
61      * this struct is deliberately declared without ifdef's for them, so (say) ARM-specific
62      * fields are declared everywhere. This reduces build dependencies (so that this
63      * files does not require nanojit.h to be included beforehand) and also reduces
64      * clutter in this file; the extra storage space required is trivial since most
65      * fields are single bits.
66      */
67     struct Config
68     {
69     public:
70         // fills in reasonable default values for all fields.
71         Config();
72
73         // ARM architecture to assume when generate instructions for (currently, 4 <= arm_arch <= 7)
74         uint8_t arm_arch;
75
76         // If true, use CSE.
77         uint32_t cseopt:1;
78
79         // Can we use SSE2 instructions? (x86-only)
80         uint32_t i386_sse2:1;
81
82         // Can we use cmov instructions? (x86-only)
83         uint32_t i386_use_cmov:1;
84
85         // Should we use a virtual stack pointer? (x86-only)
86         uint32_t i386_fixed_esp:1;
87
88         // Whether or not to generate VFP instructions. (ARM only)
89         uint32_t arm_vfp:1;
90
91         // @todo, document me
92         uint32_t arm_show_stats:1;
93
94         // If true, use softfloat for all floating point operations,
95         // whether or not an FPU is present. (ARM only for now, but might also includes MIPS in the future)
96         uint32_t soft_float:1;
97
98         // If true, compiler will insert a random amount of space in between functions (x86-32 only)
99         uint32_t harden_function_alignment:1;
100
101         // If true, compiler will insert randomly choosen no-op instructions at random locations within a compiled method (x86-32 only)
102         uint32_t harden_nop_insertion:1;
103     };
104 }
105
106 #endif // FEATURE_NANOJIT
107 #endif // __njconfig_h__