2008-03-04 21:22:31 +03:00
|
|
|
#ifndef _SPL_SYSMACROS_H
|
|
|
|
#define _SPL_SYSMACROS_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <linux/module.h>
|
2008-03-08 03:18:21 +03:00
|
|
|
#include <sys/varargs.h>
|
2008-03-13 02:48:28 +03:00
|
|
|
#include <sys/zone.h>
|
2008-03-17 21:29:57 +03:00
|
|
|
#include <sys/signal.h>
|
2008-03-04 21:22:31 +03:00
|
|
|
|
|
|
|
#ifndef _KERNEL
|
|
|
|
#define _KERNEL __KERNEL__
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Missing defines.
|
|
|
|
*/
|
2008-03-07 02:42:37 +03:00
|
|
|
#define FALSE 0
|
|
|
|
#define TRUE 1
|
2008-03-07 03:28:32 +03:00
|
|
|
|
2008-03-04 21:22:31 +03:00
|
|
|
#define INT32_MAX INT_MAX
|
2008-03-07 23:48:44 +03:00
|
|
|
#define INT32_MIN INT_MIN
|
|
|
|
#define UINT32_MAX UINT_MAX
|
|
|
|
#define UINT32_MIN UINT_MIN
|
|
|
|
#define INT64_MAX LLONG_MAX
|
|
|
|
#define INT64_MIN LLONG_MIN
|
|
|
|
#define UINT64_MAX ULLONG_MAX
|
|
|
|
#define UINT64_MIN ULLONG_MIN
|
|
|
|
|
2008-03-04 21:22:31 +03:00
|
|
|
#define NBBY 8
|
|
|
|
#define ENOTSUP ENOTSUPP
|
2008-03-07 03:28:32 +03:00
|
|
|
|
2008-03-08 03:18:21 +03:00
|
|
|
#define MAXMSGLEN 256
|
2008-03-04 21:22:31 +03:00
|
|
|
#define MAXNAMELEN 256
|
|
|
|
#define MAXPATHLEN PATH_MAX
|
2008-03-07 03:28:32 +03:00
|
|
|
#define MAXOFFSET_T 0x7fffffffffffffffl
|
|
|
|
|
|
|
|
#define MAXBSIZE 8192
|
|
|
|
#define DEV_BSIZE 512
|
|
|
|
#define DEV_BSHIFT 9 /* log2(DEV_BSIZE) */
|
|
|
|
|
2008-03-04 21:22:31 +03:00
|
|
|
#define max_ncpus 64
|
2008-03-08 03:58:32 +03:00
|
|
|
#define CPU_SEQID smp_processor_id() /* I think... */
|
2008-03-07 03:28:32 +03:00
|
|
|
#define _NOTE(x)
|
2008-03-04 21:22:31 +03:00
|
|
|
|
2008-03-10 20:05:34 +03:00
|
|
|
#define RLIM64_INFINITY RLIM_INFINITY
|
|
|
|
|
2008-03-04 21:22:31 +03:00
|
|
|
/* 0..MAX_PRIO-1: Process priority
|
|
|
|
* 0..MAX_RT_PRIO-1: RT priority tasks
|
|
|
|
* MAX_RT_PRIO..MAX_PRIO-1: SCHED_NORMAL tasks
|
|
|
|
*
|
|
|
|
* Treat shim tasks as SCHED_NORMAL tasks
|
|
|
|
*/
|
|
|
|
#define minclsyspri (MAX_RT_PRIO)
|
|
|
|
#define maxclsyspri (MAX_PRIO-1)
|
|
|
|
|
|
|
|
#define NICE_TO_PRIO(nice) (MAX_RT_PRIO + (nice) + 20)
|
|
|
|
#define PRIO_TO_NICE(prio) ((prio) - MAX_RT_PRIO - 20)
|
|
|
|
|
|
|
|
/* Missing macros
|
|
|
|
*/
|
|
|
|
#define PAGESIZE PAGE_SIZE
|
|
|
|
|
|
|
|
/* from Solaris sys/byteorder.h */
|
|
|
|
#define BSWAP_8(x) ((x) & 0xff)
|
|
|
|
#define BSWAP_16(x) ((BSWAP_8(x) << 8) | BSWAP_8((x) >> 8))
|
|
|
|
#define BSWAP_32(x) ((BSWAP_16(x) << 16) | BSWAP_16((x) >> 16))
|
|
|
|
#define BSWAP_64(x) ((BSWAP_32(x) << 32) | BSWAP_32((x) >> 32))
|
|
|
|
|
|
|
|
/* Map some simple functions.
|
|
|
|
*/
|
|
|
|
#define bzero(ptr,size) memset(ptr,0,size)
|
|
|
|
#define bcopy(src,dest,size) memcpy(dest,src,size)
|
2008-03-07 03:28:32 +03:00
|
|
|
#define bcmp(src,dest,size) memcmp((src), (dest), (size_t)(size))
|
2008-03-04 21:22:31 +03:00
|
|
|
#define ASSERT(x) BUG_ON(!(x))
|
2008-03-07 02:12:55 +03:00
|
|
|
#define VERIFY(x) ASSERT(x)
|
2008-03-05 03:58:54 +03:00
|
|
|
|
2008-03-28 01:06:59 +03:00
|
|
|
#define VERIFY3_IMPL(LEFT, OP, RIGHT, TYPE, FMT, CAST) do { \
|
|
|
|
const TYPE __left = (TYPE)(LEFT); \
|
|
|
|
const TYPE __right = (TYPE)(RIGHT); \
|
|
|
|
if (!(__left OP __right)) { \
|
|
|
|
printk("Failed VERIFY3(" FMT " " #OP " " FMT ")\n", \
|
|
|
|
CAST __left, CAST __right); \
|
|
|
|
BUG(); \
|
|
|
|
} \
|
2008-03-05 03:58:54 +03:00
|
|
|
} while (0)
|
|
|
|
|
2008-03-28 01:06:59 +03:00
|
|
|
#define VERIFY3S(x, y, z) VERIFY3_IMPL(x, y, z, int64_t, "%ld", (long))
|
|
|
|
#define VERIFY3U(x, y, z) VERIFY3_IMPL(x, y, z, uint64_t, "%lu", (unsigned long))
|
|
|
|
#define VERIFY3P(x, y, z) VERIFY3_IMPL(x, y, z, uintptr_t, "%p", (void *))
|
2008-03-05 03:58:54 +03:00
|
|
|
|
2008-03-28 01:06:59 +03:00
|
|
|
#define ASSERT3S(x, y, z) VERIFY3S(x, y, z)
|
|
|
|
#define ASSERT3U(x, y, z) VERIFY3U(x, y, z)
|
|
|
|
#define ASSERT3P(x, y, z) VERIFY3P(x, y, z)
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
/* Dtrace probes do not exist in the linux kernel */
|
|
|
|
|
|
|
|
#ifdef DTRACE_PROBE1
|
|
|
|
#undef DTRACE_PROBE1
|
|
|
|
#endif /* DTRACE_PROBE1 */
|
2008-03-07 23:48:44 +03:00
|
|
|
#define DTRACE_PROBE1(a, b, c) ((void)0)
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
#ifdef DTRACE_PROBE2
|
|
|
|
#undef DTRACE_PROBE2
|
|
|
|
#endif /* DTRACE_PROBE2 */
|
2008-03-07 23:48:44 +03:00
|
|
|
#define DTRACE_PROBE2(a, b, c, d, e) ((void)0)
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
#ifdef DTRACE_PROBE3
|
|
|
|
#undef DTRACE_PROBE3
|
|
|
|
#endif /* DTRACE_PROBE3 */
|
2008-03-07 23:48:44 +03:00
|
|
|
#define DTRACE_PROBE3(a, b, c, d, e, f, g) ((void)0)
|
2008-03-05 03:58:54 +03:00
|
|
|
|
|
|
|
#ifdef DTRACE_PROBE4
|
|
|
|
#undef DTRACE_PROBE4
|
|
|
|
#endif /* DTRACE_PROBE4 */
|
2008-03-07 23:48:44 +03:00
|
|
|
#define DTRACE_PROBE4(a, b, c, d, e, f, g, h, i) ((void)0)
|
2008-03-04 21:22:31 +03:00
|
|
|
|
2008-03-07 02:12:55 +03:00
|
|
|
/* Missing globals */
|
2008-03-04 21:22:31 +03:00
|
|
|
extern int p0;
|
2008-03-13 00:33:28 +03:00
|
|
|
extern char hw_serial[11];
|
2008-03-04 21:22:31 +03:00
|
|
|
|
2008-03-07 02:12:55 +03:00
|
|
|
/* Missing misc functions */
|
|
|
|
extern int highbit(unsigned long i);
|
2008-03-13 00:33:28 +03:00
|
|
|
extern int ddi_strtoul(const char *hw_serial, char **nptr,
|
|
|
|
int base, unsigned long *result);
|
2008-03-07 02:12:55 +03:00
|
|
|
|
2008-03-04 21:22:31 +03:00
|
|
|
#define makedevice(maj,min) makedev(maj,min)
|
|
|
|
|
|
|
|
/* common macros */
|
|
|
|
#ifndef MIN
|
|
|
|
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
|
|
|
#endif
|
|
|
|
#ifndef MAX
|
|
|
|
#define MAX(a, b) ((a) < (b) ? (b) : (a))
|
|
|
|
#endif
|
|
|
|
#ifndef ABS
|
|
|
|
#define ABS(a) ((a) < 0 ? -(a) : (a))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Compatibility macros/typedefs needed for Solaris -> Linux port
|
|
|
|
*/
|
|
|
|
#define P2ALIGN(x, align) ((x) & -(align))
|
|
|
|
#define P2CROSS(x, y, align) (((x) ^ (y)) > (align) - 1)
|
|
|
|
#define P2ROUNDUP(x, align) (-(-(x) & -(align)))
|
|
|
|
#define P2ROUNDUP_TYPED(x, align, type) \
|
|
|
|
(-(-(type)(x) & -(type)(align)))
|
|
|
|
#define P2PHASE(x, align) ((x) & ((align) - 1))
|
|
|
|
#define P2NPHASE(x, align) (-(x) & ((align) - 1))
|
|
|
|
#define P2NPHASE_TYPED(x, align, type) \
|
|
|
|
(-(type)(x) & ((type)(align) - 1))
|
|
|
|
#define ISP2(x) (((x) & ((x) - 1)) == 0)
|
|
|
|
#define IS_P2ALIGNED(v, a) ((((uintptr_t)(v)) & ((uintptr_t)(a) - 1)) == 0)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Typed version of the P2* macros. These macros should be used to ensure
|
|
|
|
* that the result is correctly calculated based on the data type of (x),
|
|
|
|
* which is passed in as the last argument, regardless of the data
|
|
|
|
* type of the alignment. For example, if (x) is of type uint64_t,
|
|
|
|
* and we want to round it up to a page boundary using "PAGESIZE" as
|
|
|
|
* the alignment, we can do either
|
|
|
|
* P2ROUNDUP(x, (uint64_t)PAGESIZE)
|
|
|
|
* or
|
|
|
|
* P2ROUNDUP_TYPED(x, PAGESIZE, uint64_t)
|
|
|
|
*/
|
|
|
|
#define P2ALIGN_TYPED(x, align, type) \
|
|
|
|
((type)(x) & -(type)(align))
|
|
|
|
#define P2PHASE_TYPED(x, align, type) \
|
|
|
|
((type)(x) & ((type)(align) - 1))
|
|
|
|
#define P2NPHASE_TYPED(x, align, type) \
|
|
|
|
(-(type)(x) & ((type)(align) - 1))
|
|
|
|
#define P2ROUNDUP_TYPED(x, align, type) \
|
|
|
|
(-(-(type)(x) & -(type)(align)))
|
|
|
|
#define P2END_TYPED(x, align, type) \
|
|
|
|
(-(~(type)(x) & -(type)(align)))
|
|
|
|
#define P2PHASEUP_TYPED(x, align, phase, type) \
|
|
|
|
((type)(phase) - (((type)(phase) - (type)(x)) & -(type)(align)))
|
|
|
|
#define P2CROSS_TYPED(x, y, align, type) \
|
|
|
|
(((type)(x) ^ (type)(y)) > (type)(align) - 1)
|
|
|
|
#define P2SAMEHIGHBIT_TYPED(x, y, type) \
|
|
|
|
(((type)(x) ^ (type)(y)) < ((type)(x) & (type)(y)))
|
|
|
|
|
|
|
|
#if defined(_KERNEL) && !defined(_KMEMUSER) && !defined(offsetof)
|
|
|
|
|
|
|
|
/* avoid any possibility of clashing with <stddef.h> version */
|
|
|
|
|
|
|
|
#define offsetof(s, m) ((size_t)(&(((s *)0)->m)))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _SPL_SYSMACROS_H */
|