Add FIO_PREFERRED_CLOCK_SOURCE to allow selection of clock source on a per-platform...
[fio.git] / os / os-solaris.h
CommitLineData
2c0ecd28
JA
1#ifndef FIO_OS_SOLARIS_H
2#define FIO_OS_SOLARIS_H
3
cca84643
JA
4#define FIO_OS os_solaris
5
690dec6e 6#include <errno.h>
f8ed6d89 7#include <malloc.h>
e116f2b9
JA
8#include <sys/types.h>
9#include <sys/fcntl.h>
6f7024e4 10#include <sys/pset.h>
08987f0e
JA
11#include <sys/mman.h>
12#include <sys/dkio.h>
232f9b73 13#include <sys/byteorder.h>
e116f2b9 14
e2e58886
JA
15#include "../file.h"
16
2c0ecd28 17#define FIO_HAVE_POSIXAIO
417f0068 18#define FIO_HAVE_SOLARISAIO
207cb0f0 19#define FIO_HAVE_POSIXAIO_FSYNC
6f7024e4 20#define FIO_HAVE_CPU_AFFINITY
f356d01d 21#define FIO_HAVE_PSHARED_MUTEX
c36d16f5 22#define FIO_HAVE_FDATASYNC
08987f0e
JA
23#define FIO_HAVE_CHARDEV_SIZE
24#define FIO_USE_GENERIC_BDEV_SIZE
862745bf 25#define FIO_HAVE_GETTID
2c0ecd28 26
dc873b6f
JA
27#define OS_MAP_ANON MAP_ANON
28#define OS_RAND_MAX 2147483648UL
2c0ecd28 29
232f9b73
JA
30#if defined(_BIG_ENDIAN)
31#define FIO_BIG_ENDIAN
32#else
33#define FIO_LITTLE_ENDIAN
34#endif
35
36#define fio_swap16(x) BSWAP_16(x)
37#define fio_swap32(x) BSWAP_32(x)
38#define fio_swap64(x) BSWAP_64(x)
39
f022ddb7
JA
40struct solaris_rand_seed {
41 unsigned short r[3];
42};
43
3f77f723 44#ifndef POSIX_MADV_SEQUENTIAL
08987f0e 45#define posix_madvise madvise
08987f0e 46#define POSIX_MADV_SEQUENTIAL MADV_SEQUENTIAL
3f77f723 47#define POSIX_MADV_DONTNEED MADV_DONTNEED
08987f0e 48#define POSIX_MADV_RANDOM MADV_RANDOM
3f77f723 49#endif
08987f0e 50
6f7024e4 51typedef psetid_t os_cpu_mask_t;
f022ddb7 52typedef struct solaris_rand_seed os_random_state_t;
2c0ecd28 53
08987f0e
JA
54static inline int chardev_size(struct fio_file *f, unsigned long long *bytes)
55{
56 struct dk_minfo info;
57
58 *bytes = 0;
59
60 if (ioctl(f->fd, DKIOCGMEDIAINFO, &info) < 0)
61 return errno;
62
63 *bytes = info.dki_lbsize * info.dki_capacity;
64 return 0;
65}
66
9b836561 67static inline int blockdev_invalidate_cache(struct fio_file *f)
e5b401d4 68{
08987f0e 69 return 0;
2c0ecd28
JA
70}
71
72static inline unsigned long long os_phys_mem(void)
73{
2c0ecd28 74 return 0;
2c0ecd28
JA
75}
76
77static inline void os_random_seed(unsigned long seed, os_random_state_t *rs)
78{
f022ddb7
JA
79 rs->r[0] = seed & 0xffff;
80 seed >>= 16;
81 rs->r[1] = seed & 0xffff;
82 seed >>= 16;
83 rs->r[2] = seed & 0xffff;
84 seed48(rs->r);
2c0ecd28
JA
85}
86
87static inline long os_random_long(os_random_state_t *rs)
88{
f022ddb7 89 return nrand48(rs->r);
2c0ecd28
JA
90}
91
e116f2b9
JA
92#define FIO_OS_DIRECTIO
93extern int directio(int, int);
94static inline int fio_set_odirect(int fd)
95{
96 if (directio(fd, DIRECTIO_ON) < 0)
97 return errno;
98
99 return 0;
100}
101
6f7024e4
JA
102/*
103 * pset binding hooks for fio
104 */
e8462bd8 105#define fio_setaffinity(pid, cpumask) \
f2b7ce1c 106 pset_bind((cpumask), P_PID, (pid), NULL)
39555d03 107#define fio_getaffinity(pid, ptr) ({ 0; })
6f7024e4 108
39555d03
JA
109#define fio_cpu_clear(mask, cpu) pset_assign(PS_NONE, (cpu), NULL)
110#define fio_cpu_set(mask, cpu) pset_assign(*(mask), (cpu), NULL)
d2ce18b5
JA
111
112static inline int fio_cpuset_init(os_cpu_mask_t *mask)
113{
e721c57f 114 if (pset_create(mask) < 0)
d2ce18b5 115 return -1;
d2ce18b5
JA
116
117 return 0;
118}
119
120static inline int fio_cpuset_exit(os_cpu_mask_t *mask)
121{
e721c57f 122 if (pset_destroy(*mask) < 0)
d2ce18b5 123 return -1;
d2ce18b5
JA
124
125 return 0;
126}
6f7024e4 127
e8d588e4
JA
128static inline int gettid(void)
129{
130 return pthread_self();
131}
132
6f7024e4
JA
133/*
134 * Should be enough, not aware of what (if any) restrictions Solaris has
135 */
136#define FIO_MAX_CPUS 16384
137
a1c58075
JA
138#ifdef MADV_FREE
139#define FIO_MADV_FREE MADV_FREE
140#endif
141
2c0ecd28 142#endif