OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [newlib-1.18.0/] [newlib-1.18.0-or32-1.0rc2/] [newlib/] [libc/] [include/] [sys/] [types.h] - Blame information for rev 520

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 207 jeremybenn
/* unified sys/types.h:
2
   start with sef's sysvi386 version.
3
   merge go32 version -- a few ifdefs.
4
   h8300hms, h8300xray, and sysvnecv70 disagree on the following types:
5
 
6
   typedef int gid_t;
7
   typedef int uid_t;
8
   typedef int dev_t;
9
   typedef int ino_t;
10
   typedef int mode_t;
11
   typedef int caddr_t;
12
 
13
   however, these aren't "reasonable" values, the sysvi386 ones make far
14
   more sense, and should work sufficiently well (in particular, h8300
15
   doesn't have a stat, and the necv70 doesn't matter.) -- eichin
16
 */
17
 
18
#ifndef _SYS_TYPES_H
19
 
20
#include <_ansi.h>
21
 
22
#ifndef __INTTYPES_DEFINED__
23
#define __INTTYPES_DEFINED__
24
 
25
#include <machine/_types.h>
26
 
27
#if defined(__rtems__) || defined(__XMK__)
28
/*
29
 *  The following section is RTEMS specific and is needed to more
30
 *  closely match the types defined in the BSD sys/types.h.
31
 *  This is needed to let the RTEMS/BSD TCP/IP stack compile.
32
 */
33
 
34
/* deprecated */
35
#if ___int8_t_defined
36
typedef __uint8_t       u_int8_t;
37
#endif
38
#if ___int16_t_defined
39
typedef __uint16_t      u_int16_t;
40
#endif 
41
#if ___int32_t_defined
42
typedef __uint32_t      u_int32_t;
43
#endif
44
 
45
#if ___int64_t_defined
46
typedef __uint64_t      u_int64_t;
47
 
48
/* deprecated */
49
typedef __uint64_t      u_quad_t;
50
typedef __int64_t       quad_t;
51
typedef quad_t *        qaddr_t;
52
#endif
53
 
54
#endif
55
 
56
#endif /* ! __INTTYPES_DEFINED */
57
 
58
#ifndef __need_inttypes
59
 
60
#define _SYS_TYPES_H
61
#include <sys/_types.h>
62
 
63
#ifdef __i386__
64
#if defined (GO32) || defined (__MSDOS__)
65
#define __MS_types__
66
#endif
67
#endif
68
 
69
# include <stddef.h>
70
# include <machine/types.h>
71
 
72
/* To ensure the stat struct's layout doesn't change when sizeof(int), etc.
73
   changes, we assume sizeof short and long never change and have all types
74
   used to define struct stat use them and not int where possible.
75
   Where not possible, _ST_INTxx are used.  It would be preferable to not have
76
   such assumptions, but until the extra fluff is necessary, it's avoided.
77
   No 64 bit targets use stat yet.  What to do about them is postponed
78
   until necessary.  */
79
#ifdef __GNUC__
80
#define _ST_INT32 __attribute__ ((__mode__ (__SI__)))
81
#else
82
#define _ST_INT32
83
#endif
84
 
85
# ifndef        _POSIX_SOURCE
86
 
87
#  define       physadr         physadr_t
88
#  define       quad            quad_t
89
 
90
#ifndef _BSDTYPES_DEFINED
91
/* also defined in mingw/gmon.h and in w32api/winsock[2].h */
92
typedef unsigned char   u_char;
93
typedef unsigned short  u_short;
94
typedef unsigned int    u_int;
95
typedef unsigned long   u_long;
96
#define _BSDTYPES_DEFINED
97
#endif
98
 
99
typedef unsigned short  ushort;         /* System V compatibility */
100
typedef unsigned int    uint;           /* System V compatibility */
101
# endif /*!_POSIX_SOURCE */
102
 
103
#ifndef __clock_t_defined
104
typedef _CLOCK_T_ clock_t;
105
#define __clock_t_defined
106
#endif
107
 
108
#ifndef __time_t_defined
109
typedef _TIME_T_ time_t;
110
#define __time_t_defined
111
 
112
/* Time Value Specification Structures, P1003.1b-1993, p. 261 */
113
 
114
struct timespec {
115
  time_t  tv_sec;   /* Seconds */
116
  long    tv_nsec;  /* Nanoseconds */
117
};
118
 
