projects
/
fio.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
HP-UX disk query size
[fio.git]
/
os
/
os-hpux.h
diff --git
a/os/os-hpux.h
b/os/os-hpux.h
index a36cb70424d255b8fc73c79820a82fb4b4603af3..1b1c95896eec5431584fb89e4ee6b35308ea8da9 100644
(file)
--- a/
os/os-hpux.h
+++ b/
os/os-hpux.h
@@
-8,6
+8,11
@@
#include <sys/fadvise.h>
#include <sys/mman.h>
#include <sys/mpctl.h>
#include <sys/fadvise.h>
#include <sys/mman.h>
#include <sys/mpctl.h>
+#include <sys/diskio.h>
+#include <sys/param.h>
+#include <sys/pstat.h>
+#include <time.h>
+#include <aio.h>
#include "../file.h"
#include "../file.h"
@@
-17,6
+22,7
@@
#define FIO_HAVE_CLOCK_MONOTONIC
#define FIO_HAVE_PSHARED_MUTEX
#define FIO_HAVE_FADVISE
#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 OS_MAP_ANON MAP_ANONYMOUS
#define OS_MSG_DONTWAIT 0
@@
-26,6
+32,14
@@
#define POSIX_MADV_RANDOM MADV_RANDOM
#define posix_madvise(ptr, sz, hint) madvise((ptr), (sz), (hint))
#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;
static inline int blockdev_invalidate_cache(struct fio_file *f)
{
return EINVAL;
@@
-33,33
+47,38
@@
static inline int blockdev_invalidate_cache(struct fio_file *f)
static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
{
static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes)
{
-#if 0
- struct devinfo info;
+ disk_describe_type_ext_t dext;
+
+ if (!ioctl(f->fd, DIOC_DESCRIBE_EXT, &dext)) {
+ unsigned long long lba;
- if (!ioctl(f->fd, IOCINFO, &info)) {
- *bytes = (unsigned long long)info.un.scdk.numblks *
- info.un.scdk.blksize;
+ lba = ((uint64_t) dext.maxsva_high << 32) | dext.maxsva_low;
+ *bytes = lba * dext.lgblksz;
return 0;
}
return 0;
}
+ *bytes = 0;
return errno;
return errno;
-#else
- return 0;
-#endif
+}
+
+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)
{
}
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 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
}
#define FIO_HAVE_CPU_ONLINE_SYSCONF