From 55558a4367a3c7dc36211c426d5becf08a967c6a Mon Sep 17 00:00:00 2001 From: Olivier Blin Date: Tue, 29 Nov 2005 17:27:23 +0000 Subject: don't die if non-mandatory modules are missing, warn and skip them --- tools/draklive | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/tools/draklive b/tools/draklive index 7ddc394e8..ea285ed56 100755 --- a/tools/draklive +++ b/tools/draklive @@ -252,19 +252,25 @@ sub create_initrd { (map { $_, $_ . '1' } map { "sd$_" } ('a' .. 'h')); load_moddeps($live->{system}{root}, "/lib/modules/" . $live->{system}{kernel}); - my ($modules, $unknown) = partition { exists $moddeps{$_} } - uniq(map { modules::cond_mapping_24_26($_) } category2modules($storage_modules{$live->{media}{storage}})), + + my ($modules, $skipped) = partition { exists $moddeps{$_} } + uniq(map { modules::cond_mapping_24_26($_) } category2modules($storage_modules{$live->{media}{storage}})); + my ($extra_modules, $missing) = partition { exists $moddeps{$_} } nls_modules($live), $live->{media}{fs}, @{$live->{media}{modules} || []}, (map { @{$loop{$_}{modules} || []} } uniq(map { $_->{type} } grep { $_->{type} } @{$live->{mount}{dirs} || []})), ($live->{mount}{overlay} ? @{$overlay{$live->{mount}{overlay}}{modules} || []} : ()); - @$unknown and die "unknown modules:" . join("\n", '', @$unknown); + + @$missing and die "missing mandatory modules:" . join("\n", '', sort(@$missing)); + push @$modules, @$extra_modules; my @module_deps = uniq(map { moddeps_closure($_) } @$modules); run_('gzip', '>', $live->{initrd_tree} . "/lib/$_.ko", '-dc', $live->{system}{root} . $moddeps{$_}{full}) foreach @module_deps, @$modules; + @$skipped and warn "skipped modules:" . join("\n", '', sort(@$skipped)); + create_initrd_linuxrc($live, @module_deps, @$modules); compress_initrd_tree($live); add_splash($live); -- cgit v1.2.1