Common.h revision 734155efc18543eab20b763f9a315ab1a44240ac
1/*
2 * Copyright (C) 2008 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *      http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17/*
18 * Common defines for all Dalvik code.
19 */
20#ifndef _DALVIK_COMMON
21#define _DALVIK_COMMON
22
23#ifndef LOG_TAG
24# define LOG_TAG "dalvikvm"
25#endif
26
27#include <stdio.h>
28#include <assert.h>
29
30#if !defined(NDEBUG) && defined(WITH_DALVIK_ASSERT)
31# undef assert
32# define assert(x) \
33    ((x) ? ((void)0) : (LOGE("ASSERT FAILED (%s:%d): %s\n", \
34        __FILE__, __LINE__, #x), *(int*)39=39, 0) )
35#endif
36
37
38/*
39 * If "very verbose" logging is enabled, make it equivalent to LOGV.
40 * Otherwise, make it disappear.
41 *
42 * Define this above the #include "Dalvik.h" to enable for only a
43 * single file.
44 */
45/* #define VERY_VERBOSE_LOG */
46#if defined(VERY_VERBOSE_LOG)
47# define LOGVV      LOGV
48# define IF_LOGVV() IF_LOGV()
49#else
50# define LOGVV(...) ((void)0)
51# define IF_LOGVV() if (false)
52#endif
53
54
55/*
56 * These match the definitions in the VM specification.
57 */
58#ifdef HAVE_STDINT_H
59# include <stdint.h>    /* C99 */
60typedef uint8_t             u1;
61typedef uint16_t            u2;
62typedef uint32_t            u4;
63typedef uint64_t            u8;
64typedef int8_t              s1;
65typedef int16_t             s2;
66typedef int32_t             s4;
67typedef int64_t             s8;
68#else
69typedef unsigned char       u1;
70typedef unsigned short      u2;
71typedef unsigned int        u4;
72typedef unsigned long long  u8;
73typedef signed char         s1;
74typedef signed short        s2;
75typedef signed int          s4;
76typedef signed long long    s8;
77#endif
78
79/*
80 * Storage for primitive types and object references.
81 *
82 * Some parts of the code (notably object field access) assume that values
83 * are "left aligned", i.e. given "JValue jv", "jv.i" and "*((s4*)&jv)"
84 * yield the same result.  This seems to be guaranteed by gcc on big- and
85 * little-endian systems.
86 */
87typedef union JValue {
88    u1      z;
89    s1      b;
90    u2      c;
91    s2      s;
92    s4      i;
93    s8      j;
94    float   f;
95    double  d;
96    void*   l;
97} JValue;
98
99/*
100 * Some systems might have this in <stdbool.h>.
101 */
102#ifndef __bool_true_false_are_defined
103typedef enum { false=0, true=!false } bool;
104#define __bool_true_false_are_defined 1
105#endif
106
107#define NELEM(x) ((int) (sizeof(x) / sizeof((x)[0])))
108
109
110#if defined(HAVE_ENDIAN_H)
111# include <endian.h>
112#else /*not HAVE_ENDIAN_H*/
113# define __BIG_ENDIAN 4321
114# define __LITTLE_ENDIAN 1234
115# if defined(HAVE_LITTLE_ENDIAN)
116#  define __BYTE_ORDER __LITTLE_ENDIAN
117# else
118#  define __BYTE_ORDER __BIG_ENDIAN
119# endif
120#endif /*not HAVE_ENDIAN_H*/
121
122
123#if 0
124/*
125 * Pretend we have the Android logging macros.  These are replaced by the
126 * Android logging implementation.
127 */
128#define ANDROID_LOG_DEBUG 3
129#define LOGV(...)    LOG_PRI(2, 0, __VA_ARGS__)
130#define LOGD(...)    LOG_PRI(3, 0, __VA_ARGS__)
131#define LOGI(...)    LOG_PRI(4, 0, __VA_ARGS__)
132#define LOGW(...)    LOG_PRI(5, 0, __VA_ARGS__)
133#define LOGE(...)    LOG_PRI(6, 0, __VA_ARGS__)
134#define MIN_LOG_LEVEL   2
135
136#define LOG_PRI(priority, tag, ...) do {                            \
137        if (priority >= MIN_LOG_LEVEL) {                            \
138            dvmFprintf(stdout, "%s:%-4d ", __FILE__, __LINE__);     \
139            dvmFprintf(stdout, __VA_ARGS__);                        \
140        }                                                           \
141    } while(0)
142#else
143# include "utils/Log.h"
144#endif
145
146#endif /*_DALVIK_COMMON*/
147