oi_cpu_dep.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505
  1. /******************************************************************************
  2. *
  3. * Copyright (C) 2014 The Android Open Source Project
  4. * Copyright 2002 - 2004 Open Interface North America, Inc. All rights reserved.
  5. *
  6. * Licensed under the Apache License, Version 2.0 (the "License");
  7. * you may not use this file except in compliance with the License.
  8. * You may obtain a copy of the License at:
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. *
  18. ******************************************************************************/
  19. #ifndef _OI_CPU_DEP_H
  20. #define _OI_CPU_DEP_H
  21. /**
  22. * @file
  23. * This file contains definitions for characteristics of the target CPU and
  24. * compiler, including primitive data types and endianness.
  25. *
  26. * This file defines the byte order and primitive data types for various
  27. * CPU families. The preprocessor symbol 'CPU' must be defined to be an
  28. * appropriate value or this header will generate a compile-time error.
  29. *
  30. * @note The documentation for this header file uses the x86 family of processors
  31. * as an illustrative example for CPU/compiler-dependent data type definitions.
  32. * Go to the source code of this header file to see the details of primitive type
  33. * definitions for each platform.
  34. *
  35. * Additional information is available in the @ref data_types_docpage section.
  36. */
  37. /**********************************************************************************
  38. $Revision: #1 $
  39. ***********************************************************************************/
  40. #ifdef __cplusplus
  41. extern "C" {
  42. #endif
  43. /** \addtogroup Misc Miscellaneous APIs */
  44. /**@{*/
  45. /** @name Definitions indicating family of target OI_CPU_TYPE
  46. * @{
  47. */
  48. #define OI_CPU_X86 1 /**< x86 processor family */
  49. #define OI_CPU_ARM 2 /**< ARM processor family.
  50. @deprecated Use #OI_CPU_ARM7_LEND or
  51. #OI_CPU_ARM7_BEND. */
  52. #define OI_CPU_ARC 3 /**< ARC processor family.
  53. @deprecated Use #OI_CPU_ARC_LEND or
  54. #OI_CPU_ARC_BEND. */
  55. #define OI_CPU_SH3 4 /**< Hitachi SH-3 processor family */
  56. #define OI_CPU_H8 5 /**< Hitachi H8 processor family */
  57. #define OI_CPU_MIPS 6 /**< MIPS processor family */
  58. #define OI_CPU_SPARC 7 /**< SPARC processor family */
  59. #define OI_CPU_M68000 8 /**< Motorola M68000 processor family */
  60. #define OI_CPU_PPC 9 /**< PowerPC (PPC) processor family */
  61. #define OI_CPU_SH4_7750 10 /**< Hitachi SH7750 series in SH-4 processor family */
  62. #define OI_CPU_SH2 11 /**< Hitachi SH-2 processor family */
  63. #define OI_CPU_ARM7_LEND 12 /**< ARM7, little-endian */
  64. #define OI_CPU_ARM7_BEND 13 /**< ARM7, big-endian */
  65. #define OI_CPU_GDM1202 14 /**< GCT GDM1202 */
  66. #define OI_CPU_ARC_LEND 15 /**< ARC processor family, little-endian */
  67. #define OI_CPU_ARC_BEND 16 /**< ARC processor family, big-endian */
  68. #define OI_CPU_M30833F 17 /**< Mitsubishi M308 processor family */
  69. #define OI_CPU_CR16C 18 /**< National Semiconductor 16 bit processor family */
  70. #define OI_CPU_M64111 19 /**< Renesas M64111 processor (M32R family) */
  71. #define OI_CPU_ARMV5_LEND 20 //*< ARM5, little-endian */
  72. #define OI_CPU_TYPE 12
  73. #ifndef OI_CPU_TYPE
  74. #error "OI_CPU_TYPE type not defined"
  75. #endif
  76. /**@}*/
  77. /** @name Definitions indicating byte-wise endianness of target CPU
  78. * @{
  79. */
  80. #define OI_BIG_ENDIAN_BYTE_ORDER 0 /**< Multiple-byte values are stored in memory beginning with the most significant byte at the lowest address. */
  81. #define OI_LITTLE_ENDIAN_BYTE_ORDER 1 /**< Multiple-byte values are stored in memory beginning with the least significant byte at the lowest address. */
  82. /**@}*/
  83. /** @name CPU/compiler-independent primitive data type definitions
  84. * @{
  85. */
  86. typedef int OI_BOOL; /**< Boolean values use native integer data type for target CPU. */
  87. typedef int OI_INT; /**< Integer values use native integer data type for target CPU. */
  88. typedef unsigned int OI_UINT; /**< Unsigned integer values use native unsigned integer data type for target CPU. */
  89. typedef unsigned char OI_BYTE; /**< Raw bytes type uses native character data type for target CPU. */
  90. /**@}*/
  91. /*********************************************************************************/
  92. #if OI_CPU_TYPE==OI_CPU_X86
  93. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER /**< x86 platform byte ordering is little-endian */
  94. /** @name CPU/compiler-dependent primitive data type definitions for x86 processor family
  95. * @{
  96. */
  97. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for x86 processor. */
  98. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for x86 processor. */
  99. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for x86 processor. */
  100. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for x86 processor. */
  101. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for x86 processor. */
  102. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for x86 processor. */
  103. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  104. /**@}*/
  105. #endif
  106. /*********************************************************************************/
  107. #if OI_CPU_TYPE==OI_CPU_ARM
  108. /* This CPU type is deprecated (removed from use). Instead, use OI_CPU_ARM7_LEND or OI_CPU_ARM7_BEND for
  109. little-endian or big-endian configurations of the ARM7, respectively. */
  110. #error OI_CPU_ARM is deprecated
  111. #endif
  112. /*********************************************************************************/
  113. #if OI_CPU_TYPE==OI_CPU_ARC
  114. /* This CPU type is deprecated (removed from use). Instead, use OI_CPU_ARC_LEND or OI_CPU_ARC_BEND for
  115. little-endian or big-endian configurations of the ARC, respectively. */
  116. #error OI_CPU_ARC is deprecated
  117. #endif
  118. /*********************************************************************************/
  119. #if OI_CPU_TYPE==OI_CPU_SH3
  120. /* The Hitachi SH C compiler defines _LIT or _BIG, depending on the endianness
  121. specified to the compiler on the command line. */
  122. #if defined(_LIT)
  123. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER /**< If _LIT is defined, SH-3 platform byte ordering is little-endian. */
  124. #elif defined(_BIG)
  125. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER /**< If _BIG is defined, SH-3 platform byte ordering is big-endian. */
  126. #else
  127. #error SH compiler endianness undefined
  128. #endif
  129. /** @name CPU/compiler-dependent primitive data type definitions for SH-3 processor family
  130. * @{
  131. */
  132. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for SH-3 processor. */
  133. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for SH-3 processor. */
  134. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for SH-3 processor. */
  135. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for SH-3 processor. */
  136. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for SH-3 processor. */
  137. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for SH-3 processor. */
  138. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  139. /**@}*/
  140. #endif
  141. /*********************************************************************************/
  142. #if OI_CPU_TYPE==OI_CPU_SH2
  143. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER /**< SH-2 platform byte ordering is big-endian. */
  144. /** @name CPU/compiler-dependent primitive data type definitions for SH-2 processor family
  145. * @{
  146. */
  147. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for SH-2 processor. */
  148. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for SH-2 processor. */
  149. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for SH-2 processor. */
  150. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for SH-2 processor. */
  151. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for SH-2 processor. */
  152. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for SH-2 processor. */
  153. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  154. /**@}*/
  155. #endif
  156. /*********************************************************************************/
  157. #if OI_CPU_TYPE==OI_CPU_H8
  158. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  159. #error basic types not defined
  160. #endif
  161. /*********************************************************************************/
  162. #if OI_CPU_TYPE==OI_CPU_MIPS
  163. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  164. /** @name CPU/compiler-dependent primitive data type definitions for MIPS processor family
  165. * @{
  166. */
  167. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARM7 processor. */
  168. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARM7 processor. */
  169. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARM7 processor. */
  170. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARM7 processor. */
  171. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARM7 processor. */
  172. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARM7 processor. */
  173. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  174. /**@}*/
  175. #endif
  176. /*********************************************************************************/
  177. #if OI_CPU_TYPE==OI_CPU_SPARC
  178. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  179. #error basic types not defined
  180. #endif
  181. /*********************************************************************************/
  182. #if OI_CPU_TYPE==OI_CPU_M68000
  183. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER /**< M68000 platform byte ordering is big-endian. */
  184. /** @name CPU/compiler-dependent primitive data type definitions for M68000 processor family
  185. * @{
  186. */
  187. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for M68000 processor. */
  188. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for M68000 processor. */
  189. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for M68000 processor. */
  190. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for M68000 processor. */
  191. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for M68000 processor. */
  192. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for M68000 processor. */
  193. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  194. /**@}*/
  195. #endif
  196. /*********************************************************************************/
  197. #if OI_CPU_TYPE==OI_CPU_PPC
  198. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  199. /** @name CPU/compiler-dependent primitive data type definitions for PPC 8XX processor family
  200. * @{
  201. */
  202. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for PPC8XX processor. */
  203. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for PPC8XX processor. */
  204. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for PPC8XX processor. */
  205. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for PPC8XX processor. */
  206. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for PPC8XX processor. */
  207. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for PPC8XX processor. */
  208. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  209. /**@}*/
  210. #endif
  211. /*********************************************************************************/
  212. #if OI_CPU_TYPE==OI_CPU_SH4_7750
  213. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER /**< SH7750 platform byte ordering is big-endian. */
  214. /** @name CPU/compiler-dependent primitive data type definitions for SH7750 processor series of the SH-4 processor family
  215. * @{
  216. */
  217. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for SH7750 SH-4 processor. */
  218. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for SH7750 SH-4 processor. */
  219. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for SH7750 SH-4 processor. */
  220. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for SH7750 SH-4 processor. */
  221. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for SH7750 SH-4 processor. */
  222. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for SH7750 SH-4 processor. */
  223. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  224. /**@}*/
  225. #endif
  226. /*********************************************************************************/
  227. #if OI_CPU_TYPE==OI_CPU_ARM7_LEND
  228. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  229. /** @name little-endian CPU/compiler-dependent primitive data type definitions for the ARM7 processor family
  230. * @{
  231. */
  232. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARM7 processor. */
  233. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARM7 processor. */
  234. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARM7 processor. */
  235. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARM7 processor. */
  236. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARM7 processor. */
  237. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARM7 processor. */
  238. typedef void *OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  239. /**@}*/
  240. #endif
  241. /*********************************************************************************/
  242. #if OI_CPU_TYPE==OI_CPU_ARM7_BEND
  243. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  244. /** @name big-endian CPU/compiler-dependent primitive data type definitions for the ARM7 processor family
  245. * @{
  246. */
  247. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARM7 processor. */
  248. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARM7 processor. */
  249. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARM7 processor. */
  250. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARM7 processor. */
  251. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARM7 processor. */
  252. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARM7 processor. */
  253. typedef void *OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  254. /**@}*/
  255. #endif
  256. /*********************************************************************************/
  257. #if OI_CPU_TYPE==OI_CPU_GDM1202
  258. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  259. typedef signed char OI_INT8; /**< 8-bit signed integer. */
  260. typedef signed short OI_INT16; /**< 16-bit signed integer. */
  261. typedef signed long OI_INT32; /**< 32-bit signed integer. */
  262. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer. */
  263. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer. */
  264. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer. */
  265. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  266. #endif
  267. /*********************************************************************************/
  268. #if OI_CPU_TYPE==OI_CPU_ARC_LEND
  269. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  270. /** @name CPU/compiler-dependent primitive data type definitions for ARC processor family
  271. * @{
  272. */
  273. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARC processor. */
  274. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARC processor. */
  275. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARC processor. */
  276. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARC processor. */
  277. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARC processor. */
  278. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARC processor. */
  279. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  280. /**@}*/
  281. #endif
  282. /*********************************************************************************/
  283. #if OI_CPU_TYPE==OI_CPU_ARC_BEND
  284. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  285. /** @name CPU/compiler-dependent primitive data type definitions for ARC processor family
  286. * @{
  287. */
  288. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARC processor. */
  289. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARC processor. */
  290. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARC processor. */
  291. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARC processor. */
  292. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARC processor. */
  293. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARC processor. */
  294. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  295. /**@}*/
  296. #endif
  297. /*********************************************************************************/
  298. #if OI_CPU_TYPE==OI_CPU_M30833F
  299. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  300. /** @name CPU/compiler-dependent primitive data type definitions for Mitsubishi M308 processor family
  301. * @{
  302. */
  303. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for M308 processor. */
  304. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for M308 processor. */
  305. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for M308 processor. */
  306. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for M308 processor. */
  307. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for M308 processor. */
  308. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for M308 processor. */
  309. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  310. /**@}*/
  311. #endif
  312. /*********************************************************************************/
  313. #if OI_CPU_TYPE==OI_CPU_CR16C
  314. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  315. /** @name CPU/compiler-dependent primitive data type definitions for National Semicnductor processor family
  316. * @{
  317. */
  318. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for CR16C processor. */
  319. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for CR16C processor. */
  320. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for CR16C processor. */
  321. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for CR16C processor. */
  322. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for CR16C processor. */
  323. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for CR16C processor. */
  324. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  325. /**@}*/
  326. #endif
  327. /*********************************************************************************/
  328. #if OI_CPU_TYPE==OI_CPU_M64111
  329. #define OI_CPU_BYTE_ORDER OI_BIG_ENDIAN_BYTE_ORDER
  330. /** @name CPU/compiler-dependent primitive data type definitions for Renesas M32R processor family
  331. * @{
  332. */
  333. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for M64111 processor. */
  334. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for M64111 processor. */
  335. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for M64111 processor. */
  336. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for M64111 processor. */
  337. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for M64111 processor. */
  338. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for M64111 processor. */
  339. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  340. /**@}*/
  341. #endif
  342. /*********************************************************************************/
  343. #if OI_CPU_TYPE==OI_CPU_ARMV5_LEND
  344. #define OI_CPU_BYTE_ORDER OI_LITTLE_ENDIAN_BYTE_ORDER
  345. /** @name little-endian CPU/compiler-dependent primitive data type definitions for the ARM7 processor family
  346. * @{
  347. */
  348. typedef signed char OI_INT8; /**< 8-bit signed integer values use native signed character data type for ARM7 processor. */
  349. typedef signed short OI_INT16; /**< 16-bit signed integer values use native signed short integer data type for ARM7 processor. */
  350. typedef signed long OI_INT32; /**< 32-bit signed integer values use native signed long integer data type for ARM7 processor. */
  351. typedef unsigned char OI_UINT8; /**< 8-bit unsigned integer values use native unsigned character data type for ARM7 processor. */
  352. typedef unsigned short OI_UINT16; /**< 16-bit unsigned integer values use native unsigned short integer data type for ARM7 processor. */
  353. typedef unsigned long OI_UINT32; /**< 32-bit unsigned integer values use native unsigned long integer data type for ARM7 processor. */
  354. typedef OI_UINT32 OI_ELEMENT_UNION; /**< Type for first element of a union to support all data types up to pointer width. */
  355. /**@}*/
  356. #endif
  357. /*********************************************************************************/
  358. #ifndef OI_CPU_BYTE_ORDER
  359. #error "Byte order (endian-ness) not defined"
  360. #endif
  361. /**@}*/
  362. #ifdef __cplusplus
  363. }
  364. #endif
  365. /*********************************************************************************/
  366. #endif /* _OI_CPU_DEP_H */