HP-UX disk query size
[fio.git] / os / os-hpux.h
index 3c90841022575c75706b558fad627615db3e72a3..1b1c95896eec5431584fb89e4ee6b35308ea8da9 100644 (file)
@@ -8,7 +8,11 @@
 #include <sys/fadvise.h>
 #include <sys/mman.h>
 #include <sys/mpctl.h>
-#include <sys/scsi.h>
+#include <sys/diskio.h>
+#include <sys/param.h>
+#include <sys/pstat.h>
+#include <time.h>
+#include <aio.h>
 
 #include "../file.h"
 
@@ -18,6 +22,7 @@
 #define FIO_HAVE_CLOCK_MONOTONIC
 #define FIO_HAVE_PSHARED_MUTEX
 #define FIO_HAVE_FADVISE
+#define FIO_HAVE_CHARDEV_SIZE
 
 #define OS_MAP_ANON            MAP_ANONYMOUS
 #define OS_MSG_DONTWAIT                0
 #define POSIX_MADV_RANDOM      MADV_RANDOM
 #define posix_madvise(ptr, sz, hint)   madvise((ptr), (sz), (hint))
 
+#ifndef CLOCK_MONOTONIC
+#define CLOCK_MONOTONIC                CLOCK_REALTIME
+#endif
+
+#ifndef MSG_WAITALL
+#define MSG_WAITALL    0x40
+#endif
+
 static inline int blockdev_invalidate_cache(struct fio_file *f)
 {
        return EINVAL;
@@ -34,10 +47,13 @@ static inline int blockdev_invalidate_cache(struct fio_file *f)
 
 static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
 {
-       struct capacity cap;
+       disk_describe_type_ext_t dext;
+
+       if (!ioctl(f->fd, DIOC_DESCRIBE_EXT, &dext)) {
+               unsigned long long lba;
 
-       if (!ioctl(f->fd, SIOC_CAPACITY, &cap) == -1) {
-               *bytes = cap.lba * cap.blksz;
+               lba = ((uint64_t) dext.maxsva_high << 32) | dext.maxsva_low;
+               *bytes = lba * dext.lgblksz;
                return 0;
        }
 
@@ -45,18 +61,24 @@ static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
        return errno;
 }
 
+static inline int chardev_size(struct fio_file *f, unsigned long long *bytes)
+{
+       return blockdev_size(f, bytes);
+}
+
 static inline unsigned long long os_phys_mem(void)
 {
-#if 0
-       long mem = sysconf(_SC_AIX_REALMEM);
+       unsigned long long ret;
+       struct pst_static pst;
+       union pstun pu;
 
-       if (mem == -1)
+       pu.pst_static = &pst;
+       if (pstat(PSTAT_STATIC, pu, sizeof(pst), 0, 0) == -1)
                return 0;
 
-       return (unsigned long long) mem * 1024;
-#else
-       return 0;
-#endif
+       ret = pst.physical_memory;
+       ret *= pst.page_size;
+       return ret;
 }
 
 #define FIO_HAVE_CPU_ONLINE_SYSCONF