diff options
author | lloyd <[email protected]> | 2006-09-08 03:02:28 +0000 |
---|---|---|
committer | lloyd <[email protected]> | 2006-09-08 03:02:28 +0000 |
commit | 391323a4c9b97156f793fd09ee39c737a9a0cd75 (patch) | |
tree | 3f9197407af0ed5a7d92f65739b9a1bac5e060e9 /configure.pl | |
parent | 770c39fbe0613132e58906dc709190d5e0ec037d (diff) |
Fix a failure that occured if the user specified the OS as generic.
Fix the code that took the user-specified or autodetected CPU name and
turned it into the canonical arch/submodel pair. It did not handle arch
aliases (such as 'x86' or 'axp') correctly.
Diffstat (limited to 'configure.pl')
-rwxr-xr-x | configure.pl | 61 |
1 files changed, 33 insertions, 28 deletions
diff --git a/configure.pl b/configure.pl index 64770eedb..ce1baadcb 100755 --- a/configure.pl +++ b/configure.pl @@ -277,29 +277,22 @@ sub figure_out_arch { return ('generic', 'generic') if($name eq 'generic'); sub submodel_alias { - my ($name) = @_; + my ($name,$info) = @_; - foreach my $arch (keys %CPU) { - next unless defined $CPU{$arch}{'submodel_aliases'}; - my %sm_aliases = %{$CPU{$arch}{'submodel_aliases'}}; + my %info = %{$info}; - foreach my $alias (keys %sm_aliases) { - my $official = $sm_aliases{$alias}; - return $official if($alias eq $name); - } + foreach my $submodel (@{$info{'submodels'}}) { + return $submodel if ($name eq $submodel); } - return $name; - } - sub arch_alias { - my $name = $_[0]; + return '' unless defined $info{'submodel_aliases'}; + my %sm_aliases = %{$info{'submodel_aliases'}}; - foreach my $arch (keys %CPU) { - foreach my $alias (@{$CPU{$arch}{'aliases'}}) { - return $arch if($alias eq $name); - } + foreach my $alias (keys %sm_aliases) { + my $official = $sm_aliases{$alias}; + return $official if($alias eq $name); } - return undef; + return ''; } sub find_arch { @@ -310,29 +303,37 @@ sub figure_out_arch { return $arch if ($name eq $arch); + foreach my $alias (@{$info{'aliases'}}) { + return $arch if ($name eq $alias); + } + foreach my $submodel (@{$info{'submodels'}}) { return $arch if ($name eq $submodel); } + + foreach my $submodel (keys %{$info{'submodel_aliases'}}) { + return $arch if ($name eq $submodel); + } } + return undef; } - my $submodel = submodel_alias($name); - my $arch = arch_alias($name); + my $arch = find_arch($name); + error("Arch type $name isn't known") unless defined $arch; - if(not defined($arch) and $submodel ne '') { - $arch = find_arch($submodel); - } + my %archinfo = %{ $CPU{$arch} }; - error("Arch $name isn't known") unless defined $arch; + my $submodel = submodel_alias($name, \%archinfo); - if($submodel eq $arch) { - $submodel = $CPU{$arch}{'default_submodel'}; + if($submodel eq '') { + $submodel = $archinfo{'default_submodel'}; warning("Using $submodel as default type for family ", realname($arch)) if($submodel ne $arch); } - die unless defined($arch) and defined($submodel); + error("Couldn't figure out arch type of $name") + unless defined($arch) and defined($submodel); return ($arch,$submodel); } @@ -744,9 +745,13 @@ sub os_info_for { die "Internal error: os_info_for called with an os of defaults\n" if($os eq 'defaults'); - my %osinfo = %{$OPERATING_SYSTEM{$os}}; + my $result = ''; + + if(defined($OPERATING_SYSTEM{$os})) { + my %osinfo = %{$OPERATING_SYSTEM{$os}}; + $result = $osinfo{$what}; + } - my $result = $osinfo{$what}; if(!defined($result) or $result eq '') { #print "Using defaults for $what\n"; $result = $OPERATING_SYSTEM{'defaults'}{$what}; |