blob: 57ce409c67fd4d2a5476ab8e3c45577161a8d827 [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))
35
36static inline int fio_cpuset_init(os_cpu_mask_t *mask)
37{
38 CPU_ZERO(mask);
39 return 0;
40}
41
42static inline int fio_cpuset_exit(os_cpu_mask_t *mask)
43{
44 return 0;
45}
46
47static inline int fio_setaffinity(int pid, os_cpu_mask_t cpumask)
48{
49 return cpuset_setaffinity(CPU_LEVEL_WHICH, CPU_WHICH_TID, pid, sizeof(cpumask), &cpumask);
50}
51
52static inline int fio_getaffinity(int pid, os_cpu_mask_t *cpumask)
53{
54 return cpuset_getaffinity(CPU_LEVEL_WHICH, CPU_WHICH_PID, pid, sizeof(cpumask), cpumask);
55}
56
57#define FIO_MAX_CPUS CPU_SETSIZE
58
Bruce Cranecc314b2011-01-04 10:59:30 +010059static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
Jens Axboeaa5e69b2010-06-24 09:25:15 +020060{
61 off_t size;
62
Bruce Cranecc314b2011-01-04 10:59:30 +010063 if (!ioctl(f->fd, DIOCGMEDIASIZE, &size)) {
Jens Axboeaa5e69b2010-06-24 09:25:15 +020064 *bytes = size;
65 return 0;
66 }
67
Jens Axboe2fa55e92010-06-24 09:36:11 +020068 *bytes = 0;
Jens Axboeaa5e69b2010-06-24 09:25:15 +020069 return errno;
70}
71
Bruce Cranecc314b2011-01-04 10:59:30 +010072static inline int chardev_size(struct fio_file *f, unsigned long long *bytes)
Jens Axboe4ccdccd2010-06-24 10:27:22 +020073{
Bruce Cran9b836562011-01-08 19:49:54 +010074 return blockdev_size(f, bytes);
Jens Axboe4ccdccd2010-06-24 10:27:22 +020075}
76
Bruce Cranecc314b2011-01-04 10:59:30 +010077static inline int blockdev_invalidate_cache(struct fio_file *f)
Jens Axboee5b401d2006-10-18 16:03:40 +020078{
79 return EINVAL;
Jens Axboeebac4652005-12-08 15:25:21 +010080}
81
Jens Axboe32cd46a2006-06-07 13:40:40 +020082static inline unsigned long long os_phys_mem(void)
83{
84 int mib[2] = { CTL_HW, HW_PHYSMEM };
85 unsigned long long mem;
86 size_t len = sizeof(mem);
87
88 sysctl(mib, 2, &mem, &len, NULL, 0);
89 return mem;
90}
91
Jens Axboee8d588e2011-07-12 22:33:53 +020092static inline int gettid(void)
93{
94 long lwpid;
95
96 thr_self(&lwpid);
97 return (int) lwpid;
98}
99
Jens Axboea1c58072009-08-04 23:17:02 +0200100#ifdef MADV_FREE
101#define FIO_MADV_FREE MADV_FREE
102#endif
103
Jens Axboeebac4652005-12-08 15:25:21 +0100104#endif