2
* Copyright (c) 2004 Mellanox Technologies LTD. All rights reserved.
4
* This software is available to you under a choice of one of two
5
* licenses. You may choose to be licensed under the terms of the GNU
6
* General Public License (GPL) Version 2, available from the file
7
* COPYING in the main directory of this source tree, or the
8
* OpenIB.org BSD license below:
10
* Redistribution and use in source and binary forms, with or
11
* without modification, are permitted provided that the following
14
* - Redistributions of source code must retain the above
15
* copyright notice, this list of conditions and the following
18
* - Redistributions in binary form must reproduce the above
19
* copyright notice, this list of conditions and the following
20
* disclaimer in the documentation and/or other materials
21
* provided with the distribution.
23
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
27
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
28
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
29
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
35
/****h* IBMS/IB Management Simulator
37
* IB Management Simulator
40
* The top level object of the management simulator
43
* Eitan Zahavi, Mellanox
50
#include <ibdm/Fabric.h>
53
#include "dispatcher.h"
56
/* Stores the entire topology */
57
class IBFabric *pFabric;
59
/* Server to handle client connections */
60
class IBMSServer *pServer;
62
/* Dispatcher for MAD messages */
63
class IBMSDispatcher *pDispatcher;
65
/* allocate guids to the nodes */
66
int allocateFabricNodeGuids();
68
/* initialize simulator nodes */
69
int populateFabricNodes();
71
/* the random generator seed */
72
unsigned int randomSeed;
74
/* lock - enables locking the simulator */
84
pthread_mutex_init( &lock, NULL );
88
inline class IBFabric *getFabric() { return pFabric;};
89
inline class IBMSServer *getServer() { return pServer; };
90
inline class IBMSDispatcher *getDispatcher() { return pDispatcher; };
92
/* Initialize the fabric server and dispatcher */
93
int init(string topoFileName, int serverPortNum, int numWorkers);
95
/* get the directory name where the simulator rendezvous exists */
96
char *getSimulatorDir();
98
/* set the random number seed */
99
int setRandomSeed( int seed );
101
/* get a random floating point number 0.0 - 1.0 */
105
#endif /* IBMS_SIM_H */