/*
* UCW Library -- Configuration-Dependent Definitions
*
- * (c) 1997--2004 Martin Mares <mj@ucw.cz>
+ * (c) 1997--2007 Martin Mares <mj@ucw.cz>
* (c) 2006 Robert Spalek <robert@ucw.cz>
*
* This software may be freely distributed and used according to the terms
#include "lib/autoconf.h"
-/* Types */
-
-typedef unsigned char byte; /* exactly 8 bits, unsigned */
-typedef signed char sbyte; /* exactly 8 bits, signed */
-typedef unsigned char u8; /* exactly 8 bits, unsigned */
-typedef signed char s8; /* exactly 8 bits, signed */
-typedef unsigned short word; /* exactly 16 bits, unsigned */
-typedef short sword; /* exactly 16 bits, signed */
-typedef unsigned short u16; /* exactly 16 bits, unsigned */
-typedef short s16; /* exactly 16 bits, signed */
-typedef unsigned int u32; /* exactly 32 bits, unsigned */
-typedef int s32; /* exactly 32 bits, signed */
-typedef unsigned int uns; /* at least 32 bits */
-typedef unsigned long long int u64; /* exactly 64 bits, unsigned */
-typedef long long int s64; /* exactly 64 bits, signed */
-typedef unsigned long addr_int_t; /* Both integer and address */
-typedef unsigned int sh_time_t; /* Timestamp */
+/* Tell libc we're going to use all extensions available */
-#ifndef NULL
-#define NULL (void *)0
+#ifndef _GNU_SOURCE
+#define _GNU_SOURCE
#endif
+/* Types (based on standard C99 integers) */
+
+#include <stddef.h>
+#include <stdint.h>
+
+typedef uint8_t byte; /* exactly 8 bits, unsigned */
+typedef uint8_t u8; /* exactly 8 bits, unsigned */
+typedef int8_t s8; /* exactly 8 bits, signed */
+typedef uint16_t u16; /* exactly 16 bits, unsigned */
+typedef int16_t s16; /* exactly 16 bits, signed */
+typedef uint32_t u32; /* exactly 32 bits, unsigned */
+typedef int32_t s32; /* exactly 32 bits, signed */
+typedef uint64_t u64; /* exactly 64 bits, unsigned */
+typedef int64_t s64; /* exactly 64 bits, signed */
+
+typedef unsigned int uns; /* at least 32 bits */
+typedef u32 sh_time_t; /* Timestamp */
+
#ifdef CONFIG_LARGE_FILES /* File positions */
typedef s64 sh_off_t;
#else
typedef s32 sh_off_t;
#endif
-#ifdef CPU_64BIT_POINTERS
-#define BYTES_PER_P 8
-#define bgetp(f) bgetq(f)
-#define bputp(f,l) bputq(f,l)
-#define GET_P(p) GET_U64(p)
-#define PUT_P(p,x) PUT_U64(p,x)
-#else
-#define BYTES_PER_P 4
-#define bgetp(f) bgetl(f)
-#define bputp(f,l) bputl(f,l)
-#define GET_P(p) GET_U32(p)
-#define PUT_P(p,x) PUT_U32(p,x)
-#endif
-
#endif
/*
* The UCW Library -- Miscellaneous Functions
*
- * (c) 1997--2006 Martin Mares <mj@ucw.cz>
+ * (c) 1997--2007 Martin Mares <mj@ucw.cz>
* (c) 2005 Tomas Valla <tom@ucw.cz>
* (c) 2006 Robert Spalek <robert@ucw.cz>
*
#include "lib/config.h"
#include <stdarg.h>
-/* Tell libc we're going to use all extensions available */
-
-#ifndef _GNU_SOURCE
-#define _GNU_SOURCE
-#endif
-
/* Macros for handling structurues, offsets and alignment */
#define CHECK_PTR_TYPE(x, type) ((x)-(type)(x) + (type)(x))
#define OFFSETOF(s, i) ((unsigned int) PTR_TO(s, i))
#define SKIP_BACK(s, i, p) ((s *)((char *)p - OFFSETOF(s, i)))
#define ALIGN_TO(s, a) (((s)+a-1)&~(a-1))
-#define ALIGN_PTR(p, s) ((addr_int_t)(p) % (s) ? (typeof(p))((addr_int_t)(p) + (s) - (addr_int_t)(p) % (s)) : (p))
-#define UNALIGNED_PART(ptr, type) (((addr_int_t) (ptr)) % sizeof(type))
+#define ALIGN_PTR(p, s) ((uintptr_t)(p) % (s) ? (typeof(p))((uintptr_t)(p) + (s) - (uintptr_t)(p) % (s)) : (p))
+#define UNALIGNED_PART(ptr, type) (((uintptr_t) (ptr)) % sizeof(type))
/* Some other macros */