Fix for crash with more than ~500 jobs
[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
93bcfd20 25#define FIO_USE_GENERIC_INIT_RANDOM_STATE
862745bf 26#define FIO_HAVE_GETTID
2c0ecd28 27
dc873b6f
JA
28#define OS_MAP_ANON MAP_ANON
29#define OS_RAND_MAX 2147483648UL
2c0ecd28 30
232f9b73
JA
31#if defined(_BIG_ENDIAN)
32#define FIO_BIG_ENDIAN
33#else
34#define FIO_LITTLE_ENDIAN
35#endif
36
37#define fio_swap16(x) BSWAP_16(x)
38#define fio_swap32(x) BSWAP_32(x)
39#define fio_swap64(x) BSWAP_64(x)
40
f022ddb7
JA
41struct solaris_rand_seed {
42 unsigned short r[3];
43};
44
3f77f723 45#ifndef POSIX_MADV_SEQUENTIAL
08987f0e 46#define posix_madvise madvise
08987f0e 47#define POSIX_MADV_SEQUENTIAL MADV_SEQUENTIAL
3f77f723 48#define POSIX_MADV_DONTNEED MADV_DONTNEED
08987f0e 49#define POSIX_MADV_RANDOM MADV_RANDOM
3f77f723 50#endif
08987f0e 51
6f7024e4 52typedef psetid_t os_cpu_mask_t;
f022ddb7 53typedef struct solaris_rand_seed os_random_state_t;
2c0ecd28 54
08987f0e
JA
55static inline int chardev_size(struct fio_file *f, unsigned long long *bytes)
56{
57 struct dk_minfo info;
58
59 *bytes = 0;
60
61 if (ioctl(f->fd, DKIOCGMEDIAINFO, &info) < 0)
62 return errno;
63
64 *bytes = info.dki_lbsize * info.dki_capacity;
65 return 0;
66}
67
9b836561 68static inline int blockdev_invalidate_cache(struct fio_file *f)
e5b401d4 69{
08987f0e 70 return 0;
2c0ecd28
JA
71}
72
73static inline unsigned long long os_phys_mem(void)
74{
2c0ecd28 75 return 0;
2c0ecd28
JA
76}
77
78static inline void os_random_seed(unsigned long seed, os_random_state_t *rs)
79{
f022ddb7
JA
80 rs->r[0] = seed & 0xffff;
81 seed >>= 16;
82 rs->r[1] = seed & 0xffff;
83 seed >>= 16;
84 rs->r[2] = seed & 0xffff;
85 seed48(rs->r);
2c0ecd28
JA
86}
87
88static inline long os_random_long(os_random_state_t *rs)
89{
f022ddb7 90 return nrand48(rs->r);
2c0ecd28
JA
91}
92
e116f2b9
JA
93#define FIO_OS_DIRECTIO
94extern int directio(int, int);
95static inline int fio_set_odirect(int fd)
96{
97 if (directio(fd, DIRECTIO_ON) < 0)
98 return errno;
99
100 return 0;
101}
102
6f7024e4
JA
103/*
104 * pset binding hooks for fio
105 */
e8462bd8 106#define fio_setaffinity(pid, cpumask) \
f2b7ce1c 107 pset_bind((cpumask), P_PID, (pid), NULL)
39555d03 108#define fio_getaffinity(pid, ptr) ({ 0; })
6f7024e4 109
39555d03
JA
110#define fio_cpu_clear(mask, cpu) pset_assign(PS_NONE, (cpu), NULL)
111#define fio_cpu_set(mask, cpu) pset_assign(*(mask), (cpu), NULL)
d2ce18b5
JA
112
113static inline int fio_cpuset_init(os_cpu_mask_t *mask)
114{
e721c57f 115 if (pset_create(mask) < 0)
d2ce18b5 116 return -1;
d2ce18b5
JA
117
118 return 0;
119}
120
121static inline int fio_cpuset_exit(os_cpu_mask_t *mask)
122{
e721c57f 123 if (pset_destroy(*mask) < 0)
d2ce18b5 124 return -1;
d2ce18b5
JA
125
126 return 0;
127}
6f7024e4 128
e8d588e4
JA
129static inline int gettid(void)
130{
131 return pthread_self();
132}
133
6f7024e4
JA
134/*
135 * Should be enough, not aware of what (if any) restrictions Solaris has
136 */
137#define FIO_MAX_CPUS 16384
138
a1c58075
JA
139#ifdef MADV_FREE
140#define FIO_MADV_FREE MADV_FREE
141#endif
142
2c0ecd28 143#endif