xref: /onnv-gate/usr/src/cmd/filebench/common/ipc.h (revision 6212:d9dcad6dd79c)
15184Sek110237 /*
25184Sek110237  * CDDL HEADER START
35184Sek110237  *
45184Sek110237  * The contents of this file are subject to the terms of the
55184Sek110237  * Common Development and Distribution License (the "License").
65184Sek110237  * You may not use this file except in compliance with the License.
75184Sek110237  *
85184Sek110237  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
95184Sek110237  * or http://www.opensolaris.org/os/licensing.
105184Sek110237  * See the License for the specific language governing permissions
115184Sek110237  * and limitations under the License.
125184Sek110237  *
135184Sek110237  * When distributing Covered Code, include this CDDL HEADER in each
145184Sek110237  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
155184Sek110237  * If applicable, add the following below this CDDL HEADER, with the
165184Sek110237  * fields enclosed by brackets "[]" replaced with your own identifying
175184Sek110237  * information: Portions Copyright [yyyy] [name of copyright owner]
185184Sek110237  *
195184Sek110237  * CDDL HEADER END
205184Sek110237  */
215184Sek110237 /*
226084Saw148015  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
235184Sek110237  * Use is subject to license terms.
245184Sek110237  */
255184Sek110237 
265184Sek110237 #ifndef _FB_IPC_H
275184Sek110237 #define	_FB_IPC_H
285184Sek110237 
295184Sek110237 #pragma ident	"%Z%%M%	%I%	%E% SMI"
305184Sek110237 
315184Sek110237 #include "config.h"
325184Sek110237 #include <pthread.h>
335184Sek110237 
345184Sek110237 #include "procflow.h"
355184Sek110237 #include "threadflow.h"
365184Sek110237 #include "fileset.h"
375184Sek110237 #include "flowop.h"
38*6212Saw148015 #include "fb_random.h"
395184Sek110237 #include "filebench.h"
405184Sek110237 
415184Sek110237 #ifdef	__cplusplus
425184Sek110237 extern "C" {
435184Sek110237 #endif
445184Sek110237 
455184Sek110237 #ifdef USE_PROCESS_MODEL
465184Sek110237 #define	FILEBENCH_MEMSIZE 4096
475184Sek110237 #else
485184Sek110237 #define	FILEBENCH_MEMSIZE 2048
495184Sek110237 #endif /* USE_PROCESS_MODEL */
505184Sek110237 
515184Sek110237 #define	FILEBENCH_NFILESETS FILEBENCH_MEMSIZE
525184Sek110237 #define	FILEBENCH_NFILESETENTRIES (1024 * 1024)
535184Sek110237 #define	FILEBENCH_NPROCFLOWS FILEBENCH_MEMSIZE
54*6212Saw148015 #define	FILEBENCH_NTHREADFLOWS (64 * FILEBENCH_MEMSIZE)
55*6212Saw148015 #define	FILEBENCH_NFLOWOPS (64 * FILEBENCH_MEMSIZE)
565184Sek110237 #define	FILEBENCH_NVARS FILEBENCH_MEMSIZE
57*6212Saw148015 #define	FILEBENCH_NRANDDISTS (FILEBENCH_MEMSIZE/4)
58*6212Saw148015 #define	FILEBENCH_FILESETPATHMEMORY (FILEBENCH_NFILESETENTRIES*FSE_MAXPATHLEN)
59*6212Saw148015 #define	FILEBENCH_STRINGMEMORY (FILEBENCH_NVARS * 128)
605184Sek110237 #define	FILEBENCH_MAXBITMAP FILEBENCH_NFILESETENTRIES
615184Sek110237 
625673Saw148015 #define	FILEBENCH_PROCFLOW	0
635673Saw148015 #define	FILEBENCH_THREADFLOW	1
645673Saw148015 #define	FILEBENCH_FLOWOP	2
65*6212Saw148015 #define	FILEBENCH_AVD		3
66*6212Saw148015 #define	FILEBENCH_VARIABLE	4
67*6212Saw148015 #define	FILEBENCH_FILESET	5
68*6212Saw148015 #define	FILEBENCH_FILESETENTRY	6
69*6212Saw148015 #define	FILEBENCH_RANDDIST	7
705673Saw148015 #define	FILEBENCH_TYPES		8
715184Sek110237 
725184Sek110237 #define	FILEBENCH_NSEMS 128
735184Sek110237 
746084Saw148015 #define	FILEBENCH_ABORT_ERROR  	1
756084Saw148015 #define	FILEBENCH_ABORT_DONE   	2
766084Saw148015 #define	FILEBENCH_ABORT_RSRC	3
776084Saw148015 
786084Saw148015 #define	FILEBENCH_MODE_TIMEOUT	0x0
796084Saw148015 #define	FILEBENCH_MODE_Q1STDONE	0x1
806084Saw148015 #define	FILEBENCH_MODE_QALLDONE	0x2
816084Saw148015 
825184Sek110237 typedef struct filebench_shm {
835184Sek110237 	pthread_mutex_t fileset_lock;
845184Sek110237 	pthread_mutex_t procflow_lock;
855184Sek110237 	pthread_mutex_t threadflow_lock;
865184Sek110237 	pthread_mutex_t flowop_lock;
875184Sek110237 	pthread_mutex_t msg_lock;
885184Sek110237 	pthread_mutex_t malloc_lock;
895184Sek110237 	pthread_mutex_t ism_lock;
905184Sek110237 	pthread_rwlock_t run_lock;
915184Sek110237 	pthread_rwlock_t flowop_find_lock;
925184Sek110237 
935184Sek110237 	char		*string_ptr;
945184Sek110237 	char		*path_ptr;
955184Sek110237 	fileset_t	*filesetlist;
965184Sek110237 	flowop_t	*flowoplist;
975184Sek110237 	procflow_t	*proclist;
985184Sek110237 	var_t		*var_list;
995184Sek110237 	var_t		*var_dyn_list;
100*6212Saw148015 	randdist_t	*shm_rand_list;
1015184Sek110237 	int		debug_level;
1025184Sek110237 	hrtime_t	epoch;
1035184Sek110237 	hrtime_t	starttime;
1045184Sek110237 	int		bequiet;
1055184Sek110237 	key_t		semkey;
1065184Sek110237 	int		seminit;
1075184Sek110237 	int		semid_seq;
1085184Sek110237 	int		utid;
1095184Sek110237 	int		log_fd;
1105184Sek110237 	int		dump_fd;
1115184Sek110237 	char		dump_filename[MAXPATHLEN];
1125184Sek110237 	pthread_mutex_t	eventgen_lock;
1135184Sek110237 	pthread_cond_t	eventgen_cv;
1145184Sek110237 	int		eventgen_hz;
1155673Saw148015 	uint64_t	eventgen_q;
1165184Sek110237 	char		fscriptname[1024];
1175184Sek110237 	int		shm_id;
1185184Sek110237 	size_t		shm_required;
1195184Sek110237 	size_t		shm_allocated;
1205184Sek110237 	caddr_t		shm_addr;
1215184Sek110237 	char		*shm_ptr;
1226084Saw148015 	int		shm_running;
1235184Sek110237 	int		f_abort;
1246084Saw148015 	int		shm_rmode;
1256084Saw148015 	int		shm_1st_err;
1265184Sek110237 
1275184Sek110237 	int		marker;
1285184Sek110237 
1295184Sek110237 	fileset_t	fileset[FILEBENCH_NFILESETS];
1305184Sek110237 	filesetentry_t	filesetentry[FILEBENCH_NFILESETENTRIES];
1315184Sek110237 	char		filesetpaths[FILEBENCH_FILESETPATHMEMORY];
1325184Sek110237 	procflow_t	procflow[FILEBENCH_NPROCFLOWS];
1335184Sek110237 	threadflow_t	threadflow[FILEBENCH_NTHREADFLOWS];
1345184Sek110237 	flowop_t	flowop[FILEBENCH_NFLOWOPS];
1355184Sek110237 	var_t		var[FILEBENCH_NVARS];
136*6212Saw148015 	randdist_t	shm_randdist[FILEBENCH_NRANDDISTS];
137*6212Saw148015 	struct avd	shm_avd_ptrs[FILEBENCH_NVARS * 2];
1385184Sek110237 	char		strings[FILEBENCH_STRINGMEMORY];
1395184Sek110237 	char		semids[FILEBENCH_NSEMS];
1405184Sek110237 	int		bitmap[FILEBENCH_TYPES][FILEBENCH_MAXBITMAP];
1415184Sek110237 } filebench_shm_t;
1425184Sek110237 
1435184Sek110237 extern char *shmpath;
1445184Sek110237 
1455184Sek110237 void ipc_init(void);
1465184Sek110237 void *ipc_malloc(int type);
1475184Sek110237 void ipc_free(int type, char *addr);
1485184Sek110237 int ipc_attach(caddr_t shmaddr);
1495184Sek110237 pthread_mutexattr_t *ipc_mutexattr(void);
1505184Sek110237 pthread_condattr_t *ipc_condattr(void);
1515184Sek110237 int ipc_semidalloc(void);
1525184Sek110237 void ipc_semidfree(int semid);
1535184Sek110237 char *ipc_stralloc(char *string);
1545184Sek110237 char *ipc_pathalloc(char *string);
1555184Sek110237 int ipc_mutex_lock(pthread_mutex_t *mutex);
1565184Sek110237 int ipc_mutex_unlock(pthread_mutex_t *mutex);
1575184Sek110237 void ipc_seminit(void);
1585184Sek110237 char *ipc_ismmalloc(size_t size);
1595184Sek110237 int ipc_ismcreate(size_t size);
1605184Sek110237 void ipc_ismdelete(void);
1615184Sek110237 void ipc_cleanup(void);
1625184Sek110237 
1635184Sek110237 extern filebench_shm_t *filebench_shm;
1645184Sek110237 
1655184Sek110237 #ifdef	__cplusplus
1665184Sek110237 }
1675184Sek110237 #endif
1685184Sek110237 
1695184Sek110237 #endif	/* _FB_IPC_H */
170