ptopgen.in 5.7 KB
Newer Older
Leigh B. Stoller's avatar
Leigh B. Stoller committed
1
#!/usr/bin/perl -w
2
3
use English;
use Getopt::Std;
Leigh B. Stoller's avatar
Leigh B. Stoller committed
4

5
6
7
8
9
10
11
sub usage()
{
    print STDOUT "Usage: ptopgen [-s switch]\n";
    exit(-1);
}
my  $optlist = "s:";

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

# Settings - Change these to your particular network.
#
# Explanation from Mac:
#
# These are for the imaginary "lan nodes". Internally the way we map
# lans is as a bunch of machines connected in a star to a "lan node"
# that has infinite bw basically, and an infinite number of connections
# available to it. So the first big number is BW (100Gbps), and the
# 1000 means it has 1000 connections to the switch. That number is
# plenty high as it is, since our limit on one switch is under 400.
#
# Speed in in Kbs!
#
my $lannode_switch2switch_speed = 100000000;
my $lannode_switch2switch_links = 1000;

#
# Also bogus. The interfaces table does not hold entries for the switch
# side of each link. It will have to at some point, when we have something
# other than 100Mbs ports (say, gbit ports).
#
# Speed in in Kbs!
#
my $default_switchport_speed    = 100000;

38
39
######################################################################

40
my $TBROOT = "@prefix@";
41
use lib '@prefix@/lib';
42
require exitonwarn;
43
use libdb;
Leigh B. Stoller's avatar
Leigh B. Stoller committed
44

45
%switches=();
46
%used_switches=();
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
my $switchtouse;

#
# Parse command arguments. Once we return from getopts, all that should be
# left are the required arguments.
#
%options = ();
if (! getopts($optlist, \%options)) {
    usage();
}
if (@ARGV) {
    usage();
}
if (defined($options{"s"})) {
    $switchtouse = $options{"s"};
}
63

64
# Read class/type maps
65
66
my $result = DBQueryFatal("select class,type,delay_capacity from node_types");
while (($class,$type,$delaycapacity) = $result->fetchrow_array) {
67
    $classes{$type} = $class;
68
    $nodetypes{$type} = $delaycapacity;
69
}
70
$result->finish;
71
72
73
74

# switches can't delay
$nodetypes{"switch"} = 0;

75
# Print switches
76
77
78
79
80
81
82
83
84
85
86
87
88
if (defined($switchtouse)) {
    print "node $switchtouse switch:1\n";
    $switches{$switchtouse} = 1;
}
else {
    $result =
	DBQueryFatal("select node_id from nodes where role = \"testswitch\"");

    while (($switch) = $result->fetchrow_array) {
	print "node $switch switch:1\n";
	$switches{$switch} = 1;
    }
    $result->finish;
89
}
90

Leigh B. Stoller's avatar
Leigh B. Stoller committed
91
# Find available nodes
92
$result = DBQueryFatal("select a.node_id,a.type from" .
Leigh B. Stoller's avatar
Leigh B. Stoller committed
93
94
		     " nodes as a left join reserved as b" .
		     " on a.node_id=b.node_id" .
95
		     " where b.node_id is null and a.role = \"testnode\"");
96
while (($node,$type) = $result->fetchrow_array) {
Leigh B. Stoller's avatar
Leigh B. Stoller committed
97
98
99
100
101
102
103
104
105
    # Shark hack
    if (($shelf,$number) = ($node =~ /^sh(\d+)-(\d+)/)) {
	if ($number == 1) {
	    $nodes{"sh$shelf"} = "shark-shelf";
	}
    } else {
	$nodes{$node} = $type;
    }
}
106
$result->finish;
Leigh B. Stoller's avatar
Leigh B. Stoller committed
107
108


109
$sharklinks = "";
Leigh B. Stoller's avatar
Leigh B. Stoller committed
110
111
112
113
foreach $node (keys(%nodes)) {
    if ($node =~ /^sh/) {
	print "node $node shark-shelf:1\n";
    } else {
114
115
116
117
	$text = "node $node $nodes{$node}:1 $classes{$nodes{$node}}:1";
	$delay_capacity = $nodetypes{$nodes{$node}};
	if ($delay_capacity > 0) {
	    $text .= " delay:$delay_capacity";
Leigh B. Stoller's avatar
Leigh B. Stoller committed
118
119
120
121
122
	}
	print "$text\n";
    }
}