119
struct itimerspec {
120
  struct timespec  it_interval;  /* Timer period */
121
  struct timespec  it_value;     /* Timer expiration */
122
};
123
#endif
124
 
125
typedef long    daddr_t;
126
typedef char *  caddr_t;
127
 
128
#ifndef __CYGWIN__
129
#if defined(__MS_types__) || defined(__rtems__) || \
130
    defined(__sparc__) || defined(__SPU__)
131
typedef unsigned long   ino_t;
132
#else
133
typedef unsigned short  ino_t;
134
#endif
135
#endif /*__CYGWIN__*/
136
 
137
#ifdef __MS_types__
138
typedef unsigned long vm_offset_t;
139
typedef unsigned long vm_size_t;
140
 
141
#define __BIT_TYPES_DEFINED__
142
 
143
typedef signed char int8_t;
144
typedef unsigned char u_int8_t;
145
typedef short int16_t;
146
typedef unsigned short u_int16_t;
147
typedef int int32_t;
148
typedef unsigned int u_int32_t;
149
typedef long long int64_t;
150
typedef unsigned long long u_int64_t;
151
typedef int32_t register_t;
152
#endif /* __MS_types__ */
153
 
154
/*
155
 * All these should be machine specific - right now they are all broken.
156
 * However, for all of Cygnus' embedded targets, we want them to all be
157
 * the same.  Otherwise things like sizeof (struct stat) might depend on
158
 * how the file was compiled (e.g. -mint16 vs -mint32, etc.).
159
 */
160
 
161
#ifndef __CYGWIN__      /* which defines these types in it's own types.h. */
162
typedef _off_t  off_t;
163
typedef __dev_t dev_t;
164
typedef __uid_t uid_t;
165
typedef __gid_t gid_t;
166
#endif
167
 
168
#if defined(__XMK__)
169
typedef signed char pid_t;
170
#else
171
typedef int pid_t;
172
#endif
173
 
174
#ifndef __CYGWIN__
175
typedef long key_t;
176
#endif
177
typedef _ssize_t ssize_t;
178
 
179
#ifndef __CYGWIN__
180
#ifdef __MS_types__
181
typedef char *  addr_t;
182
typedef int mode_t;
183
#else
184
#if defined (__sparc__) && !defined (__sparc_v9__)
185
#ifdef __svr4__
186
typedef unsigned long mode_t;
187
#else
188
typedef unsigned short mode_t;
189
#endif
190
#else
191
typedef unsigned int mode_t _ST_INT32;
192
#endif
193
#endif /* ! __MS_types__ */
194
#endif /*__CYGWIN__*/
195
 
196
typedef unsigned short nlink_t;
197
 
198
/* We don't define fd_set and friends if we are compiling POSIX
199
   source, or if we have included (or may include as indicated
200
   by __USE_W32_SOCKETS) the W32api winsock[2].h header which
201
   defines Windows versions of them.   Note that a program which
202
   includes the W32api winsock[2].h header must know what it is doing;
203
   it must not call the cygwin32 select function.
204
*/
205
# if !(defined (_POSIX_SOURCE) || defined (_WINSOCK_H) || defined (__USE_W32_SOCKETS)) 
206
#  define _SYS_TYPES_FD_SET
207
#  define       NBBY    8               /* number of bits in a byte */
208
/*
209
 * Select uses bit masks of file descriptors in longs.
210
 * These macros manipulate such bit fields (the filesystem macros use chars).
211
 * FD_SETSIZE may be defined by the user, but the default here
212
 * should be >= NOFILE (param.h).
213
 */
214
#  ifndef       FD_SETSIZE
215
#       define  FD_SETSIZE      64
216
#  endif
217
 
218
typedef long    fd_mask;
219
#  define       NFDBITS (sizeof (fd_mask) * NBBY)       /* bits per mask */
220
#  ifndef       howmany
221
#       define  howmany(x,y)    (((x)+((y)-1))/(y))
222
#  endif
223
 
224
/* We use a macro for fd_set so that including Sockets.h afterwards
225
   can work.  */
226
typedef struct _types_fd_set {
227
        fd_mask fds_bits[howmany(FD_SETSIZE, NFDBITS)];
228
} _types_fd_set;
229
 
230
#define fd_set _types_fd_set
231
 
