blob: 22765ce60161075bb4aba10c32d4ddd4900ddf90 [file] [log] [blame]
Jens Axboeebac4652005-12-08 15:25:21 +01001#ifndef FIO_OS_FREEBSD_H
2#define FIO_OS_FREEBSD_H
3
Jens Axboecca84642011-10-07 12:47:57 +02004#define FIO_OS os_freebsd
5
Jens Axboe690dec62009-01-06 14:22:30 +01006#include <errno.h>
Jens Axboe5c4e1db2006-06-07 14:17:08 +02007#include <sys/sysctl.h>
Jens Axboeaa5e69b2010-06-24 09:25:15 +02008#include <sys/disk.h>
Jens Axboeb9396832011-07-30 13:29:58 +02009#include <sys/thr.h>
Bruce Cranf1415a92011-10-08 18:50:34 +020010#include <sys/socket.h>
Bruce Cran63820492013-02-21 12:39:24 +000011#include <sys/param.h>
12#include <sys/cpuset.h>
Jens Axboe5c4e1db2006-06-07 14:17:08 +020013
Jens Axboee2e58882011-01-04 08:36:06 +010014#include "../file.h"
15
Jens Axboe2c0ecd22006-06-08 13:25:41 +020016#define FIO_HAVE_ODIRECT
Jens Axboe53531372009-12-15 10:28:37 +010017#define FIO_USE_GENERIC_RAND
Bruce Cran93bcfd22012-02-20 20:18:19 +010018#define FIO_USE_GENERIC_INIT_RANDOM_STATE
Jens Axboe4ccdccd2010-06-24 10:27:22 +020019#define FIO_HAVE_CHARDEV_SIZE
Jens Axboee8d588e2011-07-12 22:33:53 +020020#define FIO_HAVE_GETTID
Bruce Cran63820492013-02-21 12:39:24 +000021#define FIO_HAVE_CPU_AFFINITY
Jens Axboeebac4652005-12-08 15:25:21 +010022
Jens Axboedc873b62008-06-04 20:13:04 +020023#define OS_MAP_ANON MAP_ANON
Jens Axboeebac4652005-12-08 15:25:21 +010024
Jens Axboe232f9b72011-10-04 14:45:20 +020025#define fio_swap16(x) bswap16(x)
26#define fio_swap32(x) bswap32(x)
27#define fio_swap64(x) bswap64(x)
28
Jens Axboe907249c2010-06-22 10:30:11 +020029typedef off_t off64_t;
30
Bruce Cran63820492013-02-21 12:39:24 +000031typedef cpuset_t os_cpu_mask_t;
32
33#define fio_cpu_clear(mask, cpu) (void) CPU_CLR((cpu), (mask))
34#define fio_cpu_set(mask, cpu) (void) CPU_SET((cpu), (mask))
Jens Axboe50b58602014-02-28 15:08:25 -080035#define fio_cpu_isset(mask, cpu) CPU_ISSET((cpu), (mask))
Jens Axboed004a202014-03-04 09:02:10 -070036#define fio_cpu_count(mask) CPU_COUNT((mask))
Bruce Cran63820492013-02-21 12:39:24 +000037
38static inline int fio_cpuset_init(os_cpu_mask_t *mask)
39{
40 CPU_ZERO(mask);
41 return 0;
42}
43
44static inline int fio_cpuset_exit(os_cpu_mask_t *mask)
45{
46 return 0;
47}
48
49static inline int fio_setaffinity(int pid, os_cpu_mask_t cpumask)
50{
51 return cpuset_setaffinity(CPU_LEVEL_WHICH, CPU_WHICH_TID, pid, sizeof(cpumask), &cpumask);
52}
53
54static inline int fio_getaffinity(int pid, os_cpu_mask_t *cpumask)
55{
56 return cpuset_getaffinity(CPU_LEVEL_WHICH, CPU_WHICH_PID, pid, sizeof(cpumask), cpumask);
57}
58
59#define FIO_MAX_CPUS CPU_SETSIZE
60
Bruce Cranecc314b2011-01-04 10:59:30 +010061static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
Jens Axboeaa5e69b2010-06-24 09:25:15 +020062{
63 off_t size;
64
Bruce Cranecc314b2011-01-04 10:59:30 +010065 if (!ioctl(f->fd, DIOCGMEDIASIZE, &size)) {
Jens Axboeaa5e69b2010-06-24 09:25:15 +020066 *bytes = size;
67 return 0;
68 }
69
Jens Axboe2fa55e92010-06-24 09:36:11 +020070 *bytes = 0;
Jens Axboeaa5e69b2010-06-24 09:25:15 +020071 return errno;
72}
73
Bruce Cranecc314b2011-01-04 10:59:30 +010074static inline int chardev_size(struct fio_file *f, unsigned long long *bytes)
Jens Axboe4ccdccd2010-06-24 10:27:22 +020075{
Bruce Cran9b836562011-01-08 19:49:54 +010076 return blockdev_size(f, bytes);
Jens Axboe4ccdccd2010-06-24 10:27:22 +020077}
78
Bruce Cranecc314b2011-01-04 10:59:30 +010079static inline int blockdev_invalidate_cache(struct fio_file *f)
Jens Axboee5b401d2006-10-18 16:03:40 +020080{
81 return EINVAL;
Jens Axboeebac4652005-12-08 15:25:21 +010082}
83
Jens Axboe32cd46a2006-06-07 13:40:40 +020084static inline unsigned long long os_phys_mem(void)
85{
86 int mib[2] = { CTL_HW, HW_PHYSMEM };
87 unsigned long long mem;
88 size_t len = sizeof(mem);
89
90 sysctl(mib, 2, &mem, &len, NULL, 0);
91 return mem;
92}
93
Jens Axboee8d588e2011-07-12 22:33:53 +020094static inline int gettid(void)
95{
96 long lwpid;
97
98 thr_self(&lwpid);
99 return (int) lwpid;
100}
101
Jens Axboea1c58072009-08-04 23:17:02 +0200102#ifdef MADV_FREE
103#define FIO_MADV_FREE MADV_FREE
104#endif
105
Jens Axboeebac4652005-12-08 15:25:21 +0100106#endif