diff usr/src/cmd/filebench/common/flowop.h @ 0:c9caec207d52 b86

Initial porting based on b86
author Koji Uno <koji.uno@sun.com>
date Tue, 02 Jun 2009 18:56:50 +0900
parents
children 1a15d5aaf794
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/usr/src/cmd/filebench/common/flowop.h	Tue Jun 02 18:56:50 2009 +0900
@@ -0,0 +1,145 @@
+/*
+ * CDDL HEADER START
+ *
+ * The contents of this file are subject to the terms of the
+ * Common Development and Distribution License (the "License").
+ * You may not use this file except in compliance with the License.
+ *
+ * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
+ * or http://www.opensolaris.org/os/licensing.
+ * See the License for the specific language governing permissions
+ * and limitations under the License.
+ *
+ * When distributing Covered Code, include this CDDL HEADER in each
+ * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
+ * If applicable, add the following below this CDDL HEADER, with the
+ * fields enclosed by brackets "[]" replaced with your own identifying
+ * information: Portions Copyright [yyyy] [name of copyright owner]
+ *
+ * CDDL HEADER END
+ */
+/*
+ * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
+ * Use is subject to license terms.
+ */
+
+#ifndef	_FB_FLOWOP_H
+#define	_FB_FLOWOP_H
+
+
+#pragma ident	"@(#)flowop.h	1.3	08/02/20 SMI"
+
+#include "config.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+#include <sys/param.h>
+#include <sys/resource.h>
+#include <pthread.h>
+#ifndef HAVE_SYSV_SEM
+#include <semaphore.h>
+#endif
+#include "stats.h"
+#include "threadflow.h"
+#include "vars.h"
+#include "fileset.h"
+#include "filebench.h"
+
+#ifdef	__cplusplus
+extern "C" {
+#endif
+
+typedef struct flowop {
+	char		fo_name[128];	/* Name */
+	int		fo_instance;	/* Instance number */
+	struct flowop	*fo_next;	/* Next in global list */
+	struct flowop	*fo_threadnext;	/* Next in thread's list */
+	struct flowop	*fo_resultnext;	/* List of flowops in result */
+	struct threadflow *fo_thread;	/* Backpointer to thread */
+	int		(*fo_func)();	/* Method */
+	int		(*fo_init)();	/* Init Method */
+	void		(*fo_destruct)(); /* Destructor Method */
+	int		fo_type;	/* Type */
+	int		fo_attrs;	/* Flow op attribute */
+	fileset_t	*fo_fileset;	/* Fileset for op */
+	int		fo_fd;		/* File descriptor */
+	int		fo_fdnumber;	/* User specified file descriptor */
+	int		fo_srcfdnumber;	/* User specified src file descriptor */
+	var_integer_t	fo_iosize;	/* Size of operation */
+	var_integer_t	fo_wss;		/* Flow op working set size */
+	char		fo_targetname[128]; /* Target, for wakeup etc... */
+	struct flowop	*fo_targets;	/* List of targets matching name */
+	struct flowop	*fo_targetnext;	/* List of targets matching name */
+	var_integer_t	fo_iters;	/* Number of iterations of op */
+	var_integer_t	fo_value;	/* Attr */
+	var_integer_t	fo_sequential;	/* Attr */
+	var_integer_t	fo_random;	/* Attr */
+	var_integer_t	fo_stride;	/* Attr */
+	var_integer_t	fo_backwards;	/* Attr */
+	var_integer_t	fo_dsync;	/* Attr */
+	var_integer_t	fo_blocking;	/* Attr */
+	var_integer_t	fo_directio;	/* Attr */
+	var_integer_t	fo_rotatefd;	/* Attr */
+	flowstat_t	fo_stats;	/* Flow statistics */
+	pthread_cond_t	fo_cv;		/* Block/wakeup cv */
+	pthread_mutex_t	fo_lock;	/* Mutex around flowop */
+	char		*fo_buf;	/* Per-flowop buffer */
+	uint64_t	fo_buf_size;	/* current size of buffer */
+#ifdef HAVE_SYSV_SEM
+	int		fo_semid_lw;	/* sem id */
+	int		fo_semid_hw;	/* sem id for highwater block */
+#else
+	sem_t		fo_sem;		/* sem_t for posix semaphores */
+#endif /* HAVE_SYSV_SEM */
+	var_integer_t	fo_highwater;	/* value of highwater paramter */
+	void		*fo_idp;	/* id, for sems etc */
+	hrtime_t	fo_timestamp;	/* for ratecontrol, etc... */
+	int		fo_initted;	/* Set to one if initialized */
+	int64_t		fo_tputbucket;	/* Throughput bucket, for limiter */
+	uint64_t	fo_tputlast;	/* Throughput count, for delta's */
+
+} flowop_t;
+
+/* Flow Op Attrs */
+#define	FLOW_ATTR_SEQUENTIAL	0x1
+#define	FLOW_ATTR_RANDOM	0x2
+#define	FLOW_ATTR_STRIDE	0x4
+#define	FLOW_ATTR_BACKWARDS	0x8
+#define	FLOW_ATTR_DSYNC		0x10
+#define	FLOW_ATTR_BLOCKING	0x20
+#define	FLOW_ATTR_DIRECTIO	0x40
+#define	FLOW_ATTR_READ		0x80
+#define	FLOW_ATTR_WRITE		0x100
+
+#define	FLOW_MASTER -1	    /* Declaration of thread from script */
+#define	FLOW_DEFINITION 0   /* Prototype definition of flowop from library */
+
+#define	FLOW_TYPES	5
+#define	FLOW_TYPE_GLOBAL	0  /* Rolled up statistics */
+#define	FLOW_TYPE_IO		1  /* Op is an I/O, reflected in iops and lat */
+#define	FLOW_TYPE_AIO		2  /* Op is an async I/O, reflected in iops */
+#define	FLOW_TYPE_SYNC		3  /* Op is a sync event */
+#define	FLOW_TYPE_OTHER		4  /* Op is a something else */
+
+extern flowstat_t controlstats;
+
+void flowop_init(void);
+flowop_t *flowop_define(threadflow_t *, char *name, flowop_t *inherit,
+    int instance, int type);
+flowop_t *flowop_find(char *name);
+flowop_t *flowop_find_one(char *name, int instance);
+void flowoplib_usage(void);
+void flowoplib_init(void);
+void flowop_delete_all(flowop_t **threadlist);
+void flowop_endop(threadflow_t *threadflow, flowop_t *flowop, int64_t bytes);
+void flowop_beginop(threadflow_t *threadflow, flowop_t *flowop);
+void flowop_destruct_all_flows(threadflow_t *threadflow);
+
+#ifdef	__cplusplus
+}
+#endif
+
+#endif	/* _FB_FLOWOP_H */