blob: 35148d2dfcec7bf6aff5de95af36a30357842b84 [file] [log] [blame]
Jens Axboe2c0ecd22006-06-08 13:25:41 +02001#ifndef FIO_OS_SOLARIS_H
2#define FIO_OS_SOLARIS_H
3
Jens Axboee116f2b2008-06-04 15:14:24 +02004#include <sys/types.h>
5#include <sys/fcntl.h>
Jens Axboe6f7024e2008-12-12 20:42:26 +01006#include <sys/pset.h>
Jens Axboee116f2b2008-06-04 15:14:24 +02007
Jens Axboe2c0ecd22006-06-08 13:25:41 +02008#define FIO_HAVE_POSIXAIO
Jens Axboe417f0062008-06-02 11:59:30 +02009#define FIO_HAVE_SOLARISAIO
Jens Axboefffca022008-06-02 12:23:40 +020010#define FIO_HAVE_FALLOCATE
Jens Axboe207cb0f2008-06-02 12:28:02 +020011#define FIO_HAVE_POSIXAIO_FSYNC
Jens Axboe6f7024e2008-12-12 20:42:26 +010012#define FIO_HAVE_CPU_AFFINITY
Jens Axboef356d012009-01-05 09:56:29 +010013#define FIO_HAVE_PSHARED_MUTEX
Jens Axboe2c0ecd22006-06-08 13:25:41 +020014
Jens Axboedc873b62008-06-04 20:13:04 +020015#define OS_MAP_ANON MAP_ANON
16#define OS_RAND_MAX 2147483648UL
Jens Axboe2c0ecd22006-06-08 13:25:41 +020017
Jens Axboef022ddb2008-06-04 19:55:58 +020018struct solaris_rand_seed {
19 unsigned short r[3];
20};
21
Jens Axboe6f7024e2008-12-12 20:42:26 +010022typedef psetid_t os_cpu_mask_t;
Jens Axboef022ddb2008-06-04 19:55:58 +020023typedef struct solaris_rand_seed os_random_state_t;
Jens Axboe2c0ecd22006-06-08 13:25:41 +020024
25/*
26 * FIXME
27 */
28static inline int blockdev_size(int fd, unsigned long long *bytes)
29{
Jens Axboee5b401d2006-10-18 16:03:40 +020030 return EINVAL;
31}
32
33static inline int blockdev_invalidate_cache(int fd)
34{
35 return EINVAL;
Jens Axboe2c0ecd22006-06-08 13:25:41 +020036}
37
38static inline unsigned long long os_phys_mem(void)
39{
Jens Axboe2c0ecd22006-06-08 13:25:41 +020040 return 0;
Jens Axboe2c0ecd22006-06-08 13:25:41 +020041}
42
43static inline void os_random_seed(unsigned long seed, os_random_state_t *rs)
44{
Jens Axboef022ddb2008-06-04 19:55:58 +020045 rs->r[0] = seed & 0xffff;
46 seed >>= 16;
47 rs->r[1] = seed & 0xffff;
48 seed >>= 16;
49 rs->r[2] = seed & 0xffff;
50 seed48(rs->r);
Jens Axboe2c0ecd22006-06-08 13:25:41 +020051}
52
53static inline long os_random_long(os_random_state_t *rs)
54{
Jens Axboef022ddb2008-06-04 19:55:58 +020055 return nrand48(rs->r);
Jens Axboe2c0ecd22006-06-08 13:25:41 +020056}
57
Jens Axboee116f2b2008-06-04 15:14:24 +020058#define FIO_OS_DIRECTIO
59extern int directio(int, int);
60static inline int fio_set_odirect(int fd)
61{
62 if (directio(fd, DIRECTIO_ON) < 0)
63 return errno;
64
65 return 0;
66}
67
Jens Axboe6f7024e2008-12-12 20:42:26 +010068/*
69 * pset binding hooks for fio
70 */
71#define fio_setaffinity(td) \
Jens Axboe39555d02008-12-22 11:28:26 +010072 pset_bind((td)->o.cpumask, P_PID, (td)->pid, NULL)
73#define fio_getaffinity(pid, ptr) ({ 0; })
Jens Axboe6f7024e2008-12-12 20:42:26 +010074
Jens Axboe39555d02008-12-22 11:28:26 +010075#define fio_cpu_clear(mask, cpu) pset_assign(PS_NONE, (cpu), NULL)
76#define fio_cpu_set(mask, cpu) pset_assign(*(mask), (cpu), NULL)
Jens Axboed2ce18b2008-12-12 20:51:40 +010077
78static inline int fio_cpuset_init(os_cpu_mask_t *mask)
79{
80 int ret;
81
82 if (pset_create(mask) < 0) {
83 ret = errno;
84 return -1;
85 }
86
87 return 0;
88}
89
90static inline int fio_cpuset_exit(os_cpu_mask_t *mask)
91{
92 int ret;
93
94 if (pset_destroy(*mask) < 0) {
95 ret = errno;
96 return -1;
97 }
98
99 return 0;
100}
Jens Axboe6f7024e2008-12-12 20:42:26 +0100101
102/*
103 * Should be enough, not aware of what (if any) restrictions Solaris has
104 */
105#define FIO_MAX_CPUS 16384
106
Jens Axboe2c0ecd22006-06-08 13:25:41 +0200107#endif