summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuillaume Cottenceau <gc@mandriva.com>2002-02-27 13:31:30 +0000
committerGuillaume Cottenceau <gc@mandriva.com>2002-02-27 13:31:30 +0000
commit4ad56d5017b21fa3f3aa1052dc308c23afe4dca0 (patch)
tree8e61defbff756a4a61e66888b616b370014782f6
parenta6682583fc15396f9e1464b6c59acc6db4d32442 (diff)
downloaddrakx-backup-do-not-use-4ad56d5017b21fa3f3aa1052dc308c23afe4dca0.tar
drakx-backup-do-not-use-4ad56d5017b21fa3f3aa1052dc308c23afe4dca0.tar.gz
drakx-backup-do-not-use-4ad56d5017b21fa3f3aa1052dc308c23afe4dca0.tar.bz2
drakx-backup-do-not-use-4ad56d5017b21fa3f3aa1052dc308c23afe4dca0.tar.xz
drakx-backup-do-not-use-4ad56d5017b21fa3f3aa1052dc308c23afe4dca0.zip
add "restore Windows Boot Loader" to rescue
-rw-r--r--mdk-stage1/rescue-gui.c15
-rw-r--r--rescue/list.i3861
-rwxr-xr-xrescue/make_rescue_img3
-rwxr-xr-xrescue/restore_ms_boot108
4 files changed, 125 insertions, 2 deletions
diff --git a/mdk-stage1/rescue-gui.c b/mdk-stage1/rescue-gui.c
index 055c680a3..dd4b9a0df 100644
--- a/mdk-stage1/rescue-gui.c
+++ b/mdk-stage1/rescue-gui.c
@@ -141,13 +141,19 @@ int main(int argc, char **argv)
enum return_type results;
char install_bootloader[] = "Re-install Boot Loader";
+#ifdef __i386__
+ char restore_ms_boot[] = "Restore Windows Boot Loader";
+#endif
char mount_parts[] = "Mount your partitions under /mnt";
char go_to_console[] = "Go to console";
char reboot_[] = "Reboot";
char doc[] = "Doc: what's addressed by this Rescue?";
-
- char * actions[] = { install_bootloader, mount_parts, go_to_console, reboot_, doc, NULL };
+ char * actions[] = { install_bootloader,
+#ifdef __i386__
+ restore_ms_boot,
+#endif
+ mount_parts, go_to_console, reboot_, doc, NULL };
char * choice;
init_frontend("Welcome to " DISTRIB_NAME " Rescue (" VERSION ") " __DATE__ " " __TIME__);
@@ -162,6 +168,11 @@ int main(int argc, char **argv)
if (ptr_begins_static_str(choice, install_bootloader)) {
binary = "/usr/bin/install_bootloader";
}
+#ifdef __i386__
+ if (ptr_begins_static_str(choice, restore_ms_boot)) {
+ binary = "/usr/bin/restore_ms_boot";
+ }
+#endif
if (ptr_begins_static_str(choice, mount_parts)) {
binary = "/usr/bin/guessmounts";
}
diff --git a/rescue/list.i386 b/rescue/list.i386
index 2013900bf..a3b1493c2 100644
--- a/rescue/list.i386
+++ b/rescue/list.i386
@@ -10,3 +10,4 @@
/boot/grub/stage[12]
/usr/lib/perl5/PERL_VERSION/i386-linux/CORE/libperl.so
/usr/lib/perl5/site_perl/PERL_VERSION/i386-linux/packdrake.pm
+/usr/lib/extipl/aldebaran.bin
diff --git a/rescue/make_rescue_img b/rescue/make_rescue_img
index fa1a23591..30096a91b 100755
--- a/rescue/make_rescue_img
+++ b/rescue/make_rescue_img
@@ -87,6 +87,9 @@ _ "cp ../all.modules/$main/modules.dep $tmp/modules";
installown("drvinst", "/usr/bin");
installown("guessmounts", "/usr/bin");
installown("install_bootloader", "/usr/bin");
+if ($arch =~ /^i.86/) {
+ installown("restore_ms_boot", "/usr/bin");
+}
installown("lsparts", "/usr/bin");
installown("rescue-doc", "/usr/bin");
_ "cd ../mdk-stage1 && make rescue-gui";
diff --git a/rescue/restore_ms_boot b/rescue/restore_ms_boot
new file mode 100755
index 000000000..0d674af99
--- /dev/null
+++ b/rescue/restore_ms_boot
@@ -0,0 +1,108 @@
+#!/usr/bin/perl
+#
+# Guillaume Cottenceau (gc@mandrakesoft.com)
+#
+# Copyright 2002 MandrakeSoft
+#
+# This software may be freely redistributed under the terms of the GNU
+# public license.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+#
+
+sub arch() {
+ my $t = `uname -m`;
+ chomp $t;
+ $t;
+}
+sub if_($@) {
+ my $b = shift;
+ $b or return ();
+ wantarray || @_ <= 1 or die("if_ called in scalar context with more than one argument " . join(":", caller()));
+ wantarray ? @_ : $_[0];
+}
+sub cat_ { local *F; open F, $_[0] or $_[1] ? die "cat of file $_[0] failed: $!\n" : return; my @l = <F>; wantarray ? @l : join '', @l }
+sub member { my $e = shift; foreach (@_) { $e eq $_ and return 1 } 0 }
+
+@known_boot_loaders = qw(lilo grub yaboot);
+
+# keep this in sync with DrakX
+@MBR_signatures = (
+ [ 'empty', 0, "\0\0\0\0" ],
+ [ 'grub', 0x6, "GRUB" ],
+ [ 'grub', 0, "\xEBG", 0x17d, "stage1 \0" ],
+ [ 'grub', 0, "\xEBH", 0x17e, "stage1 \0" ],
+ [ 'grub', 0, "\xEBH", 0x18a, "stage1 \0" ],
+ [ 'grub', 0, "\xEBH", 0x181, "GRUB \0" ],
+ [ 'lilo', 0x2, "LILO" ],
+ [ 'lilo', 0x6, "LILO" ],
+if_(arch() =~ /ppc/,
+ map { [ 'yaboot', 0, "PM", 0x200 * $_ + 0x10, "bootstrap\0" ] } 0 .. 61
+),
+);
+
+sub typeFromMagic {
+ my $f = shift;
+ local *F; sysopen F, $f, 0 or return;
+
+ my $tmp;
+ M: foreach (@MBR_signatures) {
+ my ($name, @l) = @$_;
+ while (@l) {
+ my ($offset, $signature) = splice(@l, 0, 2);
+ sysseek(F, $offset, 0) or next M;
+ sysread(F, $tmp, length $signature);
+ $tmp eq $signature or next M;
+ }
+ return $name;
+ }
+ return 0;
+}
+
+
+my (undef, undef, @parts) = cat_('/proc/partitions');
+
+my @possibilities;
+
+P: foreach (@parts) {
+ my (undef, undef, $blocks, $dev) = split or next;
+ next if $blocks <= 1;
+ my $type = typeFromMagic("/dev/$dev");
+ $type && member($type, @known_boot_loaders) and push @possibilities, [ $dev, $type ];
+}
+
+my $choice;
+
+if (!@possibilities) {
+ print "No known Linux bootloader has been found, nothing to do.\n";
+} elsif (@possibilities == 1) {
+ print "I've found a Linux bootloader only on </dev/$possibilities[0]->[0]>.\n\n";
+ $choice = $possibilities[0];
+} else {
+ print "I've found the following Linux bootloaders:\n";
+ my $i;
+ print "\t", ++$i, ": <$_->[1]> \ton <$_->[0]>\n" foreach @possibilities;
+ print "\n";
+ print "Which disk/partition do you want to overwrite with the Windows bootloader?\n";
+ print "\t<enter the number or press 'n' and Enter to cancel> ";
+ <STDIN> !~ /^(\d+)$/i && $1 >= 1 and $choice = $possibilities[$1-1];
+}
+
+if ($choice) {
+ print "I'm going to overwrite bootloader on </dev/$choice->[0]> with
+Windows bootloader.
+
+Ok? <press Enter to continue, 'n' and Enter to cancel> ";
+ <STDIN> =~ /^n/i and exit 0;
+
+ system("/bin/dd if=/usr/lib/extipl/aldebaran.bin of=/dev/$choice->[0]\n") and print "\tFailed!\n";
+}
+
+#-------------------------------------------------
+#- $Log$
+#- Revision 1.1 2002/02/27 13:31:30 gc
+#- add "restore Windows Boot Loader" to rescue
+#-
+#-