232
#  define       FD_SET(n, p)    ((p)->fds_bits[(n)/NFDBITS] |= (1L << ((n) % NFDBITS)))
233
#  define       FD_CLR(n, p)    ((p)->fds_bits[(n)/NFDBITS] &= ~(1L << ((n) % NFDBITS)))
234
#  define       FD_ISSET(n, p)  ((p)->fds_bits[(n)/NFDBITS] & (1L << ((n) % NFDBITS)))
235
#  define       FD_ZERO(p)      (__extension__ (void)({ \
236
     size_t __i; \
237
     char *__tmp = (char *)p; \
238
     for (__i = 0; __i < sizeof (*(p)); ++__i) \
239
       *__tmp++ = 0; \
240
}))
241
 
242
# endif /* !(defined (_POSIX_SOURCE) || defined (_WINSOCK_H) || defined (__USE_W32_SOCKETS)) */
243
 
244
#undef __MS_types__
245
#undef _ST_INT32
246
 
247
 
248
#ifndef __clockid_t_defined
249
typedef _CLOCKID_T_ clockid_t;
250
#define __clockid_t_defined
251
#endif
252
 
253
#ifndef __timer_t_defined
254
typedef _TIMER_T_ timer_t;
255
#define __timer_t_defined
256
#endif
257
 
258
typedef unsigned long useconds_t;
259
typedef long suseconds_t;
260
 
261
#include <sys/features.h>
262
 
263
 
264
/* Cygwin will probably never have full posix compliance due to little things
265
 * like an inability to set the stackaddress. Cygwin is also using void *
266
 * pointers rather than structs to ensure maximum binary compatability with
267
 * previous releases.
268
 * This means that we don't use the types defined here, but rather in
269
 * <cygwin/types.h>
270
 */
271
#if defined(_POSIX_THREADS) && !defined(__CYGWIN__)
272
 
273
#include <sys/sched.h>
274
 
275
/*
276
 *  2.5 Primitive System Data Types,  P1003.1c/D10, p. 19.
277
 */
278
 
279
#if defined(__XMK__)
280
typedef unsigned int pthread_t;          /* identify a thread */
281
#else
282
typedef __uint32_t pthread_t;            /* identify a thread */
283
#endif
284
 
285
/* P1003.1c/D10, p. 118-119 */
286
#define PTHREAD_SCOPE_PROCESS 0
287
#define PTHREAD_SCOPE_SYSTEM  1
288
 
289
/* P1003.1c/D10, p. 111 */
290
#define PTHREAD_INHERIT_SCHED  1      /* scheduling policy and associated */
291
                                      /*   attributes are inherited from */
292
                                      /*   the calling thread. */
293
#define PTHREAD_EXPLICIT_SCHED 2      /* set from provided attribute object */
294
 
295
/* P1003.1c/D10, p. 141 */
296
#define PTHREAD_CREATE_DETACHED 0
297
#define PTHREAD_CREATE_JOINABLE  1
298
 
299
#if defined(__XMK__) || defined(__rtems__)
300
/* The following defines are part of the X/Open System Interface (XSI). */
301
 
302
/* This type of mutex does not detect deadlock. A thread attempting to relock this mutex without first unlocking
303
 * it shall deadlock. Attempting to unlock a mutex locked by a different thread results in undefined behavior.
304
 * Attempting to unlock an unlocked mutex results in undefined behavior.
305
 */
306
#define PTHREAD_MUTEX_NORMAL  1
307
 
308
/*
309
 * This type of mutex provides error checking. A thread attempting to relock this mutex without first unlocking
310
 * it shall return with an error. A thread attempting to unlock a mutex which another thread has locked shall return
311
 * with an error. A thread attempting to unlock an unlocked mutex shall return with an error.
312
 */
313
#define PTHREAD_MUTEX_ERRORCHECK  2 
314
 
315
/* A thread attempting to relock this mutex without first unlocking it shall succeed in locking the mutex.
316
 * The relocking deadlock which can occur with mutexes of type PTHREAD_MUTEX_NORMAL cannot occur with this type of mutex.
317
 * Multiple locks of this mutex shall require the same number of unlocks to release the mutex before another thread can
318
 * acquire the mutex. A thread attempting to unlock a mutex which another thread has locked shall return with an error.
319
 * A thread attempting to unlock an unlocked mutex shall return with an error.
320
 */
321
#define PTHREAD_MUTEX_RECURSIVE  3
322
 
