-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathREADME
103 lines (72 loc) · 3.31 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
Infiniband Fabric Simulator - ibsim
===================================
Basic Description and main features.
-----------------------------------
ibsim emulates the fabric behavior by using MAD communication with the
SM/SA and the PerfMgr. This simple tool is ideally suitable for various
research, development, debug and testing tasks where IB subnet
management is involved.
For generation and reception of this MAD traffic it replaces the
/dev/umadX file descriptor interface between libibumad and ib_umad
kernel module by using preloaded libumad2sim.so shared library (umad2sim
wrapper - part of ibsim distribution). This conveys MADs to/from
SM/SA/PerfMgr to ibsim.
OpenSM Diags utils App (using libibumad)
| | |
V V |
libosmvendor libibmad |
| | |
V V V
libibumad
|
V
--> LD_PRELOAD=libumad2sim.so <--> ibsim
---------------------------------
ib stack (ib_umad.ko)
Any libibumad based application may work with ibsim. Kernel support
and userspace application recompilation are not required.
ibsim works locally via unix sockets or remotely via inet sockets.
For fabric topology description, ibsim uses a text file in the format
compatible with ibnetdiscover command output (for examples see
net-examples/) and it can be generated using a real cluster snapshot.
ibsim has a simple console command interface and can simulate random
packets drops and link up/down events. It is possible to run batch
commands from file via pipe or named fifo.
Building and using ibsim
------------------------
1. cd to unpacked simulator directory.
2. make ibsim and umad2sim wrapper:
$ make
Notes:
- by default this will build ibsim against installed in /usr/local
version of libib* libraries. If you like to build it against
development tree use IB_DEV_DIR variable (or export it into
environment):
$ make IB_DEV_DIR=${HOME}/src/management
- 'make dep', 'make clean' and 'make install' are available now
3. run ibsim:
$ ./ibsim/ibsim -s <netfile>
, where <netfile> is network definition file, it is compatible with
output of ibnetdiscover command (+some more options are available as
well). Some examples can be found under 'net-examples' directory.
Notes:
- '-s' option is in order to start the IB network immediately, the
ibsim console may be used instead.
- '-h' option shows ibsim command line usage and 'help' and '?'
ibsim console commands show brief console help.
4. run libibumad based application with preloaded umad2sim wrapper:
$ LD_PRELOAD=./umad2sim/libumad2sim.so ibnetdiscover
, or
$ LD_PRELOAD=./umad2sim/libumad2sim.so opensm -f -
Notes:
- in order to run OpenSM as non-privileged user you may need to
export OSM_CACHE_DIR variable and to use '-f' option in order to
specify writable path to OpenSM log file.
- Point of attachment is indicated by SIM_HOST environment variable.
If not specified, first entry in topology file is used. For OpenSM,
if -g option is used, it must be the same as this.
5. Enjoy and comment.
Feedback.
---------
Please send your feedback and patches to the maintainer:
Tamir Ronen <tamirr@mellanox.com>