#--
# Copyright (c) 2004-2010 Mellanox Technologies LTD. All rights reserved.
#
# This software is available to you under a choice of one of two
# licenses. You may choose to be licensed under the terms of the GNU
# General Public License (GPL) Version 2, available from the file
# COPYING in the main directory of this source tree, or the
# OpenIB.org BSD license below:
#
# Redistribution and use in source and binary forms, with or
# without modification, are permitted provided that the following
# conditions are met:
#
# - Redistributions of source code must retain the above
# copyright notice, this list of conditions and the following
# disclaimer.
#
# - Redistributions in binary form must reproduce the above
# copyright notice, this list of conditions and the following
# disclaimer in the documentation and/or other materials
# provided with the distribution.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
#--
# This is the checker for SM lid assignment checks
##############################################################################
#
# Start up the test applications
# This is the default flow that will start OpenSM only in 0x43 verbosity
# Return a list of process ids it started (to be killed on exit)
#
proc runner {simDir osmPath osmPortGuid} {
global simCtrlSock
global env
global lmc
set osmStdOutLog [file join $simDir osm.stdout.log]
set osmLog [file join $simDir osm.log]
set lmc 1
fconfigure $simCtrlSock -blocking 1 -buffering line
puts "---------------------------------------------------------------------"
puts " Starting the SM\n"
set osmCmd "$osmPath -l $lmc -d2 -f $osmLog -g $osmPortGuid"
puts "-I- Starting: $osmCmd"
set osmPid [eval "exec $osmCmd > $osmStdOutLog &"]
# start a tracker on the log file and process:
startOsmLogAnalyzer $osmLog
return $osmPid
}
##############################################################################
#
# Check for the test results: make sure we got a "SUBNET UP"
# Return the exit code
proc checker {simDir osmPath osmPortGuid} {
global env
global simCtrlSock
global lmc
set osmLog [file join $simDir osm.log]
if {[osmWaitForUpOrDeadWithTimeout $osmLog 1000000]} {
return 1
}
puts "---------------------------------------------------------------------"
puts " OpemSM brought up the network"
puts " Randomizing some LIDs ... "
global osmPid
exec kill $osmPid
# randomize lid errors:
puts $simCtrlSock "setLidAssignmentErrors \$fabric $lmc"
puts "SIM: [gets $simCtrlSock]"
puts "---------------------------------------------------------------------"
puts " SUBNET READY FOR DIAGNOSTICS"
puts "\nCut and paste the following in a new window then run ibdiagnet:"
puts "cd $simDir"
puts "setenv IBMGTSIM_DIR $simDir"
puts "setenv OSM_CACHE_DIR $simDir"
puts "setenv OSM_TMP_DIR $simDir"
puts " "
puts " press Enter when done"
gets stdin
return 0
}