#ifndef FIO_OS_NETBSD_H
#define FIO_OS_NETBSD_H
#define FIO_OS os_netbsd
#include <errno.h>
#include <lwp.h>
#include <sys/param.h>
#include <sys/statvfs.h>
#include <sys/ioctl.h>
#include <sys/dkio.h>
#include <sys/disklabel.h>
/* XXX hack to avoid confilcts between rbtree.h and <sys/rb.h> */
#define rb_node _rb_node
#include <sys/sysctl.h>
#undef rb_node
#undef rb_left
#undef rb_right
#include "../file.h"
#define FIO_HAVE_ODIRECT
#define FIO_USE_GENERIC_RAND
#define FIO_USE_GENERIC_INIT_RANDOM_STATE
#define FIO_HAVE_FS_STAT
#define FIO_HAVE_GETTID
#undef FIO_HAVE_CPU_AFFINITY /* doesn't exist */
#define OS_MAP_ANON MAP_ANON
#ifndef PTHREAD_STACK_MIN
#define PTHREAD_STACK_MIN 4096
#endif
#define fio_swap16(x) bswap16(x)
#define fio_swap32(x) bswap32(x)
#define fio_swap64(x) bswap64(x)
typedef off_t off64_t;
static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
{
struct disklabel dl;
if (!ioctl(f->fd, DIOCGDINFO, &dl)) {
*bytes = ((unsigned long long)dl.d_secperunit) * dl.d_secsize;
return 0;
}
*bytes = 0;
return errno;
}
static inline int blockdev_invalidate_cache(struct fio_file *f)
{
return ENOTSUP;
}
static inline unsigned long long os_phys_mem(void)
{
int mib[2] = { CTL_HW, HW_PHYSMEM64 };
uint64_t mem;
size_t len = sizeof(mem);
sysctl(mib, 2, &mem, &len, NULL, 0);
return mem;
}
static inline int gettid(void)
{
return (int) _lwp_self();
}
static inline unsigned long long get_fs_free_size(const char *path)
{
unsigned long long ret;
struct statvfs s;
if (statvfs(path, &s) < 0)
return -1ULL;
ret = s.f_frsize;
ret *= (unsigned long long) s.f_bfree;
return ret;
}
#ifdef MADV_FREE
#define FIO_MADV_FREE MADV_FREE
#endif
#endif