diff options
author | Bob Gilligan <gilligan@vyatta.com> | 2011-07-17 16:43:58 -0700 |
---|---|---|
committer | Bob Gilligan <gilligan@vyatta.com> | 2011-07-17 16:43:58 -0700 |
commit | 73f59d26f6e1c2ed0af24964fb9ad04706d97aa6 (patch) | |
tree | 256e125e8fb53dc81549fc0d0e41bde2d3ad83a6 /scripts | |
parent | 995bcdd1c7027a5b235df224e10e8da0859764bb (diff) | |
download | vyatta-op-73f59d26f6e1c2ed0af24964fb9ad04706d97aa6.tar.gz vyatta-op-73f59d26f6e1c2ed0af24964fb9ad04706d97aa6.zip |
Bugfix 6800: Allow non-vyatta menu entries in grub.cfg.
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/vyatta-boot-image.pl | 125 |
1 files changed, 70 insertions, 55 deletions
diff --git a/scripts/vyatta-boot-image.pl b/scripts/vyatta-boot-image.pl index 367f4b4..91d3f0b 100755 --- a/scripts/vyatta-boot-image.pl +++ b/scripts/vyatta-boot-image.pl @@ -50,61 +50,72 @@ my $grub_cfg; # Pathname of grub config file we will use. # whether the entry is a "lost password reset" boot menu item. # sub parseGrubCfg { - my $fd = undef; - return undef if (!open($fd, '<', $grub_cfg)); - - my %ghash = (); - my @entries = (); - my $in_entry = 0; - my $idx = 0; - my $running_boot_cmd=`cat /proc/cmdline`; - $running_boot_cmd =~ s/BOOT_IMAGE=//; - while (<$fd>) { - if ($in_entry) { - if (/^}/) { - $in_entry = 0; - ++$idx; - } elsif (/^\s+linux /) { - my %ehash = ( - 'idx' => $idx, - 'ver' => undef, - 'term' => undef, - 'reset' => undef - ); - # kernel line - if (/^\s+linux \/boot\/([^\/ ]+)\/.* boot=live /) { - # union install - $ehash{'ver'} = $1; - } else { - # old install - $ehash{'ver'} = $OLD_IMG_VER_STR; - } - if (/console=tty0.*console=ttyS0/) { - $ehash{'term'} = 'serial'; - } else { - $ehash{'term'} = 'kvm'; - } - if (/standalone_root_pw_reset/) { - $ehash{'reset'} = 1; - } else { - $ehash{'reset'} = 0; - } - if (/$running_boot_cmd/) { - $ehash{'running_vers'} = 1; - } else { - $ehash{'running_vers'} = 0; - } - push @entries, \%ehash; - } - } elsif (/^set default=(\d+)$/) { - $ghash{'default'} = $1; - } elsif (/^menuentry /) { - $in_entry = 1; - } - } - close($fd); - $ghash{'entries'} = \@entries; - return \%ghash; + my $fd = undef; + return undef if (!open($fd, '<', $grub_cfg)); + + my %ghash = (); + my @entries = (); + my $in_entry = 0; + my $idx = 0; + my $running_boot_cmd=`cat /proc/cmdline`; + $running_boot_cmd =~ s/BOOT_IMAGE=//; + while (<$fd>) { + if ($in_entry) { + if (/^}/) { + if ($in_entry == 1) { + # Entry did not have linux kernel line + my %ehash = ( + 'idx' => $idx, + 'ver' => undef, + 'term' => undef, + 'reset' => undef + ); + push @entries, \%ehash; + } + $in_entry = 0; + ++$idx; + } elsif (/^\s+linux /) { + my %ehash = ( + 'idx' => $idx, + 'ver' => undef, + 'term' => undef, + 'reset' => undef + ); + # kernel line + if (/^\s+linux \/boot\/([^\/ ]+)\/.* boot=live /) { + # union install + $ehash{'ver'} = $1; + } else { + # old install + $ehash{'ver'} = $OLD_IMG_VER_STR; + } + if (/console=tty0.*console=ttyS0/) { + $ehash{'term'} = 'serial'; + } else { + $ehash{'term'} = 'kvm'; + } + if (/standalone_root_pw_reset/) { + $ehash{'reset'} = 1; + } else { + $ehash{'reset'} = 0; + } + if (/$running_boot_cmd/) { + $ehash{'running_vers'} = 1; + } else { + $ehash{'running_vers'} = 0; + } + push @entries, \%ehash; + $in_entry++; + } + } elsif (/^set default=(\d+)$/) { + $ghash{'default'} = $1; + } elsif (/^menuentry /) { + $in_entry = 1; + } + } + close($fd); + $ghash{'entries'} = \@entries; + return \%ghash; } # This function deletes the entries for the specified version from the grub @@ -175,6 +186,7 @@ sub getBootList { my @list = (); foreach (@{$entries}) { my ($ver, $term) = ($_->{'ver'}, $_->{'term'}); + next if (!defined($ver)); # Skip non-vyatta entry next if ($_->{'reset'}); # skip password reset entry next if ($term ne $dterm); # not the default terminal next if (defined($vhash{$ver})); # version already in list @@ -320,6 +332,9 @@ sub select_by_name { my $entries = $gref->{'entries'}; my $entry; foreach $entry (@{$entries}) { + # Skip non-vyatta entries + next if (!defined($entry->{'ver'})); + # Skip entries that are not using the same term type as before next if ($entry->{'term'} ne $def_term); # Skip the password reset entries |