1 /******************************************************************************
2  * $Id: AKFS_Common.h 580 2012-03-29 09:56:21Z yamada.rj $
3  ******************************************************************************
4  *
5  * Copyright (C) 2012 Asahi Kasei Microdevices Corporation, Japan
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  */
19 #ifndef AKFS_INC_COMMON_H
20 #define AKFS_INC_COMMON_H
21 
22 #ifdef WIN32
23 #ifndef _WIN32_WINNT
24 #define _WIN32_WINNT 0x0501
25 #endif
26 
27 #include <windows.h>
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include <conio.h>
31 #include <stdarg.h>
32 #include <crtdbg.h>
33 #include "Android.h"
34 
35 #define DBG_LEVEL	DBG_LEVEL4
36 #define ENABLE_AKMDEBUG	1
37 
38 #else
39 #include <stdio.h>     /* frpintf */
40 #include <stdlib.h>    /* atoi */
41 #include <string.h>    /* memset */
42 #include <unistd.h>
43 #include <stdarg.h>    /* va_list */
44 #include <utils/Log.h> /* LOGV */
45 #include <errno.h>     /* errno */
46 
47 #endif
48 
49 /*** Constant definition ******************************************************/
50 #define AKM_TRUE	1	/*!< Represents true */
51 #define AKM_FALSE	0	/*!< Represents false */
52 #define AKM_SUCCESS	1	/*!< Represents success */
53 #define AKM_FAIL	0	/*!< Represents fail */
54 
55 #undef LOG_TAG
56 #define LOG_TAG "AKMD_FS"
57 
58 #define DBG_LEVEL0	0	/* Critical */
59 #define DBG_LEVEL1	1	/* Notice */
60 #define DBG_LEVEL2	2	/* Information */
61 #define DBG_LEVEL3	3	/* Debug */
62 #define DBG_LEVEL4	4	/* Verbose */
63 
64 #ifndef DBG_LEVEL
65 #define DBG_LEVEL	DBG_LEVEL0
66 #endif
67 
68 #define DATA_AREA01	0x0001
69 #define DATA_AREA02	0x0002
70 #define DATA_AREA03	0x0004
71 #define DATA_AREA04	0x0008
72 #define DATA_AREA05	0x0010
73 #define DATA_AREA06	0x0020
74 #define DATA_AREA07	0x0040
75 #define DATA_AREA08	0x0080
76 #define DATA_AREA09	0x0100
77 #define DATA_AREA10	0x0200
78 #define DATA_AREA11	0x0400
79 #define DATA_AREA12	0x0800
80 #define DATA_AREA13	0x1000
81 #define DATA_AREA14	0x2000
82 #define DATA_AREA15	0x4000
83 #define DATA_AREA16	0x8000
84 
85 
86 /* Debug area definition */
87 #define AKMDATA_DUMP		DATA_AREA01	/*<! Dump data */
88 #define AKMDATA_BDATA		DATA_AREA02	/*<! BDATA */
89 #define AKMDATA_MAG			DATA_AREA03 /*<! Magnetic Field */
90 #define AKMDATA_ACC			DATA_AREA04 /*<! Accelerometer */
91 #define AKMDATA_ORI			DATA_AREA05 /*<! Orientation */
92 #define AKMDATA_GETINTERVAL	DATA_AREA06
93 #define AKMDATA_LOOP		DATA_AREA07
94 #define AKMDATA_DRV			DATA_AREA08
95 
96 #ifndef ENABLE_AKMDEBUG
97 #define ENABLE_AKMDEBUG		0	/* Eanble debug output when it is 1. */
98 #endif
99 
100 #define OPMODE_CONSOLE		0x01
101 #define OPMODE_FST			0x02
102 
103 /***** Debug Level Output *************************************/
104 #if ENABLE_AKMDEBUG
105 #define AKMDEBUG(level, format, ...) \
106     (((level) <= DBG_LEVEL) \
107 	  ? (fprintf(stdout, (format), ##__VA_ARGS__)) \
108 	  : ((void)0))
109 #else
110 #define AKMDEBUG(level, format, ...)
111 #endif
112 
113 /***** Dbg Zone Output ***************************************/
114 #if ENABLE_AKMDEBUG
115 #define AKMDATA(flag, format, ...)  \
116 	((((int)(flag)) & g_dbgzone) \
117 	  ? (fprintf(stdout, (format), ##__VA_ARGS__)) \
118 	  : ((void)0))
119 #else
120 #define AKMDATA(flag, format, ...)
121 #endif
122 
123 /***** Log output ********************************************/
124 #ifdef AKM_LOG_ENABLE
125 #define AKM_LOG(format, ...)	ALOGD((format), ##__VA_ARGS__)
126 #else
127 #define AKM_LOG(format, ...)
128 #endif
129 
130 /***** Error output *******************************************/
131 #define AKMERROR \
132 	((g_opmode & OPMODE_CONSOLE) \
133 	  ? (fprintf(stderr, "%s:%d Error.\n", __FUNCTION__, __LINE__)) \
134 	  : (ALOGE("%s:%d Error.", __FUNCTION__, __LINE__)))
135 
136 #define AKMERROR_STR(api) \
137 	((g_opmode & OPMODE_CONSOLE) \
138 	  ? (fprintf(stderr, "%s:%d %s Error (%s).\n", \
139 	  		  __FUNCTION__, __LINE__, (api), strerror(errno))) \
140 	  : (ALOGE("%s:%d %s Error (%s).", \
141 	  		  __FUNCTION__, __LINE__, (api), strerror(errno))))
142 
143 /*** Type declaration *********************************************************/
144 
145 /*** Global variables *********************************************************/
146 extern int g_stopRequest;	/*!< 0:Not stop,  1:Stop */
147 extern int g_opmode;		/*!< 0:Daemon mode, 1:Console mode. */
148 extern int g_dbgzone;		/*!< Debug zone. */
149 
150 /*** Prototype of function ****************************************************/
151 
152 #endif /* AKMD_INC_AKCOMMON_H */
153 
154