Fix bug for lsslp on AIX
git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@3485 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
parent
947dfd80ee
commit
d7be6ec60d
@ -106,6 +106,9 @@ sub connect {
|
||||
return( "Unable to redirect STDERR: $!" );
|
||||
}
|
||||
}
|
||||
$IO::Socket::SSL::VERSION = undef;
|
||||
eval { require Net::SSL };
|
||||
|
||||
##################################
|
||||
# Turn on tracing
|
||||
##################################
|
||||
@ -1727,11 +1730,16 @@ sub set_netcfg
|
||||
|
||||
return ( [RC_ERROR,"Cannot find interface $inc_name"]) if ( ! exists ($$interfaces{ $real_inc_name}));
|
||||
|
||||
$interfaces->{ $real_inc_name}->{'selected'}->check();
|
||||
|
||||
#not work on AIX
|
||||
# $interfaces->{ $real_inc_name}->{'selected'}->check();
|
||||
my @tmp_options = $interfaces->{ $real_inc_name}->{'selected'}->possible_values();
|
||||
$interfaces->{ $real_inc_name}->{'selected'}->value(@tmp_options[1] );
|
||||
if ( $interfaces->{ $real_inc_name}->{'type'})
|
||||
{
|
||||
$interfaces->{ $real_inc_name}->{'type'}->value('Static');
|
||||
@tmp_options = $interfaces->{ $real_inc_name}->{'type'}->possible_values();
|
||||
$interfaces->{ $real_inc_name}->{'type'}->value(@tmp_options[0]);
|
||||
#not work on AIX
|
||||
# $interfaces->{ $real_inc_name}->{'type'}->value('Static');
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -1773,7 +1781,7 @@ sub set_netcfg
|
||||
|
||||
#Go to the confirm page
|
||||
$form = HTML::Form->parse( $res->content, $res->base );
|
||||
# $data = $form->click('submit');
|
||||
$data = $form->click('submit');
|
||||
$res = $ua->request( $data);
|
||||
if ($res->is_success())
|
||||
{
|
||||
@ -1798,16 +1806,27 @@ sub format_netcfg
|
||||
$output .= "\n\t" . $inc . ":\n";
|
||||
$output =~ s/interface(\d)/eth$1/;
|
||||
# There are 2 possible value for $type,
|
||||
# 1 means "Dynamic", 2 means "Static"
|
||||
# the first means "Dynamic", 2nd means "Static"
|
||||
# Now to find the correct type name
|
||||
my $curr_type = $interfaces->{$inc}->{'type'}->value();
|
||||
my @possible_values = $interfaces->{$inc}->{'type'}->possible_values();
|
||||
my @possible_names = $interfaces->{$inc}->{'type'}->value_names();
|
||||
my %value_names = {};
|
||||
for ( my $i = 0; $i < scalar( @possible_values); $i++)
|
||||
my $type;
|
||||
if ($curr_type == @possible_values[0])
|
||||
{
|
||||
$value_names{ @possible_values[$i]} = @possible_names[$i];
|
||||
$type = "Dynamic";
|
||||
}
|
||||
my $type = $interfaces->{$inc}->{'type'} ? $value_names{ $interfaces->{$inc}->{'type'}->value()} : undef;;
|
||||
else
|
||||
{
|
||||
$type = "Static";
|
||||
}
|
||||
#not work on AIX
|
||||
#my @possible_names = $interfaces->{$inc}->{'type'}->value_names();
|
||||
#my %value_names = {};
|
||||
#for ( my $i = 0; $i < scalar( @possible_values); $i++)
|
||||
#{
|
||||
# $value_names{ @possible_values[$i]} = @possible_names[$i];
|
||||
#}
|
||||
#my $type = $interfaces->{$inc}->{'type'} ? $value_names{ $interfaces->{$inc}->{'type'}->value()} : undef;;
|
||||
$type = "Static" if ( $type == 2);
|
||||
my $ip = $interfaces->{$inc}->{'ip'} ? $interfaces->{$inc}->{'ip'}->value() : undef;
|
||||
my $hostname = $interfaces->{$inc}->{'hostname'} ? $interfaces->{$inc}->{'hostname'}->value() : undef;
|
||||
|
@ -14,14 +14,8 @@ if ($^O =~ /^linux/i) {
|
||||
}
|
||||
use xCAT::PPCdb;
|
||||
|
||||
#######################################
|
||||
# Perl::SNMP not working on AIX yet
|
||||
#######################################
|
||||
if ($^O =~ /^linux/i) {
|
||||
eval { require xCAT::MacMap };
|
||||
eval { require xCAT_plugin::blade };
|
||||
}
|
||||
|
||||
require xCAT::MacMap;
|
||||
require xCAT_plugin::blade;
|
||||
|
||||
#######################################
|
||||
# Constants
|
||||
@ -120,9 +114,7 @@ my $macmap;
|
||||
##########################################################################
|
||||
sub handled_commands {
|
||||
|
||||
if ($^O =~ /^linux/i) {
|
||||
$macmap = xCAT::MacMap->new();
|
||||
}
|
||||
$macmap = xCAT::MacMap->new();
|
||||
return( {lsslp=>"lsslp"} );
|
||||
}
|
||||
|
||||
@ -663,7 +655,7 @@ sub invoke_cmd {
|
||||
}
|
||||
else #The rest must be fsp or bpa
|
||||
{
|
||||
@cmds = ("network=$target_dev->{args}");
|
||||
@cmds = ("network=$ip,$target_dev->{args}");
|
||||
trace( $request, "update config on $target_dev->{'type'} $ip");
|
||||
$result = xCAT::PPC::updconf_in_asm(
|
||||
$ip,
|
||||
@ -1915,14 +1907,10 @@ sub preprocess_request {
|
||||
# find all the service nodes for xCAT cluster
|
||||
# build an individual request for each service node
|
||||
###########################################
|
||||
my $nrtab=xCAT::Table->new("noderes", -create =>0);
|
||||
my %sv_hash=();
|
||||
if ( $nrtab)
|
||||
{
|
||||
my @all=$nrtab->getAllNodeAttribs(['servicenode']);
|
||||
foreach (@all) {
|
||||
if ($_->{servicenode}) {$sv_hash{$_->{servicenode}}=1;}
|
||||
}
|
||||
my @all = xCAT::Utils::getAllSN();
|
||||
foreach (@all) {
|
||||
if ($_->{servicenode}) {$sv_hash{$_->{servicenode}}=1;}
|
||||
}
|
||||
###########################################
|
||||
# build each request for each service node
|
||||
@ -2064,6 +2052,19 @@ sub switch_cmd {
|
||||
if ( $^O eq 'aix' && $arpent =~ /\((\S+)\)\s+at\s+(\S+)/)
|
||||
{
|
||||
($ip, $mac) = ($1,$2);
|
||||
######################################################
|
||||
# Change mac format to be same as linux. For example:
|
||||
# '0:d:60:f4:f8:22' to '00:0d:60:f4:f8:22'
|
||||
######################################################
|
||||
if ( $mac)
|
||||
{
|
||||
my @mac_sections = split /:/, $mac;
|
||||
for (@mac_sections)
|
||||
{
|
||||
$_ = "0$_" if ( length($_) == 1);
|
||||
}
|
||||
$mac = join ':', @mac_sections;
|
||||
}
|
||||
}
|
||||
elsif ( $arpent =~ /^(\S+)+\s+\S+\s+(\S+)\s/)
|
||||
{
|
||||
@ -2116,7 +2117,7 @@ sub switch_cmd {
|
||||
$name = disti_multi_node( $req, $names, $slp_all->{$ip});
|
||||
if ( ! $name)
|
||||
{
|
||||
trace( $req, "Cannot distinguish $names.");
|
||||
trace( $req, "Cannot identify node $ip.");
|
||||
next;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user