123
# Read interfaces
124
$result = DBQueryFatal("SELECT node_id,card,port,iface,interface_type" .
125
		     " from interfaces");
126
while (($node,$card,$port,$iface,$type) = $result->fetchrow_array) {
127
128
129
130
131
    $interfacemap{"$node:$card:$port"} = $iface;
    if ($type ne "") {
	$interfacetypes{"$node:$card:$port"} = $type;
    }
}
132
$result->finish;
133
134

# Read interface types
135
136
$result = DBQueryFatal("SELECT type,max_speed from interface_types");
while (($type,$speed) = $result->fetchrow_array) {
137
138
    $interfacespeeds{$type} = $speed;
}
139
$result->finish;
140

141
$result = DBQueryFatal("SELECT node_id1,card1,port1,node_id2,card2,port2" .
142
 		    " from wires where type=\"Node\" or type=\"Trunk\"");
143
while (($node1,$card1,$port1,$node2,$card2,$port2) = 
144
       $result->fetchrow_array) {
145
    if ((defined($nodes{$node1}) || defined($switches{$node1})) && 
146
	(defined($nodes{$node2}) || defined($switches{$node2}))) {
147
148
149
150
151
152
153
154
155
	$iface1 = get_iface($node1,$card1,$port1);
	$iface2 = get_iface($node2,$card2,$port2);
	$iface1bw = get_ifacebw($node1,$card1,$port1);
	$iface2bw = get_ifacebw($node2,$card2,$port2);
	if ($iface1bw < $iface2bw) {
	    $bw = $iface1bw;
	} else {
	    $bw = $iface2bw;
	}
156
	if (defined($switches{$node2})) {
157
158
	    $used_switches{$node2} = 1;
	}
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
	if (defined($switches{$node1})) {
	    $used_switches{$node1} = 1;
	}
	if (defined($switches{$node1}) && defined($switches{$node2})) {
	    # interswitch link
	    if (defined($interconnects{"$node1:$node2"})) {
		$interconnects{"$node1:$node2"} += $bw;
	    } else {
		$interconnects{"$node1:$node2"} = $bw;
	    }
	} else {
	    # !!! - Here we use our knowledge that in the wires table links
	    # to the switch always come as node2.
	    print "link link-$node1:$iface1-$node2:$iface2 $node1:$node1/$iface1" .
		" $node2:$iface2 $bw 1\n";
	}
    } 
176
}
177
$result->finish;
178
179
180
181
foreach $interconnect (keys(%interconnects)) {
    ($src,$dst) = split(":",$interconnect);
    print "link link-$interconnect $src $dst $interconnects{$interconnect} 1\n";
}
182
183
184

print $sharklinks;

Leigh B. Stoller's avatar
Leigh B. Stoller committed
185
# Add a bunch of LANs
186
187
188
foreach $switch (keys(%used_switches)) {
    for ($i = 0;$i <= 20;$i++) {
	print "node lan-$switch-$i lan:1\n";
189
190
191
	print "link link-lan-$switch-$i lan-$switch-${i}:lan-$switch-$i " .
	    "$switch ".
	    "$lannode_switch2switch_speed $lannode_switch2switch_links\n";
192
    }
Leigh B. Stoller's avatar
Leigh B. Stoller committed
193
}
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216


# Print out links
sub get_iface {
    ($node,$card,$port) = @_;
    if (defined($interfacemap{"$node:$card:$port"})) {
	return $interfacemap{"$node:$card:$port"};
    } else {
	# shark hack
	if ($node =~ /^sh/) {
	    return "eth0";
	} else {
	    return "(null)";
	}
	# end shark hack 
    }
};

# Find the bandwidth for an interface
sub get_ifacebw {
    ($node,$card,$port) = @_;
    if (defined($interfacetypes{"$node:$card:$port"})) {
	return $interfacespeeds{$interfacetypes{"$node:$card:$port"}};
217
218
219
    }
    else {
	return $default_switchport_speed;
220
221
    }
}