mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-10-26 00:45:38 +00:00 
			
		
		
		
	Change the way of getmacs works. Invoke the sub-routine LparNetbootExp->lparnetbootexp.
git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@11512 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
		| @@ -4,9 +4,11 @@ package xCAT::PPCmac; | ||||
| use Socket; | ||||
| use strict; | ||||
| use Getopt::Long; | ||||
| use Data::Dumper; | ||||
| use xCAT::PPCcli qw(SUCCESS EXPECT_ERROR RC_ERROR NR_ERROR); | ||||
| use xCAT::NetworkUtils; | ||||
|  | ||||
| use xCAT::LparNetbootExp; | ||||
|  | ||||
| ########################################################################## | ||||
| # Parse the command line for options and operands  | ||||
| @@ -239,6 +241,7 @@ sub do_getmacs { | ||||
|     my $ssh      = @$exp[0]; | ||||
|     my $userid   = @$exp[4]; | ||||
|     my $pw       = @$exp[5]; | ||||
|     my %optarg; | ||||
|     my $cmd; | ||||
|     my $result; | ||||
|  | ||||
| @@ -255,18 +258,18 @@ sub do_getmacs { | ||||
|     my $fsp      = @$d[2]; | ||||
|     my $hcp      = @$d[3]; | ||||
|  | ||||
|     ####################################### | ||||
|     # Find Expect script  | ||||
|     ####################################### | ||||
|     $cmd = ($::XCATROOT) ? "$::XCATROOT/sbin/" : "/opt/xcat/sbin/"; | ||||
|     $cmd .= "lpar_netboot.expect";  | ||||
|  | ||||
|     ####################################### | ||||
|     # Check command installed  | ||||
|     ####################################### | ||||
|     if ( !-x $cmd ) { | ||||
|         return( [RC_ERROR,"Command not installed: $cmd"] ); | ||||
|     } | ||||
|     ######################################## | ||||
|     ## Find Expect script | ||||
|     ######################################## | ||||
|     #$cmd = ($::XCATROOT) ? "$::XCATROOT/sbin/" : "/opt/xcat/sbin/"; | ||||
|     #$cmd .= "lpar_netboot.expect"; | ||||
|     # | ||||
|     ######################################## | ||||
|     ## Check command installed | ||||
|     ######################################## | ||||
|     #if ( !-x $cmd ) { | ||||
|     #    return( [RC_ERROR,"Command not installed: $cmd"] ); | ||||
|     #} | ||||
|     ####################################### | ||||
|     # Save user name and passwd of hcp to  | ||||
|     # environment variables. | ||||
| @@ -279,13 +282,16 @@ sub do_getmacs { | ||||
|     # Turn on verbose and debugging  | ||||
|     ####################################### | ||||
|     if ( exists($request->{verbose}) ) { | ||||
|         $cmd.= " -v -x"; | ||||
|         #$cmd.= " -v -x"; | ||||
|         $optarg{'v'} = 1; #for verbose | ||||
|         $optarg{'x'} = 1; #for debug | ||||
|     } | ||||
|     ####################################### | ||||
|     # Force LPAR shutdown | ||||
|     ####################################### | ||||
|     if ( exists( $opt->{f} )) { | ||||
|         $cmd.= " -i"; | ||||
|         #$cmd.= " -i"; | ||||
|         $optarg{'i'} = 1; | ||||
|     } else { | ||||
|         ################################# | ||||
|         # Force LPAR shutdown if LPAR is | ||||
| @@ -301,7 +307,8 @@ sub do_getmacs { | ||||
|                 my $osname = "AIX"; | ||||
|                 if ( grep(/^$node$/, @nodelist) ) { | ||||
|                     if ( !grep(/^$osname$/, @oslist) ) { | ||||
|                         $cmd.= " -i"; | ||||
|                         #$cmd.= " -i"; | ||||
|                         $optarg{'i'} = 1; | ||||
|                     } | ||||
|                     $intable = 1; | ||||
|                     last; | ||||
| @@ -314,15 +321,18 @@ sub do_getmacs { | ||||
|         # but mnt node is running Linux | ||||
|         ################################# | ||||
|         if ( xCAT::Utils->isLinux() && $intable == 0 ) { | ||||
|             $cmd.= " -i"; | ||||
|                #$cmd.= " -i"; | ||||
|                $optarg{'i'} = 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     my %client_nethash = xCAT::DBobjUtils->getNetwkInfo( [$node] ); | ||||
|     if ( grep /hf/, $client_nethash{$node}{mgtifname} ) { | ||||
|         $cmd.= " -t hfi-ent"; | ||||
|         #$cmd.= " -t hfi-ent"; | ||||
|         $optarg{'t'} = "hfi-ent"; | ||||
|     } else { | ||||
|         $cmd.= " -t ent"; | ||||
|         #$cmd.= " -t ent"; | ||||
|         $optarg{'t'} = "ent"; | ||||
|     } | ||||
|  | ||||
|     ####################################### | ||||
| @@ -330,46 +340,61 @@ sub do_getmacs { | ||||
|     ####################################### | ||||
|     if ( exists( $opt->{S} )) { | ||||
|         if ( exists( $opt->{o} )) { | ||||
|             $cmd .=" -o"; | ||||
|             #$cmd .=" -o"; | ||||
|            $optarg{'o'} = 1; | ||||
|         } | ||||
|         $cmd.= " -D -s auto -d auto -S $opt->{S} -G $opt->{G} -C $opt->{C}"; | ||||
|         #$cmd.= " -D -s auto -d auto -S $opt->{S} -G $opt->{G} -C $opt->{C}"; | ||||
|         $optarg{'D'} = 1; | ||||
|         $optarg{'s'} = 'auto'; | ||||
|         $optarg{'d'} = 'auto'; | ||||
|         $optarg{'S'} = $opt->{S}; | ||||
|         $optarg{'C'} = $opt->{C}; | ||||
|         $optarg{'G'} = $opt->{G}; | ||||
|     }  | ||||
|     ####################################### | ||||
|     # Add command options  | ||||
|     ####################################### | ||||
|     $cmd.= " -f -M -A -n \"$name\" \"$pprofile\" \"$fsp\" $id $hcp \"$node\""; | ||||
|     #$cmd.= " -f -M -A -n \"$name\" \"$pprofile\" \"$fsp\" $id $hcp \"$node\""; | ||||
|     $optarg{'f'} = 1; | ||||
|     $optarg{'M'} = 1; | ||||
|     $optarg{'A'} = 1; | ||||
|     $optarg{'n'} = $name; | ||||
|     $optarg{'pprofile'} = $pprofile; | ||||
|     $optarg{'fsp'} = $fsp; | ||||
|     $optarg{'id'} = $id; | ||||
|     $optarg{'hcp'} = $hcp; | ||||
|     $optarg{'node'} = $node; | ||||
|  | ||||
|     ####################################### | ||||
|     # Execute command  | ||||
|     ####################################### | ||||
|     my $pid = open( OUTPUT, "$cmd 2>&1 |"); | ||||
|     $SIG{INT} = $SIG{TERM} = sub { #prepare to process job termination and propogate it down | ||||
|         kill 9, $pid; | ||||
|         return( [RC_ERROR,"Received INT or TERM signal"] ); | ||||
|     }; | ||||
|     if ( !$pid ) { | ||||
|         return( [RC_ERROR,"$cmd fork error: $!"] ); | ||||
|     } | ||||
|  | ||||
|     ####################################### | ||||
|     # Get command output  | ||||
|     ####################################### | ||||
|     while ( <OUTPUT> ) { | ||||
|         $result.=$_; | ||||
|     } | ||||
|     close OUTPUT; | ||||
|  | ||||
|     ####################################### | ||||
|     # Get command exit code | ||||
|     ####################################### | ||||
|     my $Rc = SUCCESS; | ||||
|  | ||||
|     foreach ( split /\n/, $result ) { | ||||
|         if ( /^lpar_netboot / ) { | ||||
|             $Rc = RC_ERROR; | ||||
|             last; | ||||
|         } | ||||
|     } | ||||
|             ######################################## | ||||
|             ## Execute command | ||||
|             ######################################## | ||||
|             #my $pid = open( OUTPUT, "$cmd 2>&1 |"); | ||||
|             #$SIG{INT} = $SIG{TERM} = sub { #prepare to process job termination and propogate it down | ||||
|             #    kill 9, $pid; | ||||
|             #    return( [RC_ERROR,"Received INT or TERM signal"] ); | ||||
|             #}; | ||||
|             #if ( !$pid ) { | ||||
|             #    return( [RC_ERROR,"$cmd fork error: $!"] ); | ||||
|             #} | ||||
|             ######################################## | ||||
|             ## Get command output | ||||
|             ######################################## | ||||
|             #while ( <OUTPUT> ) { | ||||
|             #    $result.=$_; | ||||
|             #} | ||||
|             #close OUTPUT; | ||||
|             # | ||||
|             ######################################## | ||||
|             ## Get command exit code | ||||
|             ######################################## | ||||
|             # | ||||
|             #foreach ( split /\n/, $result ) { | ||||
|             #    if ( /^lpar_netboot / ) { | ||||
|             #        $Rc = RC_ERROR; | ||||
|             #        last; | ||||
|             #    } | ||||
|             #} | ||||
|             my $Rc = xCAT::LparNetbootExp->lparnetbootexp(\%optarg, $request); | ||||
|     ###################################### | ||||
|     # Split results into array | ||||
|     ###################################### | ||||
|   | ||||
		Reference in New Issue
	
	Block a user