323
/* Attempting to recursively lock a mutex of this type results in undefined behavior. Attempting to unlock a
324
 * mutex of this type which was not locked by the calling thread results in undefined behavior. Attempting to
325
 * unlock a mutex of this type which is not locked results in undefined behavior. An implementation may map this
326
 * mutex to one of the other mutex types.
327
 */
328
#define PTHREAD_MUTEX_DEFAULT  4 
329
 
330
#endif /* defined(__XMK__) || defined(__rtems__) */
331
 
332
#if defined(__XMK__)
333
typedef struct pthread_attr_s {
334
  int contentionscope;
335
  struct sched_param schedparam;
336
  int  detachstate;
337
  void *stackaddr;
338
  size_t stacksize;
339
} pthread_attr_t;
340
 
341
#define PTHREAD_STACK_MIN       200
342
 
343
#else /* !defined(__XMK__) */
344
typedef struct {
345
  int is_initialized;
346
  void *stackaddr;
347
  int stacksize;
348
  int contentionscope;
349
  int inheritsched;
350
  int schedpolicy;
351
  struct sched_param schedparam;
352
#endif /* !defined(__XMK__) */
353
 
354
  /* P1003.4b/D8, p. 54 adds cputime_clock_allowed attribute.  */
355
#if defined(_POSIX_THREAD_CPUTIME)
356
  int  cputime_clock_allowed;  /* see time.h */
357
#endif
358
  int  detachstate;
359
 
360
} pthread_attr_t;
361
 
362
#if defined(_POSIX_THREAD_PROCESS_SHARED)
363
/* NOTE: P1003.1c/D10, p. 81 defines following values for process_shared.  */
364
 
365
#define PTHREAD_PROCESS_PRIVATE 0 /* visible within only the creating process */
366
#define PTHREAD_PROCESS_SHARED  1 /* visible too all processes with access to */
367
                                  /*   the memory where the resource is */
368
                                  /*   located */
369
#endif
370
 
371
#if defined(_POSIX_THREAD_PRIO_PROTECT)
372
/* Mutexes */
373
 
374
/* Values for blocking protocol. */
375
 
376
#define PTHREAD_PRIO_NONE    0
377
#define PTHREAD_PRIO_INHERIT 1
378
#define PTHREAD_PRIO_PROTECT 2
379
#endif
380
 
381
#if defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES)
382
 
383
/* Values for mutex type */
384
 
385
#define PTHREAD_MUTEX_NORMAL     0
386
#define PTHREAD_MUTEX_RECURSIVE  1
387
#define PTHREAD_MUTEX_ERRORCHECK 2
388
#define PTHREAD_MUTEX_DEFAULT    3
389
 
390
#endif
391
 
392
#if defined(__XMK__)
393
typedef unsigned int pthread_mutex_t;    /* identify a mutex */
394
 
395
typedef struct {
396
  int type;
397
} pthread_mutexattr_t;
398
 
399
 
400
#if defined(__XMK__)
401
/* The following defines are part of the X/Open System Interface (XSI). */
402
 
403
/* This type of mutex does not detect deadlock. A thread attempting to
404
 * relock this mutex without first unlocking it shall deadlock. Attempting
405
 * to unlock a mutex locked by a different thread results in undefined
406
 * behavior.  Attempting to unlock an unlocked mutex results in undefined
407
 * behavior.
408
 */
409
#define PTHREAD_MUTEX_NORMAL  1
410
 
411
/*
412
 * This type of mutex provides error checking. A thread attempting to
413
 * relock this mutex without first unlocking it shall return with an error.
414
 * A thread attempting to unlock a mutex which another thread has locked
415
 * shall return with an error. A thread attempting to unlock an unlocked
416
 * mutex shall return with an error.
417
 */
418
#define PTHREAD_MUTEX_ERRORCHECK  2 
419
 
420
/* A thread attempting to relock this mutex without first unlocking it
421
 * shall succeed in locking the mutex.  The relocking deadlock which can
422
 * occur with mutexes of type PTHREAD_MUTEX_NORMAL cannot occur with this
423
 * type of mutex.  Multiple locks of this mutex shall require the same
424
 * number of unlocks to release the mutex before another thread can
425
 * acquire the mutex. A thread attempting to unlock a mutex which another
426
 * thread has locked shall return with an error.  A thread attempting to
427
 * unlock an unlocked mutex shall return with an error.
428
 */
