mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-10-25 00:15:43 +00:00 
			
		
		
		
	fix bug 4126:vios:mkvm failedo
This commit is contained in:
		| @@ -206,8 +206,9 @@ sub chvm_parse_args { | ||||
|     # Process command-line arguments | ||||
|     ############################################# | ||||
|     if ( !defined( $args )) { | ||||
|         $request->{method} = $cmd; | ||||
|         return( \%opt ); | ||||
|         #$request->{method} = $cmd; | ||||
|         #return( \%opt ); | ||||
|         return ( usage() ); | ||||
|     } | ||||
|     ############################################# | ||||
|     # Checks case in GetOptions, allows opts | ||||
| @@ -863,6 +864,10 @@ sub do_op_extra_cmds { | ||||
|                     my @td = @$d; | ||||
|                     @td[0] = 0; | ||||
|                     $memhash = &query_cec_info_actions($request, $name, \@td, 1, ["part_get_hyp_process_and_mem"]); | ||||
|                     unless (scalar keys(%$memhash)) { | ||||
|                         push @values, [$mtms, "Can not get hypervisor information", 1]; | ||||
|                         next; | ||||
|                     } | ||||
|                     if (!exists($memhash->{run})) { | ||||
|                         if ($param =~ /(\d+)([G|M]?)\/(\d+)([G|M]?)\/(\d+)([G|M]?)/i) { | ||||
|                             my $memsize = $memhash->{mem_region_size}; | ||||
| @@ -921,10 +926,16 @@ sub do_op_extra_cmds { | ||||
|                     push @values, [$name, "Success", '0']; | ||||
|                 }  | ||||
|             } | ||||
|             my $rethash = query_cec_info_actions($request, $name, $d, 1, \@query_array); | ||||
|             # need to add update db here  | ||||
|             $lpar_hash{$name} = $rethash;      | ||||
|             $lpar_hash{$name}->{parent} = @$d[3]; | ||||
|             if (@query_array) { | ||||
|                 my $rethash = query_cec_info_actions($request, $name, $d, 1, \@query_array); | ||||
|                 unless (scalar keys(%$memhash)) { | ||||
|                     push @values, [$mtms, "Can not get hypervisor information", 1]; | ||||
|                     next; | ||||
|                 } | ||||
|                 # need to add update db here  | ||||
|                 $lpar_hash{$name} = $rethash;      | ||||
|                 $lpar_hash{$name}->{parent} = @$d[3]; | ||||
|             } | ||||
|         } | ||||
|     }  | ||||
|     if (%lpar_hash) { | ||||
| @@ -2264,7 +2275,7 @@ sub mkspeclpar { | ||||
|         return([["Error","Cannot open vm table", 1]]); | ||||
|     } | ||||
|     while (my ($mtms, $h) = each (%$hash)) { | ||||
|         my $memhash; | ||||
|         my $memhash = undef; | ||||
|         my @nodes = keys(%$h); | ||||
|         my $ent = $vmtab->getNodesAttribs(\@nodes, ['cpus', 'memory','physlots', 'othersettings', 'storage', 'nics']);  | ||||
|         while (my ($name, $d) = each (%$h)) { | ||||
| @@ -2273,12 +2284,17 @@ sub mkspeclpar { | ||||
|                 last; | ||||
|             } | ||||
|             #if (!exists($memhash->{run}))  | ||||
|             { | ||||
|             #{ | ||||
|                 my @td = @$d; | ||||
|                 @td[0] = 0; | ||||
|                 $memhash = &query_cec_info_actions($request, $name, \@td, 1, ["part_get_hyp_process_and_mem","lpar_lhea_mac","part_get_all_io_bus_info"]); | ||||
|                 unless (scalar keys(%$memhash)) { | ||||
|                     push @result, [$mtms, "Can not get hypervisor information", 1]; | ||||
|                     last; | ||||
|                 } | ||||
|                 #$memhash->{run} = 1;  | ||||
|             } | ||||
|             #} | ||||
|              | ||||
|             my $tmp_ent = $ent->{$name}->[0]; | ||||
|             if (exists($opt->{vmcpus})) { | ||||
|                 $tmp_ent->{cpus} = $opt->{vmcpus}; | ||||
| @@ -2439,6 +2455,10 @@ sub mkspeclpar { | ||||
|             push @result, @$values; | ||||
|             #need to add update db here | ||||
|             my $rethash = query_cec_info_actions($request, $name, $d, 1, ["part_get_lpar_processing","part_get_lpar_memory","part_get_all_vio_info","part_get_all_io_bus_info","get_huge_page","get_cec_bsr"]); | ||||
|             unless (scalar keys(%$rethash)) { | ||||
|                 push @result, [$mtms, "Can not get hypervisor information", 1]; | ||||
|                 next; | ||||
|             } | ||||
|             $lpar_hash{$name} = $rethash;      | ||||
|             $lpar_hash{$name}->{parent} = @$d[3]; | ||||
|  | ||||
| @@ -2468,8 +2488,9 @@ sub mkfulllpar { | ||||
|                 my @td = @$d; | ||||
|                 @td[0] = 0; | ||||
|                 $rethash = query_cec_info_actions($request, $name, \@td, 1);  | ||||
|                 if (ref($rethash) ne 'HASH') { | ||||
|                     return ([[$mtms, "Cann't get hypervisor info hash", 1]]); | ||||
|                 unless (scalar keys(%$rethash)) { | ||||
|                     push @result, [$mtms, "Can not get hypervisor information", 1]; | ||||
|                     next; | ||||
|                 } | ||||
|                 $rethash->{run} = 1;  | ||||
|                 #print Dumper($rethash); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user