diff options
author | Pascal Rigaux <pixel@mandriva.com> | 1999-08-25 12:12:01 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 1999-08-25 12:12:01 +0000 |
commit | 127f35b9f583ba378b8507c5e8011182be4323f0 (patch) | |
tree | 199426c374956c97c409530c50a1c0a0d6262fab /make_boot_img | |
parent | 94e662940cfa660168652ea996071a175012a1eb (diff) | |
download | drakx-127f35b9f583ba378b8507c5e8011182be4323f0.tar drakx-127f35b9f583ba378b8507c5e8011182be4323f0.tar.gz drakx-127f35b9f583ba378b8507c5e8011182be4323f0.tar.bz2 drakx-127f35b9f583ba378b8507c5e8011182be4323f0.tar.xz drakx-127f35b9f583ba378b8507c5e8011182be4323f0.zip |
no_comment
Diffstat (limited to 'make_boot_img')
-rwxr-xr-x | make_boot_img | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/make_boot_img b/make_boot_img new file mode 100755 index 000000000..e4bea7468 --- /dev/null +++ b/make_boot_img @@ -0,0 +1,76 @@ +#!/usr/bin/perl + +@ARGV >= 2 or die "usage: $0 <image> cdrom|hd|network|network_ks\n"; + +($img, $type) = @ARGV; + +$ks = "kickstart=floppy" if $type =~ s/_ks//; +$mnt = "/mnt/disk"; +if ($>) { + $sudo = "sudo"; + $ENV{PATH} = "/sbin:/usr/sbin:$ENV{PATH}"; +} + + +$install = $ {{ + network => "install", + cdrom => "local-install", + hd => "local-install" +}}{$type} or die; + +$0 =~ /initrd/ ? + initrd($mnt, $img) : + boot_img($mnt, $img); + +sub __ { print @_, "\n"; system(@_); } +sub _ { __ @_; $? and die; } + + +sub initrd { + my ($mnt, $img) = @_; + my $tmp = "$ENV{HOME}/tmp/initrd"; + + _ "install -s install/installinit/init install/install1/sbin/init"; + _ "install -s install/$install install/install1/sbin/install"; + + __ "$sudo umount $tmp $mnt 2>/dev/null"; + _ "dd if=/dev/zero of=$tmp bs=1k count=2000"; + _ "echo y | mke2fs $tmp"; + _ "$sudo mount $tmp $mnt -o loop"; + _ "$sudo cp -a install/install1/* $mnt"; + _ "$sudo install -d $mnt/modules"; + _ "$sudo cp -f modules/${type}_modules.cgz $mnt/modules/modules.cgz"; + _ "$sudo cp -f modules/modules.dep $mnt/modules/"; + _ "$sudo umount $mnt"; + _ "gzip -9 -c $tmp > $img"; + _ "rm -f $tmp"; +} + +sub boot_img { + my ($mnt, $img) = @_; + + __ "$sudo umount $mnt 2>/dev/null"; + _ "bunzip2 -c install/installinit/emptyboot.img.bz2 > $img"; + _ "$sudo mount -o umask=0 $img $mnt -o loop"; + _ "cat vmlinuz > $mnt/vmlinuz"; + initrd("${mnt}2", "$mnt/initrd.gz"); + + output("$mnt/syslinux.cfg", " +default linux +prompt 0 +label linux + kernel vmlinuz + append $ks initrd=initrd.gz mdkinst $type +"); + _ "cp -f install/installinit/ks.cfg $mnt 2>/dev/null" if $ks; + _ "sync"; +} + + + +sub output { + my $f = shift; + local *F; + open F, "> $f" or die "error writing to $f"; + print F join '', @_; +} |