429
#define PTHREAD_MUTEX_RECURSIVE  3
430
 
431
/* Attempting to recursively lock a mutex of this type results in
432
 * undefined behavior. Attempting to unlock a mutex of this type which was
433
 * not locked by the calling thread results in undefined behavior.
434
 * Attempting to unlock a mutex of this type which is not locked results
435
 * in undefined behavior. An implementation may map this mutex to one of
436
 * the other mutex types.
437
 */
438
#define PTHREAD_MUTEX_DEFAULT  4 
439
 
440
typedef struct pthread_attr_s {
441
  int contentionscope;
442
  struct sched_param schedparam;
443
  int  detachstate;
444
  void *stackaddr;
445
  size_t stacksize;
446
} pthread_attr_t;
447
 
448
#define PTHREAD_STACK_MIN       200
449
 
450
#endif /* defined(__XMK__) */
451
 
452
typedef struct {
453
    int type;
454
} pthread_mutexattr_t;
455
#else /* !defined(__XMK__) */
456
typedef __uint32_t pthread_mutex_t;      /* identify a mutex */
457
 
458
typedef struct {
459
  int   is_initialized;
460
#if defined(_POSIX_THREAD_PROCESS_SHARED)
461
  int   process_shared;  /* allow mutex to be shared amongst processes */
462
#endif
463
#if defined(_POSIX_THREAD_PRIO_PROTECT)
464
  int   prio_ceiling;
465
  int   protocol;
466
#endif
467
#if defined(_UNIX98_THREAD_MUTEX_ATTRIBUTES)
468
  int type;
469
#endif
470
  int   recursive;
471
} pthread_mutexattr_t;
472
#endif /* !defined(__XMK__) */
473
 
474
/* Condition Variables */
475
 
476
typedef __uint32_t pthread_cond_t;       /* identify a condition variable */
477
 
478
typedef struct {
479
  int   is_initialized;
480
#if defined(_POSIX_THREAD_PROCESS_SHARED)
481
  int   process_shared;       /* allow this to be shared amongst processes */
482
#endif
483
} pthread_condattr_t;         /* a condition attribute object */
484
 
485
/* Keys */
486
 
487
typedef __uint32_t pthread_key_t;        /* thread-specific data keys */
488
 
489
typedef struct {
490
  int   is_initialized;  /* is this structure initialized? */
491
  int   init_executed;   /* has the initialization routine been run? */
492
} pthread_once_t;       /* dynamic package initialization */
493
#else
494
#if defined (__CYGWIN__)
495
#include <cygwin/types.h>
496
#endif
497
#endif /* defined(_POSIX_THREADS) */
498
 
499
/* POSIX Barrier Types */
500
 
501
#if defined(_POSIX_BARRIERS)
502
typedef __uint32_t pthread_barrier_t;        /* POSIX Barrier Object */
503
typedef struct {
504
  int   is_initialized;  /* is this structure initialized? */
505
#if defined(_POSIX_THREAD_PROCESS_SHARED)
506
  int   process_shared;       /* allow this to be shared amongst processes */
507
#endif
508
} pthread_barrierattr_t;
509
#endif /* defined(_POSIX_BARRIERS) */
510
 
511
/* POSIX Spin Lock Types */
512
 
513
#if defined(_POSIX_SPIN_LOCKS)
514
typedef __uint32_t pthread_spinlock_t;        /* POSIX Spin Lock Object */
515
#endif /* defined(_POSIX_SPIN_LOCKS) */
516
 
517
/* POSIX Reader/Writer Lock Types */
518
 
519
#if !defined (__CYGWIN__)
520
#if defined(_POSIX_READER_WRITER_LOCKS)
521
typedef __uint32_t pthread_rwlock_t;         /* POSIX RWLock Object */
522
typedef struct {
523
  int   is_initialized;       /* is this structure initialized? */
524
#if defined(_POSIX_THREAD_PROCESS_SHARED)
525
  int   process_shared;       /* allow this to be shared amongst processes */
526
#endif
527
} pthread_rwlockattr_t;
528
#endif /* defined(_POSIX_READER_WRITER_LOCKS) */
529
#endif /* __CYGWIN__ */
530
 
531
#endif  /* !__need_inttypes */
532
 
533
#undef __need_inttypes
534
 
535
#endif  /* _SYS_TYPES_H */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.