From e700e1a6fb8273dbd02b2301344e933445daf6bf Mon Sep 17 00:00:00 2001 From: linggao Date: Wed, 22 Sep 2010 15:21:16 +0000 Subject: [PATCH] made the nodeset work with old images, backward compaitible git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@7579 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT-server/lib/xcat/plugins/anaconda.pm | 38 +++++++++++++++---- xCAT-server/lib/xcat/plugins/sles.pm | 48 ++++++++++++++++++------ 2 files changed, 68 insertions(+), 18 deletions(-) diff --git a/xCAT-server/lib/xcat/plugins/anaconda.pm b/xCAT-server/lib/xcat/plugins/anaconda.pm index c424284fa..367459c70 100644 --- a/xCAT-server/lib/xcat/plugins/anaconda.pm +++ b/xCAT-server/lib/xcat/plugins/anaconda.pm @@ -310,22 +310,46 @@ sub mknetboot $suffix = 'sfs' if (-r "$rootimgdir/rootimg.sfs"); # statelite images are not packed. if ($statelite) { - unless ( -r "$rootimgdir/kernel" and -r "$rootimgdir/initrd-statelite.gz" ) { + unless ( -r "$rootimgdir/kernel") { $callback->({ - error=>[qq{Did you run "genimage" before running "liteimg"? kernel or initial ramdisk cannot be found...}], + error=>[qq{Did you run "genimage" before running "liteimg"? kernel cannot be found...}], errorcode=>[1] }); next; } + if (!-r "$rootimgdir/initrd-statelite.gz") { + if (! -r "$rootimgdir/initrd.gz") { + $callback->({ + error=>[qq{Did you run "genimage" before running "liteimg"? initrd.gz or initrd-statelite.gz cannot be found}], + errorcode=>[1] + }); + next; + } + else { + copy("$rootimgdir/initrd.gz", "$rootimgdir/initrd-statelite.gz"); + } + } } else { - unless ( -r "$rootimgdir/kernel" and -r "$rootimgdir/initrd-stateless.gz" ) { + unless ( -r "$rootimgdir/kernel") { $callback->({ - error => [qq{Did you run "genimage" before running "packimage"? kernel or initial ramdisk cannot be found...}], - errorcode => [1] - }); + error=>[qq{Did you run "genimage" before running "packimage"? kernel cannot be found}], + errorcode=>[1] + }); next; + } + if (!-r "$rootimgdir/initrd-stateless.gz") { + if (! -r "$rootimgdir/initrd.gz") { + $callback->({ + error=>[qq{Did you run "genimage" before running "packimage"? initrd.gz or initrd-stateless.gz cannot be found}], + errorcode=>[1] + }); + next; + } + else { + copy("$rootimgdir/initrd.gz", "$rootimgdir/initrd-stateless.gz"); + } } - unless ( -r "$rootimgdir/rootimg.gz" or -r "$rootimgdir/rootimg.sfs" ) { + unless ( -r "$rootimgdir/rootimg.gz" or -r "$rootimgdir/rootimg.sfs" ) { $callback->({ error=>["No packed image for platform $osver, architecture $arch, and profile $profile, please run packimage (i.e. packimage -o $osver -p $profile -a $arch"], errorcode => [1]}); diff --git a/xCAT-server/lib/xcat/plugins/sles.pm b/xCAT-server/lib/xcat/plugins/sles.pm index f297717e3..e3ea969a9 100644 --- a/xCAT-server/lib/xcat/plugins/sles.pm +++ b/xCAT-server/lib/xcat/plugins/sles.pm @@ -180,22 +180,48 @@ sub mknetboot #statelite images are not packed if ($statelite) { - unless ( -r "$rootimgdir/kernel" and -r "$rootimgdir/initrd-statelite.gz") { + unless ( -r "$rootimgdir/kernel") { $callback->({ - error=>[qq{Did you run "genimage" before running "liteimg"? kernel or initrd-statelite.gz cannot be found}], + error=>[qq{Did you run "genimage" before running "liteimg"? kernel cannot be found}], errorcode => [1] }); next; - } - } else { - unless ( -r "$rootimgdir/kernel" and -r "$rootimgdir/initrd-stateless.gz" ) { - $callback->({ - error=>[qq{Did you run "genimage" before running "packimage"? kernel or initrd-stateless.gz cannot be found}], - errorcode=>[1] - }); - next; - } + } + if (!-r "$rootimgdir/initrd-statelite.gz") { + if (! -r "$rootimgdir/initrd.gz") { + $callback->({ + error=>[qq{Did you run "genimage" before running "liteimg"? initrd.gz or initrd-statelite.gz cannot be found}], + errorcode=>[1] + }); + next; + } + else { + copy("$rootimgdir/initrd.gz", "$rootimgdir/initrd-statelite.gz"); + } + } + + } else { + unless ( -r "$rootimgdir/kernel") { + $callback->({ + error=>[qq{Did you run "genimage" before running "packimage"? kernel cannot be found}], + errorcode=>[1] + }); + next; + } + if (!-r "$rootimgdir/initrd-stateless.gz") { + if (! -r "$rootimgdir/initrd.gz") { + $callback->({ + error=>[qq{Did you run "genimage" before running "packimage"? initrd.gz or initrd-stateless.gz cannot be found}], + errorcode=>[1] + }); + next; + } + else { + copy("$rootimgdir/initrd.gz", "$rootimgdir/initrd-stateless.gz"); + } + } + unless ( -r "$rootimgdir/rootimg.gz" or -r "$rootimgdir/rootimg.sfs" ) { $callback->({ error=>[qq{No packed image for platform $osver, architecture $arch, and profile $profile, please run packimage before nodeset}],