GD-Graph fuer Maniac eingebaut

Kernel laedt ab jetzt keine Module mehr ungefragt.
Nash aktualisiert um richtige Ramdisks zu erstellen (noch unstable).
pppsetup.cgi vom Maniac eingefuegt.


git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@450 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8
This commit is contained in:
ms
2007-03-18 21:34:35 +00:00
parent c78a77ebeb
commit 330345c282
21 changed files with 2932 additions and 2227 deletions

View File

@@ -1,7 +1,7 @@
#
# Automatically generated make config: don't edit
# Linux kernel version: 2.6.16.42-ipfire
# Fri Mar 16 12:03:27 2007
# Sun Mar 18 16:54:28 2007
#
CONFIG_X86_32=y
CONFIG_SEMAPHORE_SLEEPERS=y
@@ -66,7 +66,7 @@ CONFIG_MODULE_UNLOAD=y
CONFIG_OBSOLETE_MODPARM=y
CONFIG_MODVERSIONS=y
# CONFIG_MODULE_SRCVERSION_ALL is not set
CONFIG_KMOD=y
# CONFIG_KMOD is not set
#
# Block layer

View File

@@ -67,7 +67,7 @@ CONFIG_MODULE_UNLOAD=y
CONFIG_OBSOLETE_MODPARM=y
CONFIG_MODVERSIONS=y
# CONFIG_MODULE_SRCVERSION_ALL is not set
CONFIG_KMOD=y
# CONFIG_KMOD is not set
CONFIG_STOP_MACHINE=y
#

View File

@@ -0,0 +1,27 @@
#usr/lib/perl5/site_perl/5.8.8/GD
#usr/lib/perl5/site_perl/5.8.8/GD/Graph
usr/lib/perl5/site_perl/5.8.8/GD/Graph.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/Data.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/Error.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/FAQ.pod
usr/lib/perl5/site_perl/5.8.8/GD/Graph/area.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/axestype.pm
#usr/lib/perl5/site_perl/5.8.8/GD/Graph/axestype.pm.orig
usr/lib/perl5/site_perl/5.8.8/GD/Graph/bars.pm
#usr/lib/perl5/site_perl/5.8.8/GD/Graph/bars.pm.orig
usr/lib/perl5/site_perl/5.8.8/GD/Graph/colour.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/hbars.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/lines.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/linespoints.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/mixed.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/pie.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/points.pm
usr/lib/perl5/site_perl/5.8.8/GD/Graph/utils.pm
#usr/lib/perl5/site_perl/5.8.8/i586-linux/auto/GD/Graph
#usr/lib/perl5/site_perl/5.8.8/i586-linux/auto/GD/Graph/.packlist
#usr/share/man/man3/GD::Graph.3
#usr/share/man/man3/GD::Graph::Data.3
#usr/share/man/man3/GD::Graph::Error.3
#usr/share/man/man3/GD::Graph::FAQ.3
#usr/share/man/man3/GD::Graph::colour.3
#usr/share/man/man3/GD::Graph::hbars.3

View File

@@ -1,8 +1,8 @@
bin/lsmod
sbin/depmod
#sbin/generate-modprobe.conf
sbin/generate-modprobe.conf
sbin/insmod
#sbin/insmod.static
sbin/insmod.static
sbin/modinfo
sbin/modprobe
sbin/rmmod

View File

@@ -10,6 +10,7 @@
* Digest-HMAC-1.01
* Digest-SHA1-2.10
* GD-2.35
* GDGraph-1.4308
* Geo-IP-PurePerl-1.17
* HTML-Parser-3.45
* HTML-Tagset-3.04

View File

@@ -457,11 +457,10 @@ $checked{'DNS'}{'Manual'} = '';
$checked{'DNS'}{$pppsettings{'DNS'}} = "checked='checked'";
&Header::openpage($Lang::tr{'ppp setup'}, 1, '');
&Header::openbigbox('100%', 'left', '', $errormessage);
if ($errormessage) {
&Header::openbox('100%', 'left', $Lang::tr{'error messages'});
&Header::openbox('100%', 'center', $Lang::tr{'error messages'});
print "<CLASS name='base'>$errormessage\n";
print "&nbsp;</CLASS>\n";
&Header::closebox();
@@ -472,13 +471,13 @@ if ($errormessage) {
### Box for selecting profile
###
print "<form method='post' action='$ENV{'SCRIPT_NAME'}'>\n";
&Header::openbox('100%', 'left', $Lang::tr{'profiles'});
&Header::openbox('100%', 'center', $Lang::tr{'profile'});
print <<END
<table width='100%'>
<table width='95%' cellspacing='0'>
<tr>
<td align='right'>$Lang::tr{'profile'}:</td>
<td>
<select name='PROFILE'>
<td align='left'>$Lang::tr{'profile'}</td>
<td align='left'>
<select name='PROFILE' style="width: 165px">
END
;
for ($c = 1; $c <= $maxprofiles; $c++)
@@ -487,21 +486,25 @@ for ($c = 1; $c <= $maxprofiles; $c++)
}
print <<END
</select></td>
<td><input type='submit' name='ACTION' value='$Lang::tr{'select'}' /></td>
<td><input type='submit' name='ACTION' value='$Lang::tr{'delete'}' /></td>
<td width='30%'><input type='submit' name='ACTION' value='$Lang::tr{'restore'}' /></td>
<td align='left'><input type='submit' name='ACTION' value='$Lang::tr{'select'}' /></td>
<td align='left'><input type='submit' name='ACTION' value='$Lang::tr{'delete'}' /></td>
<td align='left'><input type='submit' name='ACTION' value='$Lang::tr{'restore'}' /></td>
</tr>
</table>
<br></br>
<hr></hr>
END
;
&Header::closebox();
&Header::openbox('100%', 'left', $Lang::tr{'connection'}.':');
&Header::openbox('100%', 'center', $Lang::tr{'connection'});
print <<END
<table width='100%'>
<table width='95%' cellspacing='0'>
<tr>
<td align='right'>$Lang::tr{'interface'}:</td>
<td>
<select name='TYPE'>
<td width='25%'>$Lang::tr{'interface'}:</td>
<td width='25%'>
<select name='TYPE' style="width: 165px">
<option value='modem' $selected{'TYPE'}{'modem'}>$Lang::tr{'modem'}</option>
<option value='serial' $selected{'TYPE'}{'serial'}>$Lang::tr{'serial'}</option>
END
@@ -529,32 +532,29 @@ END
}
print <<END
<option value='fritzdsl' $selected{'TYPE'}{'fritzdsl'}>Fritz!DSL</option>
<option value='pulsardsl' $selected{'TYPE'}{'pulsardsl'}>Pulsar ADSL</option>
<option value='bewanadsl' $selected{'TYPE'}{'bewanadsl'}>Bewan ADSL PCI st/USB st</option>
<option value='conexantpciadsl' $selected{'TYPE'}{'conexantpciadsl'}>Conexant PCI ADSL</option>
</select></td>
<td width='50%'><input type='submit' name='ACTION' value='$Lang::tr{'refresh'}' /></td>
<td colspan='2' width='50%'><input type='submit' name='ACTION' value='$Lang::tr{'refresh'}'></td>
</tr>
<tr>
<td align='right'>USB:</td>
<td colspan='2' width='50%'>USB:</td>
END
;
if (-f "/proc/bus/usb/devices") {
my $usb=`lsmod | cut -d ' ' -f1 | grep -E "hci"`;
if ($usb eq '') {
print "\t<td>$Lang::tr{'not running'}</td></tr>\n";
print "\t<td colspan='2' width='50%'>$Lang::tr{'not running'}</td></tr>\n";
} else {
print "\t<td>$usb</td></tr>\n";
print "\t<td colspan='2' width='50%'>$usb</td></tr>\n";
}
}
if ($pppsettings{'TYPE'}) {
print "</table><table width='100%'>";
print "<tr><td colspan='4' width='100%'><br></br></td></tr>";
if ($pppsettings{'TYPE'} =~ /^(modem|serial|isdn)$/) {
print <<END
<tr>
<td align='right'>$Lang::tr{'interface'}:</td>
<td><select name='COMPORT'>
<td colspan='3' width='75%'>$Lang::tr{'interface'}:</td>
<td width='25%'><select name='COMPORT' style="width: 165px">
END
;
if ($pppsettings{'TYPE'} =~ /^(modem|serial)$/ ) {
@@ -576,13 +576,15 @@ END
<option value='isdn1' $selected{'COMPORT'}{'isdn1'}>$Lang::tr{'isdn1'}</option>
<option value='isdn2' $selected{'COMPORT'}{'isdn2'}>$Lang::tr{'isdn2'}</option>
</select></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(modem|serial)$/ ) {
print <<END
<td align='right'>$Lang::tr{'computer to modem rate'}</td>
<td><select name='DTERATE'>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'computer to modem rate'}</td>
<td width='25%'><select name='DTERATE' style="width: 165px">
<option value='9600' $selected{'DTERATE'}{'9600'}>9600</option>
<option value='19200' $selected{'DTERATE'}{'19200'}>19200</option>
<option value='38400' $selected{'DTERATE'}{'38400'}>38400</option>
@@ -594,30 +596,28 @@ END
</tr>
END
;
} else {
print "<td colspan='2'>&nbsp;</td></tr>\n";
}
}
if ($pppsettings{'TYPE'} =~ /^(modem|isdn)$/ ) {
print "<tr><td align='right'>$Lang::tr{'number'}</td>\n";
print "<td><input type='text' name='TELEPHONE' value='$pppsettings{'TELEPHONE'}' /></td>\n";
print "<tr><td colspan='3' width='75%'>$Lang::tr{'number'}</td>\n";
print "<td width='25%'><input type='text' name='TELEPHONE' value='$pppsettings{'TELEPHONE'}'></td><tr>\n";
if ($pppsettings{'TYPE'} eq 'modem' ) {
print "<td align='right'>$Lang::tr{'modem speaker on'}</td>\n";
print "<td><input type='checkbox' name='SPEAKER' $checked{'SPEAKER'}{'on'} /></td></tr>\n";
} else {
print "<td colspan='2'>&nbsp;</td></tr>\n";
}
print "<tr><td colspan='3' width='75%'>$Lang::tr{'modem speaker on'}</td>\n";
print "<td width='25%'><input type='checkbox' name='SPEAKER' $checked{'SPEAKER'}{'on'} /></td></tr>\n";
}
}
}
if ($pppsettings{'TYPE'} eq 'modem') {
print <<END
<tr>
<td align='right'>$Lang::tr{'dialing mode'}</td>
<td><select name='DIALMODE'>
<td colspan='3' width='75%'>$Lang::tr{'dialing mode'}</td>
<td width='25%'><select name='DIALMODE' style="width: 165px">
<option value='T' $selected{'DIALMODE'}{'T'}>$Lang::tr{'tone'}</option>
<option value='P' $selected{'DIALMODE'}{'P'}>$Lang::tr{'pulse'}</option>
</select></td>
<td align='right'>$Lang::tr{'send cr'}</td>
<td><input type='checkbox' name='SENDCR' $checked{'SENDCR'}{'on'} /></td>
</tr>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'send cr'}</td>
<td width='50%'><input type='checkbox' name='SENDCR' $checked{'SENDCR'}{'on'} /></td>
</tr>
END
;
@@ -625,41 +625,46 @@ END
print <<END
<tr>
<td align='right'>$Lang::tr{'idle timeout'}</td>
<td><input type='text' size='5' name='TIMEOUT' value='$pppsettings{'TIMEOUT'}' /></td>
<td colspan='2'>&nbsp;</td>
<td colspan='3' width='75%'>$Lang::tr{'idle timeout'}</td>
<td width='25%'><input type='text' name='TIMEOUT' value='$pppsettings{'TIMEOUT'}' /></td>
</tr>
END
;
if ( $netsettings{'CONFIG_TYPE'} =~ /^(2|3|6|7)$/ && ( $netsettings{'RED_TYPE'} eq "DHCP" || $netsettings{'RED_TYPE'} eq "STATIC") ) {
$pppsettings{'AUTOCONNECT'} = 'on';
print "<tr><td align='right'>$Lang::tr{'connect on ipfire restart'}</td>\n";
print "<td><input type='checkbox' disabled='disabled' name='AUTOCONNECT' value='on' $checked{'AUTOCONNECT'}{'on'} /></td>\n";
print "<tr><td colspan='3' width='75%'>$Lang::tr{'connect on ipfire restart'}</td>\n";
print "<td width='25%'><input type='checkbox' disabled='disabled' name='AUTOCONNECT' value='on' $checked{'AUTOCONNECT'}{'on'}></td>\n";
} else {
print "<tr><td align='right'>$Lang::tr{'connect on ipfire restart'}</td>\n";
print "<td><input type='checkbox' name='AUTOCONNECT' value='on' $checked{'AUTOCONNECT'}{'on'} /></td>\n";
print "<tr><td colspan='3' width='75%'>$Lang::tr{'connect on ipfire restart'}</td>\n";
print "<td width='25%'><input type='checkbox' name='AUTOCONNECT' value='on' $checked{'AUTOCONNECT'}{'on'}></td>\n";
}
print <<END
<td align='right'>$Lang::tr{'connection debugging'}:</td>
<td><input type='checkbox' name='DEBUG' $checked{'DEBUG'}{'on'} /></td>
</tr>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'connection debugging'}:</td>
<td width='25%'><input type='checkbox' name='DEBUG' $checked{'DEBUG'}{'on'} /></td>
</tr>
<tr>
<td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='4' width='100%' bgcolor='${Header::table1colour}'><b>$Lang::tr{'reconnection'}:</b></td>
</tr>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'reconnection'}:</b></td>
<td colspan='4' width='100%'><input type='radio' name='RECONNECTION' value='manual' $checked{'RECONNECTION'}{'manual'}>$Lang::tr{'manual'}</td>
</tr>
<tr>
<td colspan='4'>
<input type='radio' name='RECONNECTION' value='manual' $checked{'RECONNECTION'}{'manual'} />$Lang::tr{'manual'}</td>
</tr>
<td colspan='4' width='100%'><input type='radio' name='RECONNECTION' value='dialondemand' $checked{'RECONNECTION'}{'dialondemand'}>$Lang::tr{'dod'}</td>
</tr>
END
;
if ($pppsettings{'TYPE'} ne 'isdn') {
print <<END
<tr>
<td>
<input type='radio' name='RECONNECTION' value='persistent' $checked{'RECONNECTION'}{'persistent'} />$Lang::tr{'persistent'}</td>
<td colspan='2' align='right'>$Lang::tr{'backupprofile'}:</td>
<td>
<select name='BACKUPPROFILE'>
<tr>
<td colspan='4' width='100%'><input type='radio' name='RECONNECTION' value='persistent' $checked{'RECONNECTION'}{'persistent'}>$Lang::tr{'persistent'}</td>
</tr>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'backupprofile'}:</td>
<td width='25%'><select name='BACKUPPROFILE' style="width: 165px">
END
;
for ($c = 1; $c <= $maxprofiles; $c++) {
@@ -672,34 +677,34 @@ END
;
}
print <<END
<tr>
<td>
<input type='radio' name='RECONNECTION' value='dialondemand' $checked{'RECONNECTION'}{'dialondemand'} />$Lang::tr{'dod'}</td>
<td colspan='2' align='right'>$Lang::tr{'dod for dns'}</td>
<td><input type='checkbox' name='DIALONDEMANDDNS' $checked{'DIALONDEMANDDNS'}{'on'} /></td>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'dod for dns'}</td>
<td width='25%'><input type='checkbox' name='DIALONDEMANDDNS' $checked{'DIALONDEMANDDNS'}{'on'} /></td>
</tr>
<tr>
<td align='right'>$Lang::tr{'holdoff'}:</td>
<td><input type='text' size='5' name='HOLDOFF' value='$pppsettings{'HOLDOFF'}' /></td>
<td align='right'>$Lang::tr{'maximum retries'}</td>
<td><input type='text' size='5' name='MAXRETRIES' value='$pppsettings{'MAXRETRIES'}' /></td>
<td colspan='3' width='75%'>$Lang::tr{'holdoff'}:</td>
<td width='25%'><input type='text' name='HOLDOFF' value='$pppsettings{'HOLDOFF'}' /></td>
</tr>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'maximum retries'}</td>
<td width='25%'><input type='text' name='MAXRETRIES' value='$pppsettings{'MAXRETRIES'}' /></td>
</tr>
END
;
if ($pppsettings{'TYPE'} eq 'isdn') {
print <<END
</table>
<table width='100%'>
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'isdn settings'}</b></td>
<td colspan='4' width='100%' bgcolor='${Header::table1colour}'><b>$Lang::tr{'isdn settings'}</b></td>
</tr>
<tr>
<td align='right'>$Lang::tr{'use ibod'}</td>
<td><input type='checkbox' name='USEIBOD' $checked{'USEIBOD'}{'on'} /></td>
<td align='right'>$Lang::tr{'use dov'}</td>
<td><input type='checkbox' name='USEDOV' $checked{'USEDOV'}{'on'} /></td>
<td colspan='3' width='75%'>$Lang::tr{'use ibod'}</td>
<td width='25%'><input type='checkbox' name='USEIBOD' $checked{'USEIBOD'}{'on'} /></td>
</tr>
<tr>
<td colspan='3' width='75%'>$Lang::tr{'use dov'}</td>
<td width='25%'><input type='checkbox' name='USEDOV' $checked{'USEDOV'}{'on'} /></td>
</tr>
END
;
@@ -708,29 +713,24 @@ END
if ($pppsettings{'TYPE'} eq 'pptp')
{
print <<END
</table>
<table width='100%'>
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'pptp settings'}</b></td>
<td colspan='4' width='100%' bgcolor='${Header::table1colour}'><b>$Lang::tr{'pptp settings'}</b></td>
</tr>
<tr>
<td colspan='2' align='right'>$Lang::tr{'phonebook entry'}</td>
<td><input type='text' name='PHONEBOOK' value='$pppsettings{'PHONEBOOK'}' /></td>
<td width='25%'>$Lang::tr{'phonebook entry'}</td>
<td colspan='2' width='50%'></td>
<td width='25%'><input type='text' name='PHONEBOOK' value='$pppsettings{'PHONEBOOK'}' /></td>
</tr>
<tr>
<td><input type='radio' name='METHOD' value='STATIC' $checked{'METHOD'}{'STATIC'} />$Lang::tr{'static ip'}</td>
<td align='right'>$Lang::tr{'router ip'}</td>
<td><input type='text' name='ROUTERIP' value='$pppsettings{'ROUTERIP'}' /></td>
<td width='25%'><input type='radio' name='METHOD' value='STATIC' $checked{'METHOD'}{'STATIC'} />$Lang::tr{'static ip'}</td>
<td colspan='2' width='50%'>$Lang::tr{'router ip'}</td>
<td width='25%'><input type='text' name='ROUTERIP' value='$pppsettings{'ROUTERIP'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='3'><hr /></td>
</tr>
<tr>
<td><input type='radio' name='METHOD' value='DHCP' $checked{'METHOD'}{'DHCP'} />$Lang::tr{'dhcp mode'}</td>
<td align='right'>$Lang::tr{'hostname'}:&nbsp;<img src='/blob.gif' alt='*' /></td>
<td><input type='text' name='DHCP_HOSTNAME' value='$pppsettings{'DHCP_HOSTNAME'}' /></td>
<td width='25%'><input type='radio' name='METHOD' value='DHCP' $checked{'METHOD'}{'DHCP'} />$Lang::tr{'dhcp mode'}</td>
<td colspan='2' width='50%'>$Lang::tr{'hostname'}:&nbsp;<img src='/blob.gif' alt='*' /></td>
<td width='25%'><input type='text' name='DHCP_HOSTNAME' value='$pppsettings{'DHCP_HOSTNAME'}' /></td>
</tr>
END
;
@@ -738,180 +738,59 @@ END
if ($pppsettings{'TYPE'} eq 'pppoe')
{
print <<END
</table>
<table width='100%'>
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'pppoe settings'}</b></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusb|alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|fritzdsl|bewanadsl|eagleusbadsl)$/)
{
print <<END
</table>
<table width='100%'>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'adsl settings'}:</b></td>
<td colspan='4' width='100%' bgcolor='${Header::table1colour}'><b>$Lang::tr{'pppoe settings'}</b></td>
</tr>
<tr>
<td nowrap='nowrap' align='right'>$Lang::tr{'vpi number'}</td>
<td><input type='text' size='5' name='VPI' value='$pppsettings{'VPI'}' /></td>
<td align='right'>$Lang::tr{'vci number'}</td>
<td colspan='2'><input type='text' size='5' name='VCI' value='$pppsettings{'VCI'}' /></td>
<td width='25%'><input type='radio' name='METHOD' value='PPPOE_PLUGIN' $checked{'METHOD'}{'PPPOE_PLUGIN'} />PPPoE plugin</td>
<td colspan='2' width='50%'>$Lang::tr{'service name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td width='25%'><input type='text' name='SERVICENAME' value='$pppsettings{'SERVICENAME'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} eq 'bewanadsl')
{
print <<END
<tr>
<td align='right'>$Lang::tr{'modem'}:</td>
<td colspan='2' nowrap='nowrap'>
<input type='radio' name='MODEM' value='PCIST' $checked{'MODEM'}{'PCIST'} />Bewan ADSL PCI st</td>
<td colspan='2'><input type='radio' name='MODEM' value='USB' $checked{'MODEM'}{'USB'} />Bewan ADSL USB st</td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(3cp4218usbadsl|bewanadsl)$/)
{
print <<END
<tr>
<td align='right'>$Lang::tr{'modulation'}:</td>
<td><input type='radio' name='MODULATION' value='AUTO' $checked{'MODULATION'}{'AUTO'} />$Lang::tr{'automatic'}</td>
<td><input type='radio' name='MODULATION' value='ANSI' $checked{'MODULATION'}{'ANSI'} />ANSI T1.483</td>
<td><input type='radio' name='MODULATION' value='GDMT' $checked{'MODULATION'}{'GDMT'} />G.DMT</td>
<td><input type='radio' name='MODULATION' value='GLITE' $checked{'MODULATION'}{'GLITE'} />G.Lite</td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
<td width='25%'><input type='radio' name='METHOD' value='PPPOE' $checked{'METHOD'}{'PPPOE'} />$Lang::tr{'pppoe'}</td>
<td colspan='2' width='50%'>$Lang::tr{'concentrator name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td width='25%'><input type='text' name='CONCENTRATORNAME' value='$pppsettings{'CONCENTRATORNAME'}' /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} eq 'eagleusbadsl')
if ($pppsettings{'TYPE'} eq 'fritzdsl')
{
print <<END
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td align='right'>$Lang::tr{'country'}:</td>
<td>
<select name='LINE'>
<option value='WO' $selected{'LINE'}{'WO'}>$Lang::tr{'other countries'}</option>
<option value='ES' $selected{'LINE'}{'ES'}>ESPANA</option>
<option value='ES03' $selected{'LINE'}{'ES03'}>ESPANA03</option>
<option value='FR' $selected{'LINE'}{'FR'}>FRANCE</option>
<option value='FR04' $selected{'LINE'}{'FR04'}>FRANCE04</option>
<option value='FR10' $selected{'LINE'}{'FR04'}>FRANCE10</option>
<option value='IT' $selected{'LINE'}{'IT'}>ITALIA</option>
</select></td>
<td colspan='4' width='100%' bgcolor='${Header::table1colour}'><b>$Lang::tr{'adsl settings'}:</b></td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} eq 'eciadsl')
{
print <<END
<tr>
<td align='right'>$Lang::tr{'modem'}:</td>
<td colspan='5'>
<select name='MODEM'>
END
;
open (MODEMS, "/etc/eciadsl/modems.db") or die 'Unable to open modems database.';
while (my $line = <MODEMS>) {
$line =~ /^([\S\ ]+).*$/;
my $modem = $1;
$modem =~ s/^\s*(.*?)\s*$/$1/;
print "<option value='$modem'";
if ($pppsettings{'MODEM'} =~ /$modem/) { print " selected";}
print ">$modem</option>\n";
}
close (MODEMS);
print <<END
</select>
</td>
<td colspan='2' width='50%'>$Lang::tr{'vpi number'}</td>
<td colspan='2' width='50%'><input type='text' name='VPI' value='$pppsettings{'VPI'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
<td colspan='2' width='50%'>$Lang::tr{'vci number'}</td>
<td colspan='2' width='50%'><input type='text' name='VCI' value='$pppsettings{'VCI'}' /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusb|alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|fritzdsl|bewanadsl|eagleusbadsl)$/)
{
print <<END
<tr>
<td valign='top' align='right'>$Lang::tr{'protocol'}:</td>
<td nowrap='nowrap'>
<input type='radio' name='PROTOCOL' value='RFC2364' $checked{'PROTOCOL'}{'RFC2364'} />RFC2364 PPPoA</td>
END
;
}
if ($pppsettings{'TYPE'} eq 'alcatelusb')
{
print "<td colspan=3>&nbsp;</td></tr>";
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|bewanadsl|eagleusbadsl|fritzdsl)$/)
{
print <<END
<td align='right'>$Lang::tr{'encapsulation'}:</td>
<td colspan='2' width='30%'>
<select name='ENCAP_RFC2364'>
<td colspan='2' width='50%'>$Lang::tr{'protocol'}:</td>
<td colspan='2' width='50%'><input type='radio' name='PROTOCOL' value='RFC2364' $checked{'PROTOCOL'}{'RFC2364'} />RFC2364 PPPoA</td>
</tr>
<td colspan='2' width='50%'></td>
<td colspan='2' width='50%'><input type='radio' name='PROTOCOL' value='RFC1483' $checked{'PROTOCOL'}{'RFC1483'} />RFC 1483 / 2684</td>
</tr>
<tr>
<td colspan='2' width='50%'>$Lang::tr{'encapsulation'}:</td>
<td colspan='2' width='50%'>
<select name='ENCAP_RFC2364' style="width: 165px">
<option value='0' $selected{'ENCAP'}{'0'}>VCmux</option>
<option value='1' $selected{'ENCAP'}{'1'}>LLC</option>
</select>
</td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusb|alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|fritzdsl|bewanadsl|eagleusbadsl)$/)
{
print <<END
<tr>
<td>&nbsp;</td>
<td colspan='4'><hr /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td valign='top'>
<input type='radio' name='PROTOCOL' value='RFC1483' $checked{'PROTOCOL'}{'RFC1483'} />RFC 1483 / 2684</td>
END
;
}
if ($pppsettings{'TYPE'} eq 'alcatelusb')
{
print "<td colspan='3'>&nbsp;</td></tr>";
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|bewanadsl|eagleusbadsl|fritzdsl)$/)
{
if ($pppsettings{'TYPE'} ne 'fritzdsl')
{
print <<END
<td align='right'>$Lang::tr{'encapsulation'}:</td>
<td colspan='2'>
<select name='ENCAP_RFC1483'>
<td colspan='2' width='50%'>$Lang::tr{'encapsulation'}:</td>
<td colspan='2' width='50%'>
<select name='ENCAP_RFC1483' style="width: 165px">
<option value='0' $selected{'ENCAP'}{'0'}>BRIDGED_ETH_LLC</option>
<option value='1' $selected{'ENCAP'}{'1'}>BRIDGED_ETH_VC</option>
<option value='2' $selected{'ENCAP'}{'2'}>ROUTED_IP_LLC</option>
@@ -919,138 +798,29 @@ print <<END
</select>
</td>
</tr>
<tr>
<td colspan='2'>&nbsp;</td>
<td colspan='3'><hr /></td>
</tr>
END
;
} else {
print <<END
<td colspan='4'>PPPoE</td>
</tr>
END
;
}
}
if ($pppsettings{'TYPE'} =~ /^(pppoe|alcatelusb|alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|bewanadsl|eagleusbadsl)$/)
{
print <<END
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td><input type='radio' name='METHOD' value='PPPOE_PLUGIN' $checked{'METHOD'}{'PPPOE_PLUGIN'} />PPPoE plugin</td>
<td align='right'>$Lang::tr{'service name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td><input type='text' name='SERVICENAME' value='$pppsettings{'SERVICENAME'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td><input type='radio' name='METHOD' value='PPPOE' $checked{'METHOD'}{'PPPOE'} />$Lang::tr{'pppoe'}</td>
<td align='right'>$Lang::tr{'concentrator name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td><input type='text' name='CONCENTRATORNAME' value='$pppsettings{'CONCENTRATORNAME'}' /></td>
</tr>
END
;
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusbk|amedynusbadsl|conexantusbadsl|conexantpciadsl|3cp4218usbadsl|pulsardsl|eciadsl|bewanadsl|eagleusbadsl)$/)
{
print <<END
<tr>
<td colspan='2'>&nbsp;</td>
<td colspan='3'><hr /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td rowspan='4'><input type='radio' name='METHOD' value='STATIC' $checked{'METHOD'}{'STATIC'} />$Lang::tr{'static ip'}</td>
<td align='right'>$Lang::tr{'static ip'}:</td>
<td><input type='text' size='16' name='IP' value='$pppsettings{'IP'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td align='right'>$Lang::tr{'gateway ip'}:</td>
<td><input type='text' size='16' name='GATEWAY' value='$pppsettings{'GATEWAY'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td align='right'>$Lang::tr{'netmask'}:</td>
<td><input type='text' size='16' name='NETMASK' value='$pppsettings{'NETMASK'}' /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td align='right' nowrap='nowrap'>$Lang::tr{'broadcast'}:&nbsp;<img src='/blob.gif' alt='*' /></td>
<td><input type='text' size='16' name='BROADCAST' value='$pppsettings{'BROADCAST'}' /></td>
</tr>
END
;
if ($pppsettings{'TYPE'} =~ /^(eciadsl|eagleusbadsl)$/)
{
print <<END
<tr>
<td colspan='2'>&nbsp;</td>
<td colspan='3'><hr /></td>
</tr>
<tr>
<td>&nbsp;</td>
<td>&nbsp;</td>
<td><input type='radio' name='METHOD' value='DHCP' $checked{'METHOD'}{'DHCP'} />$Lang::tr{'dhcp mode'}</td>
<td align='right'>$Lang::tr{'hostname'}:&nbsp;<img src='/blob.gif' alt='*' /></td>
<td><input type='text' name='DHCP_HOSTNAME' value='$pppsettings{'DHCP_HOSTNAME'}' /></td>
</tr>
END
;
}
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusb|alcatelusbk|eciadsl|fritzdsl)$/) {
print "<tr><td>&nbsp;</td><td colspan='4'><hr /></td></tr>";
}
if ($pppsettings{'TYPE'} =~ /^(alcatelusb|alcatelusbk)$/) {
my $speedtouch = &Header::speedtouchversion;
if (($speedtouch >= 0) && ($speedtouch <=4)) {
my $modem;
if ($speedtouch ==4) { $modem='v4_b'; } else { $modem='v0123'; }
print "<tr><td align='right'>$Lang::tr{'firmware'}:</td>";
if (-e "${General::swroot}/alcatelusb/firmware.$modem.bin") {
print "<td>$Lang::tr{'present'}</td><td colspan='3'>&nbsp;</td></tr>\n";
} else {
print "<td>$Lang::tr{'not present'}</td><td colspan='3'>&nbsp;</td></tr>\n";
}
} else {
print "<tr><td colspan='5'>$Lang::tr{'unknown'} Rev $speedtouch</td></tr>";
}
} elsif ($pppsettings{'TYPE'} eq 'eciadsl') {
print "<tr><td align='right'>$Lang::tr{'driver'}:</td>";
if (-e "${General::swroot}/eciadsl/synch.bin") {
print "<td>$Lang::tr{'present'}</td><td colspan='3'>&nbsp;</td></tr>\n";
} else {
print "<td>$Lang::tr{'not present'}</td><td colspan='3'>&nbsp;</td></tr>\n"; }
} elsif ($pppsettings{'TYPE'} eq 'fritzdsl') {
print "<tr><td align='right'>$Lang::tr{'driver'}:</td>";
print "<tr><td colspan='2' width='50%'>$Lang::tr{'driver'}:</td>";
if (-e "/lib/modules/$kernel/misc/fcdslusb.o.gz") {
print "<td>$Lang::tr{'present'}</td><td colspan='3'>&nbsp;</td></tr>\n";
print "<td colspan='2' width='50%'>$Lang::tr{'present'}</td></tr>";
} else {
print "<td>$Lang::tr{'not present'}</td><td colspan='3'>&nbsp;</td></tr>\n"; }
print "<td colspan='2' width='50%'>$Lang::tr{'not present'}</td></tr>"; }
}
print <<END
</table>
<table width='100%'>
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='5'><br /><hr /><b>$Lang::tr{'authentication'}</b></td>
<td bgcolor='${Header::table1colour}' colspan='4' width='100%'><b>$Lang::tr{'authentication'}</b></td>
</tr>
<tr>
<td align='right'>$Lang::tr{'username'}</td>
<td><input type='text' name='USERNAME' value='$pppsettings{'USERNAME'}' /></td>
<td align='right'>$Lang::tr{'password'}</td>
<td><input type='password' name='PASSWORD' value='$pppsettings{'PASSWORD'}' /></td>
<td width='25%'>$Lang::tr{'username'}</td>
<td width='25%'><input type='text' name='USERNAME' value='$pppsettings{'USERNAME'}' /></td>
<td width='25%'>$Lang::tr{'password'}</td>
<td width='25%'><input type='password' name='PASSWORD' value='$pppsettings{'PASSWORD'}' /></td>
</tr>
<tr>
<td align='right'>$Lang::tr{'method'}</td>
<td><select name='AUTH'>
<td width='25%'>$Lang::tr{'method'}</td>
<td width='25%'><select name='AUTH' style="width: 165px">
<option value='pap-or-chap' $selected{'AUTH'}{'pap-or-chap'}>$Lang::tr{'pap or chap'}</option>
<option value='pap' $selected{'AUTH'}{'pap'}>PAP</option>
<option value='chap' $selected{'AUTH'}{'chap'}>CHAP</option>
@@ -1066,39 +836,37 @@ END
}
print <<END
</select></td>
<td align='right'>$Lang::tr{'script name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td nowrap='nowrap'><input type='text' name='LOGINSCRIPT' value='$pppsettings{'LOGINSCRIPT'}' /></td>
<td width='25%'>$Lang::tr{'script name'}&nbsp;<img src='/blob.gif' alt='*' /></td>
<td width='25%'><input type='text' name='LOGINSCRIPT' value='$pppsettings{'LOGINSCRIPT'}' /></td>
</tr>
</table>
<table width='100%'>
<tr><td colspan='4' width='100%'><br></br></td></tr>
<tr>
<td colspan='5'><br /><hr /><b>DNS:</b></td>
<td bgcolor='${Header::table1colour}' colspan='4' width='100%'><b>DNS:</b></td>
</tr>
<tr>
<td colspan='5'><input type='radio' name='DNS' value='Automatic' $checked{'DNS'}{'Automatic'} />$Lang::tr{'automatic'}</td>
<td colspan='4' width='100%'><input type='radio' name='DNS' value='Automatic' $checked{'DNS'}{'Automatic'} />$Lang::tr{'automatic'}</td>
</tr>
<tr>
<td><input type='radio' name='DNS' value='Manual' $checked{'DNS'}{'Manual'} />$Lang::tr{'manual'}</td>
<td align='right'>$Lang::tr{'primary dns'}</td>
<td><input type='text' size='16' name='DNS1' value='$pppsettings{'DNS1'}' /></td>
<td align='right'>$Lang::tr{'secondary dns'}</td>
<td><input type='text' size='16' name='DNS2' value='$pppsettings{'DNS2'}' /></td>
<td colspan='4' width='100%'><input type='radio' name='DNS' value='Manual' $checked{'DNS'}{'Manual'} />$Lang::tr{'manual'}</td>
</tr>
<tr>
<td colspan='5'><br /><hr /></td>
<td width='25%'>$Lang::tr{'primary dns'}</td>
<td width='25%'><input type='text' name='DNS1' value='$pppsettings{'DNS1'}'></td>
<td width='25%'>$Lang::tr{'secondary dns'}</td>
<td width='25%'><input type='text' name='DNS2' value='$pppsettings{'DNS2'}'></td>
</tr>
<tr><td colspan='4' width='100%'><br></br><hr></hr><br></br></td></tr>
<tr>
<td width='25%'>$Lang::tr{'profile name'}</td>
<td width='25%'><input type='text' name='PROFILENAME' value='$pppsettings{'PROFILENAME'}'>
<td colspan='2' width='50%'></td>
</tr>
<tr>
<td>&nbsp;</td>
<td align='right'>$Lang::tr{'profile name'}</td>
<td><input type='text' name='PROFILENAME' value='$pppsettings{'PROFILENAME'}' /></td>
<td><input type='submit' name='ACTION' value='$Lang::tr{'save'}' /></td>
<td align='center' colspan='4' width='100%'><input type='submit' name='ACTION' value='$Lang::tr{'save'}'></td>
</tr>
<tr>
<td colspan='5'><br /><hr /></td>
</tr>
<tr>
<td align='right'>$Lang::tr{'legend'}:</td>
<td><img src='/blob.gif' alt='*' />&nbsp;$Lang::tr{'this field may be blank'}</td>
<td colspan='2' width='50%'>$Lang::tr{'legend'}:</td>
<td colspan='2' width='50%'><img src='/blob.gif' alt='*' />&nbsp;$Lang::tr{'this field may be blank'}</td>
</tr>
</table>
END

79
lfs/GD-Graph Normal file
View File

@@ -0,0 +1,79 @@
###############################################################################
# This file is part of the IPCop Firewall. #
# #
# IPCop is free software; you can redistribute it and/or modify #
# it under the terms of the GNU General Public License as published by #
# the Free Software Foundation; either version 2 of the License, or #
# (at your option) any later version. #
# #
# IPCop is distributed in the hope that it will be useful, #
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
# GNU General Public License for more details. #
# #
# You should have received a copy of the GNU General Public License #
# along with IPCop; if not, write to the Free Software #
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #
# #
# Makefiles are based on LFSMake, which is #
# Copyright (C) 2002 Rod Roard <rod@sunsetsystems.com> #
# #
###############################################################################
###############################################################################
# Definitions
###############################################################################
include Config
VER = 1.4308
THISAPP = GDGraph-$(VER)
DL_FILE = $(THISAPP).tar.gz
DL_FROM = $(URL_IPFIRE)
DIR_APP = $(DIR_SRC)/$(THISAPP)
TARGET = $(DIR_INFO)/$(THISAPP)
###############################################################################
# Top-level Rules
###############################################################################
objects = $(DL_FILE)
$(DL_FILE) = $(DL_FROM)/$(DL_FILE)
$(DL_FILE)_MD5 = fcdd34d5e09ae917b5d264887734b3b1
install : $(TARGET)
check : $(patsubst %,$(DIR_CHK)/%,$(objects))
download :$(patsubst %,$(DIR_DL)/%,$(objects))
md5 : $(subst %,%_MD5,$(objects))
###############################################################################
# Downloading, checking, md5sum
###############################################################################
$(patsubst %,$(DIR_CHK)/%,$(objects)) :
@$(CHECK)
$(patsubst %,$(DIR_DL)/%,$(objects)) :
@$(LOAD)
$(subst %,%_MD5,$(objects)) :
@$(MD5)
###############################################################################
# Installation Details
###############################################################################
$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
@$(PREBUILD)
@rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar zxf $(DIR_DL)/$(DL_FILE)
cd $(DIR_APP) && perl Makefile.PL
cd $(DIR_APP) && make $(MAKETUNING)
cd $(DIR_APP) && make install
@rm -rf $(DIR_APP)
@$(POSTBUILD)

View File

@@ -73,9 +73,9 @@ $(TARGET) :
depmod -a -F /boot/System.map-$(KVER)-ipfire-smp $(KVER)-ipfire-smp
cd / && tar -cvf /tmp/drivers.tar \
--exclude=lib/modules/$(KVER)-ipfire/kernel/{arch,fs} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/{acpi,atm,bluetooth,block,char,cdrom,hwmon,ide} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/{ieee1394,isdn,mmc,scsi,md,video} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/{arch,crypto} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/{acpi,atm,bluetooth,block,char,cdrom,connector,cpufreq,hwmon,ide} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/{ieee1394,isdn,mmc,md,parport,video} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/net/{wan,ppp*,slip*,slhc*,tun*,wireless} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/usb/{atm,input,storage,host} \
--exclude=lib/modules/$(KVER)-ipfire/kernel/drivers/usb/{3cp4218.ko,acm.ko,amedyn.ko,cxacru.ko} \
@@ -87,10 +87,6 @@ $(TARGET) :
cd /install/initrd/ && tar -xvf /tmp/drivers.tar && rm -f /tmp/drivers.tar
# Extra modules
-mkdir -p /install/initrd/lib/modules/$(KVER)-ipfire/kernel/drivers/scsi
cp -af /lib/modules/$(KVER)-ipfire/kernel/drivers/scsi/*.ko \
/install/initrd/lib/modules/$(KVER)-ipfire/kernel/drivers/scsi/
-mkdir -p /install/initrd/lib/modules/$(KVER)-ipfire/kernel/drivers/usb/storage
cp -f /lib/modules/$(KVER)-ipfire/kernel/drivers/usb/storage/*.ko \
/install/initrd/lib/modules/$(KVER)-ipfire/kernel/drivers/usb/storage/
@@ -107,10 +103,6 @@ $(TARGET) :
cp -f /lib/modules/$(KVER)-ipfire/kernel/drivers/usb/core/*.ko \
/install/initrd/lib/modules/$(KVER)-ipfire/kernel/drivers/usb/core
# File system
-mkdir -p /install/initrd/lib/modules/$(KVER)-ipfire/kernel/fs
cp -rf /lib/modules/$(KVER)-ipfire/kernel/fs/* /install/initrd/lib/modules/$(KVER)-ipfire/kernel/fs
cp -f /lib/modules/$(KVER)-ipfire/modules.* /install/initrd/lib/modules/$(KVER)-ipfire
cp /opt/$(MACHINE)-uClibc/lib/libgcc_s.so.1 /install/initrd/lib/

View File

@@ -393,6 +393,7 @@ buildipfire() {
ipfiremake ez-ipupdate
ipfiremake fcron
ipfiremake GD
ipfiremake GD-Graph
ipfiremake gnupg
ipfiremake hdparm
ipfiremake ibod

View File

@@ -128,7 +128,6 @@ int main(int argc, char *argv[])
}
}
// make some beeps before wiping the system :)
if (unattended) {
runcommandwithstatus("/bin/sleep 10", "WARNING: Unattended installation will start in 10 seconds...");
}
@@ -165,8 +164,7 @@ int main(int argc, char *argv[])
rc = newtWinMenu(ctr[TR_SELECT_INSTALLATION_MEDIA], message,
50, 5, 5, 6, installtypes, &installtype, ctr[TR_OK],
ctr[TR_CANCEL], NULL);
}
else {
} else {
rc = 1;
installtype = CDROM_INSTALL;
}
@@ -179,7 +177,6 @@ int main(int argc, char *argv[])
/* CDROM INSTALL */
if (installtype == CDROM_INSTALL) {
switch (mysystem("/bin/mountsource.sh")) {
case 0:
installtype = CDROM_INSTALL;
@@ -215,7 +212,7 @@ int main(int argc, char *argv[])
goto EXIT;
}
/* Check for ipcop-<VERSION>.tbz2 */
/* Check for ipfire-<VERSION>.tbz2 */
if (checktarball(SNAME "-" VERSION ".tbz2", ctr[TR_ENTER_URL])) {
errorbox(ctr[TR_NO_IPCOP_TARBALL_FOUND]);
goto EXIT;
@@ -527,30 +524,6 @@ int main(int argc, char *argv[])
mysystem("/bin/mount -t proc none /harddisk/proc");
mysystem("/bin/mount --bind /dev /harddisk/dev");
/* if we detected SCSI then fixup */
/* doesn't really work cause it sometimes creates a ramdisk on ide systems */
/* mysystem("/bin/probecntrl.sh");
if ((handle = fopen("/cntrldriver", "r")))
{
char *driver;
fgets(line, STRING_SIZE-1, handle);
fclose(handle);
line[strlen(line) - 1] = 0;
driver = strtok(line, ".");
fprintf(flog, "Detected SCSI driver %s\n",driver);
if (strlen(driver) > 1) {
fprintf(flog, "Fixing up ipfirerd.img\n");
mysystem("/sbin/chroot /harddisk /sbin/modprobe loop");
mkdir("/harddisk/initrd", S_IRWXU|S_IRWXG|S_IRWXO);
snprintf(commandstring, STRING_SIZE, "/sbin/chroot /harddisk /sbin/mkinitrd --with=scsi_mod --with=%s --with=sd_mod --with=sr_mod --with=libata /boot/ipfirerd.img %s", driver, KERNEL_VERSION);
runcommandwithstatus(commandstring, ctr[TR_BUILDING_INITRD]);
snprintf(commandstring, STRING_SIZE, "/sbin/chroot /harddisk /sbin/mkinitrd --with=scsi_mod --with=%s --with=sd_mod --with=sr_mod --with=libata /boot/ipfirerd-smp.img %s-smp", driver, KERNEL_VERSION);
runcommandwithstatus(commandstring, ctr[TR_BUILDING_INITRD]);
mysystem("/sbin/chroot /harddisk /bin/mv /boot/grub/scsigrub.conf /boot/grub/grub.conf");
}
} */
/* Build cache lang file */
snprintf(commandstring, STRING_SIZE, "/sbin/chroot /harddisk /usr/bin/perl -e \"require '" CONFIG_ROOT "/lang.pl'; &Lang::BuildCacheLang\"");
if (runcommandwithstatus(commandstring, ctr[TR_INSTALLING_LANG_CACHE]))
@@ -559,6 +532,29 @@ int main(int argc, char *argv[])
goto EXIT;
}
/* Update /etc/fstab */
replace("/harddisk/etc/fstab", "DEVICE", hdparams.devnode);
/* if we detected SCSI/USB then fixup */
mysystem("/bin/probecntrl.sh");
if ((handle = fopen("/tmp/cntrldriver", "r")))
{
char *driver;
fgets(line, STRING_SIZE-1, handle);
fclose(handle);
line[strlen(line) - 1] = 0;
driver = strtok(line, ".");
if (strlen(driver) > 1) {
fprintf(flog, "Fixing up ipfirerd.img\n");
mkdir("/harddisk/initrd", S_IRWXU|S_IRWXG|S_IRWXO);
snprintf(commandstring, STRING_SIZE, "/sbin/chroot /harddisk /sbin/mkinitrd --with=scsi_mod %s --with=sd_mod --with=sr_mod /boot/ipfirerd.img %s-ipfire", driver, KERNEL_VERSION);
runcommandwithstatus(commandstring, ctr[TR_BUILDING_INITRD]);
snprintf(commandstring, STRING_SIZE, "/sbin/chroot /harddisk /sbin/mkinitrd --with=scsi_mod %s --with=sd_mod --with=sr_mod /boot/ipfirerd-smp.img %s-ipfire-smp", driver, KERNEL_VERSION);
runcommandwithstatus(commandstring, ctr[TR_BUILDING_INITRD]);
mysystem("/sbin/chroot /harddisk /bin/mv /boot/grub/scsigrub.conf /boot/grub/grub.conf");
}
}
if (raid_disk)
sprintf(string, "root=%sp3", hdparams.devnode);
else
@@ -576,9 +572,6 @@ int main(int argc, char *argv[])
goto EXIT;
}
/* Update /etc/fstab */
replace("/harddisk/etc/fstab", "DEVICE", hdparams.devnode);
/* Install bootsplash */
mysystem("/bin/installbootsplash.sh");

View File

@@ -1,13 +1,19 @@
#!/bin/sh
echo "Probing for SCSI controllers"
MODULE=`/bin/kudzu -qps -t 30 -c SCSI | grep driver | cut -d ' ' -f 2 | sort | uniq`
echo "Probing for storage controllers"
for MODULE in $(hwinfo --usb --usb-ctrl --storage-ctrl | grep modprobe | awk '{ print $5 }' | tr -d \" | sort | uniq); do
if [ "${MODULE}" = "piix" ]; then
continue
fi
if grep -Eqe "^${MODULE} " /proc/modules; then
MODULES="${MODULES} --with=${MODULE}"
echo "Found: ${MODULE}"
fi
done
if [ "$MODULE" ]; then
echo $MODULE > /tmp/cntrldriver
echo "Your controller is: $MODULE"
if [ -z "${MODULES}" ]; then
exit 1
else
echo "${MODULES}" > /tmp/cntrldriver
exit 0
fi
echo "No SCSI controller found"
exit 1

View File

@@ -15,7 +15,7 @@
* along with IPFire; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Copyright 2002: Mark Wormgoor <mark@wormgoor.com>
* Copyright 2007: Michael Tremer for www.ipfire.org
*
*/

View File

@@ -29,6 +29,7 @@ int initialize_usb() {
mysystem("/sbin/modprobe sd_mod");
mysystem("/sbin/modprobe sr_mod");
mysystem("/sbin/modprobe usb-storage");
mysystem("/sbin/modprobe vfat");
if (ehcihcd) {
mysystem("/sbin/rmmod ehci-hcd");
@@ -51,7 +52,7 @@ int initialize_usb() {
usbuhci = 1;
mysystem("/sbin/modprobe usbhid");
mysystem("udevstart");
mysystem("/sbin/udevstart");
return 0;
}

View File

@@ -1,23 +1,18 @@
CFLAGS=-Wall -DVERSION=\"$(VERSION)\" -g
CFLAGS=-Wall -Werror -DVERSION=\"$(VERSION)\" -g -D_FORTIFY_SOURCE=2
VERSION=$(shell awk -F= '/^VERSION=/ { print $$2 }' mkinitrd)
ARCH := $(patsubst i%86,i386,$(shell uname -m))
ARCH := $(patsubst sparc%,sparc,$(ARCH))
#ifeq (i386, $(ARCH))
#CC:=diet $(CC)
#CFLAGS += -DUSE_DIET=1
#else
STATIC=-static
#endif
mandir=usr/share/man
nash: nash.o mount_by_label.o
$(CC) $(STATIC) -g $(LDFLAGS) -o $@ nash.o mount_by_label.o
nash: nash.o mount_by_label.o name_to_dev_t.o
$(CC) $(STATIC) -g $(LDFLAGS) -o $@ $^
clean:
rm -f nash $(MINILIBC) nash.o mount_by_label.o
rm -f nash $(MINILIBC) *.o
install:
mkdir -p $(BUILDROOT)/sbin

View File

@@ -1,181 +1,181 @@
/* Including <linux/fs.h> became more and more painful.
Below a very abbreviated version of some declarations,
only designed to be able to check a magic number
in case no filesystem type was given. */
#ifndef BLKGETSIZE
#ifndef _IO
/* pre-1.3.45 */
#define BLKGETSIZE 0x1260 /* return device size */
#else
/* same on i386, m68k, arm; different on alpha, mips, sparc, ppc */
#define BLKGETSIZE _IO(0x12,96)
#endif
#endif
#define MINIX_SUPER_MAGIC 0x137F /* original minix fs */
#define MINIX_SUPER_MAGIC2 0x138F /* minix fs, 30 char names */
struct minix_super_block {
unsigned char s_dummy[16];
unsigned char s_magic[2];
};
#define minixmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define ISODCL(from, to) (to - from + 1)
#define ISO_STANDARD_ID "CD001"
struct iso_volume_descriptor {
char type[ISODCL(1,1)]; /* 711 */
char id[ISODCL(2,6)];
char version[ISODCL(7,7)];
char data[ISODCL(8,2048)];
};
#define HS_STANDARD_ID "CDROM"
struct hs_volume_descriptor {
char foo[ISODCL ( 1, 8)]; /* 733 */
char type[ISODCL ( 9, 9)]; /* 711 */
char id[ISODCL ( 10, 14)];
char version[ISODCL ( 15, 15)]; /* 711 */
char data[ISODCL(16,2048)];
};
#define EXT_SUPER_MAGIC 0x137D
struct ext_super_block {
unsigned char s_dummy[56];
unsigned char s_magic[2];
};
#define extmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define EXT2_PRE_02B_MAGIC 0xEF51
#define EXT2_SUPER_MAGIC 0xEF53
#define EXT3_FEATURE_COMPAT_HAS_JOURNAL 0x0004
struct ext2_super_block {
unsigned char s_dummy1[56];
unsigned char s_magic[2];
unsigned char s_dummy2[34];
unsigned char s_feature_compat[4];
unsigned char s_feature_incompat[4];
unsigned char s_feature_ro_compat[4];
unsigned char s_uuid[16];
unsigned char s_volume_name[16];
unsigned char s_dummy3[88];
unsigned char s_journal_inum[4]; /* ext3 only */
};
#define ext2magic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
struct reiserfs_super_block
{
unsigned char s_block_count[4];
unsigned char s_free_blocks[4];
unsigned char s_root_block[4];
unsigned char s_journal_block[4];
unsigned char s_journal_dev[4];
unsigned char s_orig_journal_size[4];
unsigned char s_journal_trans_max[4];
unsigned char s_journal_block_count[4];
unsigned char s_journal_max_batch[4];
unsigned char s_journal_max_commit_age[4];
unsigned char s_journal_max_trans_age[4];
unsigned char s_blocksize[2];
unsigned char s_oid_maxsize[2];
unsigned char s_oid_cursize[2];
unsigned char s_state[2];
unsigned char s_magic[12];
};
#define REISERFS_SUPER_MAGIC_STRING "ReIsErFs"
#define REISER2FS_SUPER_MAGIC_STRING "ReIsEr2Fs"
#define REISERFS_DISK_OFFSET_IN_BYTES (64 * 1024)
/* the spot for the super in versions 3.5 - 3.5.10 (inclusive) */
#define REISERFS_OLD_DISK_OFFSET_IN_BYTES (8 * 1024)
#define _XIAFS_SUPER_MAGIC 0x012FD16D
struct xiafs_super_block {
unsigned char s_boot_segment[512]; /* 1st sector reserved for boot */
unsigned char s_dummy[60];
unsigned char s_magic[4];
};
#define xiafsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
/* From jj@sunsite.ms.mff.cuni.cz Mon Mar 23 15:19:05 1998 */
#define UFS_SUPER_MAGIC 0x00011954
struct ufs_super_block {
unsigned char s_dummy[0x55c];
unsigned char s_magic[4];
};
#define ufsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
/* From Richard.Russon@ait.co.uk Wed Feb 24 08:05:27 1999 */
#define NTFS_SUPER_MAGIC "NTFS"
struct ntfs_super_block {
unsigned char s_dummy[3];
unsigned char s_magic[4];
};
/* From inspection of a few FAT filesystems - aeb */
/* Unfortunately I find almost the same thing on an extended partition;
it looks like a primary has some directory entries where the extended
has a partition table: IO.SYS, MSDOS.SYS, WINBOOT.SYS */
struct fat_super_block {
unsigned char s_dummy[3];
unsigned char s_os[8]; /* "MSDOS5.0" or "MSWIN4.0" or "MSWIN4.1" */
/* mtools-3.9.4 writes "MTOOL394" */
unsigned char s_dummy2[32];
unsigned char s_label[11]; /* for DOS? */
unsigned char s_fs[8]; /* "FAT12 " or "FAT16 " or all zero */
/* OS/2 BM has "FAT " here. */
unsigned char s_dummy3[9];
unsigned char s_label2[11]; /* for Windows? */
unsigned char s_fs2[8]; /* garbage or "FAT32 " */
};
#define XFS_SUPER_MAGIC "XFSB"
struct xfs_super_block {
unsigned char s_magic[4];
unsigned char s_dummy[28];
unsigned char s_uuid[16];
unsigned char s_dummy2[60];
unsigned char s_fname[12];
};
#define CRAMFS_SUPER_MAGIC 0x28cd3d45
struct cramfs_super_block {
unsigned char s_magic[4];
unsigned char s_dummy[12];
unsigned char s_id[16];
};
#define cramfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
#define HFS_SUPER_MAGIC 0x4244
struct hfs_super_block {
unsigned char s_magic[2];
unsigned char s_dummy[18];
unsigned char s_blksize[4];
};
#define hfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define hfsblksize(s) ((unsigned int) s.s_blksize[0] + \
(((unsigned int) s.s_blksize[1]) << 8) + \
(((unsigned int) s.s_blksize[2]) << 16) + \
(((unsigned int) s.s_blksize[3]) << 24))
#define HPFS_SUPER_MAGIC 0xf995e849
struct hpfs_super_block {
unsigned char s_magic[4];
unsigned char s_magic2[4];
};
#define hpfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
struct adfs_super_block {
unsigned char s_dummy[448];
unsigned char s_blksize[1];
unsigned char s_dummy2[62];
unsigned char s_checksum[1];
};
#define adfsblksize(s) ((unsigned int) s.s_blksize[0])
/* Including <linux/fs.h> became more and more painful.
Below a very abbreviated version of some declarations,
only designed to be able to check a magic number
in case no filesystem type was given. */
#ifndef BLKGETSIZE
#ifndef _IO
/* pre-1.3.45 */
#define BLKGETSIZE 0x1260 /* return device size */
#else
/* same on i386, m68k, arm; different on alpha, mips, sparc, ppc */
#define BLKGETSIZE _IO(0x12,96)
#endif
#endif
#define MINIX_SUPER_MAGIC 0x137F /* original minix fs */
#define MINIX_SUPER_MAGIC2 0x138F /* minix fs, 30 char names */
struct minix_super_block {
unsigned char s_dummy[16];
unsigned char s_magic[2];
};
#define minixmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define ISODCL(from, to) (to - from + 1)
#define ISO_STANDARD_ID "CD001"
struct iso_volume_descriptor {
char type[ISODCL(1,1)]; /* 711 */
char id[ISODCL(2,6)];
char version[ISODCL(7,7)];
char data[ISODCL(8,2048)];
};
#define HS_STANDARD_ID "CDROM"
struct hs_volume_descriptor {
char foo[ISODCL ( 1, 8)]; /* 733 */
char type[ISODCL ( 9, 9)]; /* 711 */
char id[ISODCL ( 10, 14)];
char version[ISODCL ( 15, 15)]; /* 711 */
char data[ISODCL(16,2048)];
};
#define EXT_SUPER_MAGIC 0x137D
struct ext_super_block {
unsigned char s_dummy[56];
unsigned char s_magic[2];
};
#define extmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define EXT2_PRE_02B_MAGIC 0xEF51
#define EXT2_SUPER_MAGIC 0xEF53
#define EXT3_FEATURE_COMPAT_HAS_JOURNAL 0x0004
struct ext2_super_block {
unsigned char s_dummy1[56];
unsigned char s_magic[2];
unsigned char s_dummy2[34];
unsigned char s_feature_compat[4];
unsigned char s_feature_incompat[4];
unsigned char s_feature_ro_compat[4];
unsigned char s_uuid[16];
unsigned char s_volume_name[16];
unsigned char s_dummy3[88];
unsigned char s_journal_inum[4]; /* ext3 only */
};
#define ext2magic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
struct reiserfs_super_block
{
unsigned char s_block_count[4];
unsigned char s_free_blocks[4];
unsigned char s_root_block[4];
unsigned char s_journal_block[4];
unsigned char s_journal_dev[4];
unsigned char s_orig_journal_size[4];
unsigned char s_journal_trans_max[4];
unsigned char s_journal_block_count[4];
unsigned char s_journal_max_batch[4];
unsigned char s_journal_max_commit_age[4];
unsigned char s_journal_max_trans_age[4];
unsigned char s_blocksize[2];
unsigned char s_oid_maxsize[2];
unsigned char s_oid_cursize[2];
unsigned char s_state[2];
unsigned char s_magic[12];
};
#define REISERFS_SUPER_MAGIC_STRING "ReIsErFs"
#define REISER2FS_SUPER_MAGIC_STRING "ReIsEr2Fs"
#define REISERFS_DISK_OFFSET_IN_BYTES (64 * 1024)
/* the spot for the super in versions 3.5 - 3.5.10 (inclusive) */
#define REISERFS_OLD_DISK_OFFSET_IN_BYTES (8 * 1024)
#define _XIAFS_SUPER_MAGIC 0x012FD16D
struct xiafs_super_block {
unsigned char s_boot_segment[512]; /* 1st sector reserved for boot */
unsigned char s_dummy[60];
unsigned char s_magic[4];
};
#define xiafsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
/* From jj@sunsite.ms.mff.cuni.cz Mon Mar 23 15:19:05 1998 */
#define UFS_SUPER_MAGIC 0x00011954
struct ufs_super_block {
unsigned char s_dummy[0x55c];
unsigned char s_magic[4];
};
#define ufsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
/* From Richard.Russon@ait.co.uk Wed Feb 24 08:05:27 1999 */
#define NTFS_SUPER_MAGIC "NTFS"
struct ntfs_super_block {
unsigned char s_dummy[3];
unsigned char s_magic[4];
};
/* From inspection of a few FAT filesystems - aeb */
/* Unfortunately I find almost the same thing on an extended partition;
it looks like a primary has some directory entries where the extended
has a partition table: IO.SYS, MSDOS.SYS, WINBOOT.SYS */
struct fat_super_block {
unsigned char s_dummy[3];
unsigned char s_os[8]; /* "MSDOS5.0" or "MSWIN4.0" or "MSWIN4.1" */
/* mtools-3.9.4 writes "MTOOL394" */
unsigned char s_dummy2[32];
unsigned char s_label[11]; /* for DOS? */
unsigned char s_fs[8]; /* "FAT12 " or "FAT16 " or all zero */
/* OS/2 BM has "FAT " here. */
unsigned char s_dummy3[9];
unsigned char s_label2[11]; /* for Windows? */
unsigned char s_fs2[8]; /* garbage or "FAT32 " */
};
#define XFS_SUPER_MAGIC "XFSB"
struct xfs_super_block {
unsigned char s_magic[4];
unsigned char s_dummy[28];
unsigned char s_uuid[16];
unsigned char s_dummy2[60];
unsigned char s_fname[12];
};
#define CRAMFS_SUPER_MAGIC 0x28cd3d45
struct cramfs_super_block {
unsigned char s_magic[4];
unsigned char s_dummy[12];
unsigned char s_id[16];
};
#define cramfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
#define HFS_SUPER_MAGIC 0x4244
struct hfs_super_block {
unsigned char s_magic[2];
unsigned char s_dummy[18];
unsigned char s_blksize[4];
};
#define hfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8))
#define hfsblksize(s) ((unsigned int) s.s_blksize[0] + \
(((unsigned int) s.s_blksize[1]) << 8) + \
(((unsigned int) s.s_blksize[2]) << 16) + \
(((unsigned int) s.s_blksize[3]) << 24))
#define HPFS_SUPER_MAGIC 0xf995e849
struct hpfs_super_block {
unsigned char s_magic[4];
unsigned char s_magic2[4];
};
#define hpfsmagic(s) ((unsigned int) s.s_magic[0] + (((unsigned int) s.s_magic[1]) << 8) + \
(((unsigned int) s.s_magic[2]) << 16) + \
(((unsigned int) s.s_magic[3]) << 24))
struct adfs_super_block {
unsigned char s_dummy[448];
unsigned char s_blksize[1];
unsigned char s_dummy2[62];
unsigned char s_checksum[1];
};
#define adfsblksize(s) ((unsigned int) s.s_blksize[0])

View File

@@ -1,7 +1,9 @@
#!/bin/bash
#!/bin/bash --norc
# mkinitrd
#
# Copyright 2005 Red Hat, Inc.
#
# Written by Erik Troan <ewt@redhat.com>
#
# Contributors:
@@ -20,14 +22,17 @@
# Preston Brown <pbrown@redhat.com>
# Bill Nottingham <notting@redhat.com>
# Guillaume Cottenceau <gc@mandrakesoft.com>
# Peter Jones <pjones@redhat.com>
umask 0022
PATH=/sbin:/usr/sbin:/bin:/usr/bin:$PATH
export PATH
VERSION=3.5.14
VERSION=4.2.11
compress=1
allowmissing=""
target=""
kernel=""
force=""
@@ -36,18 +41,28 @@ MODULES=""
img_vers=""
builtins=""
pivot=1
squashfs=1
initramfs=""
modulefile=/etc/modules.conf
rc=0
IMAGESIZE=5120
IMAGESIZE=8000
PRESCSIMODS="scsi_mod sd_mod unknown"
fstab="/etc/fstab"
if [ -f /etc/udev/udev.conf ]; then
USE_UDEV="yes"
UDEV_TMPFS="yes"
UDEV_KEEP_DEV="yes"
. /etc/udev/udev.conf
[ -x /sbin/udev.static ] || USE_UDEV=
fi
usage () {
echo "usage: `basename $0` [--version] [-v] [-f] [--preload <module>]" >&2
echo " [--omit-scsi-modules] [--omit-raid-modules] [--omit-lvm-modules]" >&2
echo " [--with=<module>] [--image-version] [--fstab=<fstab>] [--nocompress]" >&2
echo " [--builtin=<module>] [--nopivot] <initrd-image> <kernel-version>" >&2
echo " [--builtin=<module>] [--nopivot] [--nosquashfs] <initrd-image> <kernel-version>" >&2
echo "" >&2
echo " (ex: `basename $0` /boot/initrd-2.2.5-15.img 2.2.5-15)" >&2
exit 1
@@ -61,11 +76,11 @@ moduledep() {
[ -n "$verbose" ] && echo -n "Looking for deps of module $1"
deps=$(gawk 'BEGIN { searched=ARGV[2]; ARGV[2]=""; rc=1 } \
function modname(filename) { match(filename, /\/([^\/]+)\.k?o/, ret); return ret[1] } \
function modname(filename) { match(filename, /\/([^\/]+)\.k?o:?$/, ret); return ret[1] } \
function show() { if (orig == searched) { print dep; orig=""; rc=0; exit } } \
/^\/lib/ { show(); \
orig=modname($1); \
if ($2) { dep=modname($2) } else { dep="" } } \
orig=modname($1); dep=""; \
if ($2) { for (i = 2; i <= NF; i++) { dep=sprintf("%s %s", dep, modname($i)); } } } \
/^ / { dep=sprintf("%s %s", dep, modname($1)); } \
END { show(); exit(rc) }' /lib/modules/$kernel/modules.dep $1)
[ -n "$verbose" ] && echo -e "\t$deps"
@@ -90,7 +105,7 @@ findmodule() {
modName=$(echo $modName | cut -b2-)
fi
if echo $builtins | grep -E -q '(^| )'$modName'( |$)' ; then
if echo $builtins | egrep -q '(^| )'$modName'( |$)' ; then
[ -n "$verbose" ] && echo "module $modName assumed to be built in"
set +x
return
@@ -99,7 +114,7 @@ findmodule() {
# special cases
if [ "$modName" = "i2o_block" ]; then
findmodule i2o_core
findmodule i2o_pci
findmodule -i2o_pci
modName="i2o_block"
elif [ "$modName" = "ppa" ]; then
findmodule parport
@@ -143,6 +158,11 @@ findmodule() {
return;
fi
done;
if [ -n "$allowmissing" ]; then
echo "WARNING: No module $modName found for kernel $kernel, continuing anyway" >&2
return
fi
echo "No module $modName found for kernel $kernel, aborting." >&2
exit 1
@@ -216,6 +236,10 @@ while [ $# -gt 0 ]; do
pivot=""
;;
--nosquashfs)
squashfs=""
;;
--ifneeded)
# legacy
;;
@@ -245,6 +269,12 @@ while [ $# -gt 0 ]; do
--image-version)
img_vers=yes
;;
--noudev)
USE_UDEV=
;;
--allow-missing)
allowmissing=yes
;;
*)
if [ -z "$target" ]; then
target=$1
@@ -282,6 +312,21 @@ if [ $UID != 0 ]; then
exit 1
fi
kernelmajor=`echo $kernel | cut -d . -f 1,2`
#if [ "$kernelmajor" == "2.4" ]; then
if [ -n "$verbose" ]; then echo "Creating old-style initrd"; fi
USE_UDEV=
#else
# if [ -n "$verbose" ]; then echo "Creating initramfs"; fi
# modulefile=/etc/modprobe.conf
# initramfs=1
# pivot=""
#fi
# if we're not using udev, don't set any of the other bits
[ -z "$USE_UDEV" ] && UDEV_TMPFS= && UDEV_KEEP_DEV=
# find a temporary directory which doesn't use tmpfs
TMPDIR=""
for t in /tmp /var/tmp /root ${PWD}; do
@@ -319,7 +364,7 @@ if [ -n "$withusb" ]; then
if [ `which kudzu 2>/dev/null` ]; then
host=$(kudzu --probe -b scsi |
gawk '/^device: '${dev}'/,/^host:/ { if (/^host/) { print $2; exit; } }')
if [ -d /proc/scsi/usb-storage-${host} ]; then
if [ -d /proc/scsi/usb-storage-${host} -o -f /proc/scsi/usb-storage/${host} ]; then
needusb=1
fi
fi
@@ -328,7 +373,7 @@ if [ -n "$withusb" ]; then
fi
if [ -n "$needusb" ]; then
drivers=$(gawk '/^alias usb-controller[0-9]* / { print $3}' < /etc/modules.conf)
drivers=$(gawk '/^alias[[:space:]]+usb-controller[0-9]* / { print $3}' < $modulefile)
if [ -n "$drivers" ]; then
for driver in $drivers; do
findmodule $driver
@@ -345,7 +390,7 @@ if [ -z "$noscsi" ]; then
fi
if [ -f $modulefile ]; then
scsimodules=`grep "alias[[:space:]]scsi_hostadapter" $modulefile | grep -v '^[ ]*#' | LC_ALL=C sort -u | gawk '{ print $3 }'`
scsimodules=`grep "alias[[:space:]]\+scsi_hostadapter" $modulefile | grep -v '^[ ]*#' | LC_ALL=C sort -u | gawk '{ print $3 }'`
if [ -n "$scsimodules" ]; then
for n in $PRESCSIMODS; do
@@ -371,9 +416,20 @@ fi
if [ -z "$nolvm" ]; then
if [ -f /proc/lvm/global ]; then
if grep -q '^VG:' /proc/lvm/global ; then
findmodule -lvm-mod
if [ "$kernelmajor" == "2.4" ]; then
findmodule -lvm-mod
else
findmodule -dm-mod
fi
fi
fi
if [ -x /sbin/dmsetup -a -e /dev/mapper/control ]; then
dmout=$(/sbin/dmsetup ls 2>/dev/null)
if [ "$dmout" != "No devices found" -a "$dmout" != "" ]; then
findmodule -dm-mod
fi
fi
fi
# If we have dasd devices, include the necessary modules (S/390)
@@ -395,7 +451,11 @@ if [ -z "$noraid" -a -f /proc/mdstat ]; then
findmodule linear
startraid=1
;;
raid[0145])
multipath)
findmodule multipath
startraid=1
;;
raid[01456])
findmodule $level
startraid=1
;;
@@ -415,9 +475,9 @@ fi
rootdev=$(gawk '/^[ \t]*[^#]/ { if ($2 == "/") { print $1; }}' $fstab)
if echo $rootdev | cut -d/ -f3 | grep -q loop ; then
key="^# $(echo $rootdev | cut -d/ -f3 | tr '[a-z]' '[A-Z]'):"
if ! grep "$key" $fstab > /dev/null; then
echo "The root filesystem is on a $rootdev, but there is no magic entry in $fstab" 1>&2
echo "for this device. Consult the mkinitrd man page for more information" 2>&2
if ! grep "$key" $fstab >> /dev/null; then
echo "The root filesystem is on a $rootdev, but there is no magic entry in $fstab" >&2
echo "for this device. Consult the mkinitrd man page for more information" >&2
exit 1
fi
@@ -433,19 +493,31 @@ if echo $rootdev | cut -d/ -f3 | grep -q loop ; then
basicmodules="$basicmodules -${loopFs}"
# check if the root fs is on a logical volume
elif ! echo $rootdev | cut -c1-6 |grep -q "LABEL=" ; then
root_vg=$(echo $rootdev | cut -d/ -f3)
rootdev=$(echo "readlink $rootdev" | /sbin/nash --quiet)
major=`ls -l $rootdev | sed -e "s/.* \\([0-9]\+\\), *[0-9]\+.*/\\1/"`
[ "$major" != "58" ] || root_lvm=1
if echo $rootdev |grep -q /dev/mapper 2>/dev/null ; then root_lvm=1 ; fi
fi
rootfs=$(gawk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $3; }}' $fstab)
rootopts=$(gawk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $4; }}' $fstab)
rootopts=$(gawk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $4; }}' $fstab \
| sed -e 's/\(^rw,\|rw,$\)//' -e 's/,rw,/,/' -e 's/^rw$/ro/')
# in case the root filesystem is modular
findmodule -${rootfs}
if [ -n "$root_lvm" ]; then
findmodule -lvm-mod
if [ "$kernelmajor" == "2.4" ]; then
findmodule -lvm-mod
else
findmodule -dm-mod
# DM requires all of these to be there in case someone used the
# feature. broken. (#132001)
findmodule -dm-mirror
findmodule -dm-zero
findmodule -dm-snapshot
fi
fi
for n in $basicmodules; do
@@ -459,60 +531,82 @@ fi
MNTIMAGE=`mktemp -d ${TMPDIR}/initrd.XXXXXX`
IMAGE=`mktemp ${TMPDIR}/initrd.img.XXXXXX`
MNTPOINT=`mktemp -d ${TMPDIR}/initrd.mnt.XXXXXX`
RCFILE=$MNTIMAGE/linuxrc
if [ -z "$initramfs" ]; then
MNTPOINT=`mktemp -d ${TMPDIR}/initrd.mnt.XXXXXX`
RCFILE=$MNTIMAGE/linuxrc
else
RCFILE=$MNTIMAGE/init
fi
if [ -z "$MNTIMAGE" -o -z "$IMAGE" -o -z "$MNTPOINT" ]; then
if [ -z "$MNTIMAGE" -o -z "$IMAGE" ]; then
echo "Error creating temporaries. Try again" >&2
exit 1
fi
dd if=/dev/zero of=$IMAGE bs=1k count=$IMAGESIZE 2> /dev/null || exit 1
if [ -z "$initramfs" ]; then
dd if=/dev/zero of=$IMAGE bs=1k count=$IMAGESIZE 2> /dev/null || exit 1
LODEV=$(echo findlodev | /sbin/nash --quiet)
LODEV=$(echo findlodev | /sbin/nash --quiet)
if [ -z "$LODEV" ]; then
if [ -z "$LODEV" ]; then
rm -rf $MNTIMAGE $MNTPOINT $IMAGE
echo "All of your loopback devices are in use." >&2
exit 1
fi
fi
losetup ${LODEV} $IMAGE || exit 1
losetup ${LODEV} $IMAGE || exit 1
# We have to "echo y |" so that it doesn't complain about $IMAGE not
# being a block device
echo y | mke2fs $LODEV $IMAGESIZE >/dev/null 2>/dev/null
tune2fs -i0 $LODEV >/dev/null
# We have to "echo y |" so that it doesn't complain about $IMAGE not
# being a block device
echo y | mkfs.minix -i 100 $LODEV $IMAGESIZE >/dev/null 2>/dev/null
if [ -n "$verbose" ]; then
echo "Using loopback device $LODEV"
fi
if [ -n "$verbose" ]; then
echo "Using loopback device $LODEV"
fi
mkdir -p $MNTPOINT
mount -t ext2 $LODEV $MNTPOINT || {
mkdir -p $MNTPOINT
mount -t minix $LODEV $MNTPOINT || {
echo "Can't get a loopback device"
exit 1
}
}
# We don't need this directory, so let's save space
rmdir $MNTPOINT/lost+found >/dev/null 2>&1
fi
mkdir -p $MNTIMAGE
mkdir -p $MNTIMAGE/lib
mkdir -p $MNTIMAGE/bin
mkdir -p $MNTIMAGE/etc
mkdir -p $MNTIMAGE/dev
mkdir -p $MNTIMAGE/hd
mkdir -p $MNTIMAGE/loopfs
mkdir -p $MNTIMAGE/proc
mkdir -p $MNTIMAGE/sys
mkdir -p $MNTIMAGE/sysroot
ln -s bin $MNTIMAGE/sbin
# We don't need this directory, so let's save space
rm -rf $MNTPOINT/lost+found
inst /sbin/nash "$MNTIMAGE/bin/nash"
inst /sbin/insmod.static "$MNTIMAGE/bin/insmod"
inst /bin/tar.static "$MNTIMAGE/bin/tar"
inst /usr/bin/lzmadec "$MNTIMAGE/bin/lzmadec"
inst /sbin/fsck.minix.static "$MNTIMAGE/bin/fsck.minix"
ln -s /sbin/nash $MNTIMAGE/sbin/modprobe
if [ -n "$USE_UDEV" ]; then
inst /sbin/udev.static $MNTIMAGE/sbin/udev
inst /sbin/udevstart.static $MNTIMAGE/sbin/udevstart
mkdir -p $MNTIMAGE/etc/udev
inst /etc/udev/udev.conf $MNTIMAGE/etc/udev/udev.conf
ln -s /sbin/nash $MNTIMAGE/sbin/hotplug
fi
for MODULE in $MODULES; do
cp $verbose -a /lib/modules/$kernel/$MODULE $MNTIMAGE/lib
if [ -x /usr/bin/strip ]; then
/usr/bin/strip -g $verbose /lib/modules/$kernel/$MODULE -o $MNTIMAGE/lib/$(basename $MODULE)
else
cp $verbose -a /lib/modules/$kernel/$MODULE $MNTIMAGE/lib
fi
done
# mknod'ing the devices instead of copying them works both with and
@@ -526,7 +620,7 @@ for i in 1 2 3 4; do
done
# FIXME -- this won't work if you're using devfs
if [ -n "$root_lvm" ]; then
if [ -n "$root_lvm" -a "$kernelmajor" == "2.4" ]; then
pvs=$(/sbin/pvscan | grep " PV " | gawk {'print $5;'} |sed 's/"//g')
for pv in $pvs; do
cp $verbose --parents -a $pv $MNTIMAGE/
@@ -539,9 +633,44 @@ if [ -n "$root_lvm" ]; then
mknod $MNTIMAGE/dev/lvm b 109 0
fi
echo "#!/bin/nash" > $RCFILE
if [ -n "$root_lvm" -a "$kernelmajor" == "2.6" ]; then
inst /sbin/lvm.static "$MNTIMAGE/bin/lvm"
if [ -f /etc/lvm/lvm.conf ]; then
cp $verbose --parents /etc/lvm/lvm.conf $MNTIMAGE/
fi
fi
echo "#!/bin/nash" >| $RCFILE
echo "" >> $RCFILE
echo "mount -t proc /proc /proc" >> $RCFILE
echo "setquiet" >> $RCFILE
echo "echo Mounted /proc filesystem" >> $RCFILE
if [ "$kernelmajor" != "2.4" ]; then
echo "echo Mounting sysfs" >> $RCFILE
echo "mount -t sysfs /sys /sys" >> $RCFILE
fi
if [ -n "$USE_UDEV" ]; then
if [ -n "$UDEV_TMPFS" ]; then
cat >> $RCFILE <<EOF
echo Creating /dev
mount -o mode=0755 -t tmpfs /dev /dev
mknod /dev/console c 5 1
mknod /dev/null c 1 3
mknod /dev/zero c 1 5
mkdir /dev/pts
mkdir /dev/shm
EOF
fi
cat >> $RCFILE <<EOF
echo Starting udev
/sbin/udevstart
echo -n "/sbin/hotplug" > /proc/sys/kernel/hotplug
EOF
fi
for MODULE in $MODULES; do
text=""
module=`echo $MODULE | sed "s|.*/||" | sed "s/.k\?o$//"`
@@ -561,12 +690,26 @@ for MODULE in $MODULES; do
# Hack - we need a delay after loading usb-storage to give things
# time to settle down before we start looking a block devices
if [ "$module" = "usb-storage" ]; then
echo "sleep 5" >> $RCFILE
echo "sleep 8" >> $RCFILE
fi
if [ "$module" = "zfcp" -a -f /etc/zfcp.conf ]; then
echo "sleep 2" >> $RCFILE
cat /etc/zfcp.conf | grep -v "^#" | tr "A-Z" "a-z" | while read DEVICE SCSIID WWPN SCSILUN FCPLUN; do
echo "echo -n $WWPN > /sys/bus/ccw/drivers/zfcp/${DEVICE/0x/}/port_add" >>$RCFILE
echo "echo -n $FCPLUN > /sys/bus/ccw/drivers/zfcp/${DEVICE/0x/}/$WWPN/unit_add" >>$RCFILE
echo "echo -n 1 > /sys/bus/ccw/drivers/zfcp/${DEVICE/0x/}/online" >>$RCFILE
done
fi
done
echo "echo Mounting /proc filesystem" >> $RCFILE
echo "mount -t proc /proc /proc" >> $RCFILE
# HACK: module loading + device creation isn't necessarily synchronous...
# this will make sure that we have all of our devices before trying
# things like RAID or LVM
if [ -n "$USE_UDEV" ]; then
echo "/sbin/udevstart" >> $RCFILE
fi
echo "sleep 2" >> $RCFILE
if [ -n "$startraid" ]; then
for dev in $raiddevices; do
@@ -575,8 +718,12 @@ if [ -n "$startraid" ]; then
done
fi
echo "echo Creating block devices" >> $RCFILE
echo "mkdevices /dev" >> $RCFILE
if [ -z "$USE_UDEV" ]; then
echo "echo Creating block devices" >> $RCFILE
echo "mkdevices /dev" >> $RCFILE
fi
echo "mknod /dev/loop0 b 7 0" >> $RCFILE
if [ -n "$loopDev" ]; then
mkdir /initrd
@@ -587,40 +734,91 @@ if [ -n "$loopDev" ]; then
echo "echo Setting up loopback device $rootdev" >> $RCFILE
echo "losetup $rootdev /loopfs$loopFile" >> $RCFILE
elif [ -n "$root_lvm" ]; then
if [ "$kernelmajor" == "2.4" ]; then
echo "echo Scanning logical volumes" >> $RCFILE
echo "vgscan" >> $RCFILE
echo "echo Activating logical volumes" >> $RCFILE
echo "vgchange -ay" >> $RCFILE
else
echo "echo Creating root device" >> $RCFILE
echo "mkrootdev /dev/root" >> $RCFILE
rootdev=/dev/root
else
echo "echo Making device-mapper control node" >> $RCFILE
echo "mkdmnod" >> $RCFILE
echo "echo Scanning logical volumes" >> $RCFILE
echo "lvm vgscan --ignorelockingfailure" >> $RCFILE
echo "echo Activating logical volumes" >> $RCFILE
echo "lvm vgchange -ay --ignorelockingfailure $root_vg" >> $RCFILE
fi
fi
if [ -n "$pivot" ]; then
echo "echo Creating root device" >> $RCFILE
echo "mkrootdev /dev/root" >> $RCFILE
rootdev=/dev/root
if [ -n "$initramfs" ]; then
echo "echo Mounting root filesystem" >> $RCFILE
if [ -n "$squashfs" ]; then
echo "mount -o $rootopts --ro -t $rootfs $rootdev /sysroot" >> $RCFILE
else
echo "fsck.minix $rootdev" >> $RCFILE
echo "mount -o $rootopts -t minix $rootdev /hd" >> $RCFILE
echo "losetup /dev/loop0 /hd/ipcop-1.5.0a1.squashfs" >> $RCFILE
echo "mount --ro -t squashfs /dev/loop0 /sysroot" >> $RCFILE
echo "mount -t tmpfs none /sysroot/var" >> $RCFILE
echo "echo Unpacking IPCop configuration.. Please wait.." >> $RCFILE
echo "tar -C /sysroot -xjf /hd/ipcop.tbz2" >> $RCFILE
fi
echo "echo Switching to new root" >> $RCFILE
if [ -n "$UDEV_KEEP_DEV" ]; then
echo "switchroot --movedev /sysroot" >> $RCFILE
else
echo "switchroot /sysroot" >> $RCFILE
fi
else
if [ "$kernelmajor" != "2.4" ]; then
echo "umount /sys" >> $RCFILE
fi
if [ -n "$pivot" ]; then
echo "echo 0x0100 > /proc/sys/kernel/real-root-dev" >> $RCFILE
echo "echo Mounting root filesystem" >> $RCFILE
echo "mount -o $rootopts --ro -t $rootfs $rootdev /sysroot" >> $RCFILE
if [ -n "$squashfs" ]; then
echo "mount -o $rootopts --ro -t $rootfs $rootdev /sysroot" >> $RCFILE
else
echo "fsck.minix $rootdev" >> $RCFILE
echo "mount -o $rootopts -t minix $rootdev /hd" >> $RCFILE
echo "losetup /dev/loop0 /hd/ipcop-1.5.0a1.squashfs" >> $RCFILE
echo "mount --ro -t squashfs /dev/loop0 /sysroot" >> $RCFILE
echo "mount -t tmpfs none /sysroot/var" >> $RCFILE
echo "echo Unpacking IPCop configuration.. Please wait.." >> $RCFILE
echo "tar -C /sysroot -xjf /hd/ipcop.tbz2" >> $RCFILE
fi
echo "pivot_root /sysroot /sysroot/initrd" >> $RCFILE
echo "umount /initrd/proc" >> $RCFILE
else
else
echo "umount /proc" >> $RCFILE
fi
fi
[ -n "$UDEV_TMPFS" ] && echo "umount /initrd/dev" >> $RCFILE
fi
chmod +x $RCFILE
(cd $MNTIMAGE; tar cf - .) | (cd $MNTPOINT; tar xf -) || exit 1
if [ -z "$initramfs" ]; then
(cd $MNTIMAGE; tar cf - .) | (cd $MNTPOINT; tar xf -) || exit 1
umount $MNTPOINT
losetup -d $LODEV
umount $MNTPOINT
losetup -d $LODEV
else
(cd $MNTIMAGE; find . | cpio --quiet -c -o) >| $IMAGE || exit 1
fi
if [ -n "$compress" ]; then
gzip -9 < $IMAGE > $target || rc=1
gzip -9 < $IMAGE >| $target || rc=1
else
cp -a $IMAGE $target || rc=1
fi
rm -rf $MNTIMAGE $MNTPOINT $IMAGE
rm -rf $MNTIMAGE $IMAGE
if [ -n "$MNTPOINT" ]; then rm -rf $MNTPOINT ; fi
exit $rc

View File

@@ -1,300 +1,300 @@
/*
* taken from util-linux 2.11g and hacked into nash
*
* mount_by_label.c - aeb
*
* 1999-02-22 Arkadiusz Mi<4D>kiewicz <misiek@pld.ORG.PL>
* - added Native Language Support
* 2000-01-20 James Antill <james@and.org>
* - Added error message if /proc/partitions cannot be opened
* 2000-05-09 Erik Troan <ewt@redhat.com>
* - Added cache for UUID and disk labels
* 2000-11-07 Nathan Scott <nathans@sgi.com>
* - Added XFS support
*/
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <fcntl.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
#include "linux_fs.h"
#include "mount_by_label.h"
#define PROC_PARTITIONS "/proc/partitions"
#define DEVLABELDIR "/dev"
#define _(str) (str)
static struct uuidCache_s {
struct uuidCache_s *next;
char uuid[16];
char *device;
char *label;
int major, minor;
} *uuidCache = NULL;
/* for now, only ext2, ext3 and xfs are supported */
static int
get_label_uuid(const char *device, char **label, char *uuid) {
/* start with ext2/3 and xfs tests, taken from mount_guess_fstype */
/* should merge these later */
int fd;
int rv = 1;
size_t namesize;
struct ext2_super_block e2sb;
struct xfs_super_block xfsb;
fd = open(device, O_RDONLY);
if (fd < 0)
return rv;
if (lseek(fd, 1024, SEEK_SET) == 1024
&& read(fd, (char *) &e2sb, sizeof(e2sb)) == sizeof(e2sb)
&& (ext2magic(e2sb) == EXT2_SUPER_MAGIC)) {
memcpy(uuid, e2sb.s_uuid, sizeof(e2sb.s_uuid));
namesize = sizeof(e2sb.s_volume_name);
if ((*label = calloc(namesize + 1, 1)) != NULL)
memcpy(*label, e2sb.s_volume_name, namesize);
rv = 0;
}
else if (lseek(fd, 0, SEEK_SET) == 0
&& read(fd, (char *) &xfsb, sizeof(xfsb)) == sizeof(xfsb)
&& (strncmp(xfsb.s_magic, XFS_SUPER_MAGIC, 4) == 0)) {
memcpy(uuid, xfsb.s_uuid, sizeof(xfsb.s_uuid));
namesize = sizeof(xfsb.s_fname);
if ((*label = calloc(namesize + 1, 1)) != NULL)
memcpy(*label, xfsb.s_fname, namesize);
rv = 0;
}
close(fd);
return rv;
}
static void
uuidcache_addentry(char * device, int major, int minor, char *label, char *uuid) {
struct uuidCache_s *last;
if (!uuidCache) {
last = uuidCache = malloc(sizeof(*uuidCache));
} else {
for (last = uuidCache; last->next; last = last->next) ;
last->next = malloc(sizeof(*uuidCache));
last = last->next;
}
last->next = NULL;
last->label = label;
last->device = device;
last->major = major;
last->minor = minor;
memcpy(last->uuid, uuid, sizeof(last->uuid));
}
static void
uuidcache_init(void) {
char line[100];
char *s;
int ma, mi, sz;
static char ptname[100];
FILE *procpt;
char uuid[16], *label;
char device[110];
int firstPass;
int handleOnFirst;
char * chptr, * endptr;
if (uuidCache)
return;
procpt = fopen(PROC_PARTITIONS, "r");
if (!procpt) {
static int warn = 0;
if (!warn++)
fprintf (stderr, _("mount: could not open %s, so UUID and LABEL "
"conversion cannot be done.\n"),
PROC_PARTITIONS);
return;
}
for (firstPass = 1; firstPass >= 0; firstPass--) {
fseek(procpt, 0, SEEK_SET);
while (fgets(line, sizeof(line), procpt)) {
/* The original version of this code used sscanf, but
diet's sscanf is quite limited */
chptr = line;
if (*chptr++ != ' ') continue;
ma = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
mi = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
sz = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
while (!isspace(*endptr) && *endptr != '\n') endptr++;
if (chptr == endptr) continue;
strncpy(ptname, chptr, endptr - chptr);
ptname[endptr - chptr] = '\0';
/* skip extended partitions (heuristic: size 1) */
if (sz == 1)
continue;
/* look only at md devices on first pass */
handleOnFirst = !strncmp(ptname, "md", 2);
if (firstPass != handleOnFirst)
continue;
/* skip entire disk (minor 0, 64, ... on ide;
0, 16, ... on sd) */
/* heuristic: partition name ends in a digit */
for(s = ptname; *s; s++);
if (isdigit(s[-1])) {
char * ptr;
char * deviceDir;
int mustRemove = 0;
int mustRemoveDir = 0;
int i;
sprintf(device, "%s/%s", DEVLABELDIR, ptname);
if (access(device, F_OK)) {
ptr = device;
i = 0;
while (*ptr)
if (*ptr++ == '/')
i++;
if (i > 2) {
deviceDir = alloca(strlen(device) + 1);
strcpy(deviceDir, device);
ptr = deviceDir + (strlen(device) - 1);
while (*ptr != '/')
*ptr-- = '\0';
if (mkdir(deviceDir, 0644)) {
printf("mkdir: cannot create directory %s: %d\n", deviceDir, errno);
} else {
mustRemoveDir = 1;
}
}
mknod(device, S_IFBLK | 0600, makedev(ma, mi));
mustRemove = 1;
}
if (!get_label_uuid(device, &label, uuid))
uuidcache_addentry(strdup(device), ma, mi,
label, uuid);
if (mustRemove) unlink(device);
if (mustRemoveDir) rmdir(deviceDir);
}
}
}
fclose(procpt);
}
#define UUID 1
#define VOL 2
static char *
get_spec_by_x(int n, const char *t, int * majorPtr, int * minorPtr) {
struct uuidCache_s *uc;
uuidcache_init();
uc = uuidCache;
while(uc) {
switch (n) {
case UUID:
if (!memcmp(t, uc->uuid, sizeof(uc->uuid))) {
*majorPtr = uc->major;
*minorPtr = uc->minor;
return uc->device;
}
break;
case VOL:
if (!strcmp(t, uc->label)) {
*majorPtr = uc->major;
*minorPtr = uc->minor;
return uc->device;
}
break;
}
uc = uc->next;
}
return NULL;
}
static unsigned char
fromhex(char c) {
if (isdigit(c))
return (c - '0');
else if (islower(c))
return (c - 'a' + 10);
else
return (c - 'A' + 10);
}
char *
get_spec_by_uuid(const char *s, int * major, int * minor) {
unsigned char uuid[16];
int i;
if (strlen(s) != 36 ||
s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-')
goto bad_uuid;
for (i=0; i<16; i++) {
if (*s == '-') s++;
if (!isxdigit(s[0]) || !isxdigit(s[1]))
goto bad_uuid;
uuid[i] = ((fromhex(s[0])<<4) | fromhex(s[1]));
s += 2;
}
return get_spec_by_x(UUID, uuid, major, minor);
bad_uuid:
fprintf(stderr, _("mount: bad UUID"));
return 0;
}
char *
get_spec_by_volume_label(const char *s, int * major, int * minor) {
return get_spec_by_x(VOL, s, major, minor);
}
int display_uuid_cache(void) {
struct uuidCache_s * u;
int i;
uuidcache_init();
u = uuidCache;
while (u) {
printf("%s %s ", u->device, u->label);
for (i = 0; i < sizeof(u->uuid); i++) {
if (i == 4 || i == 6 || i == 8 || i == 10)
printf("-");
printf("%x", u->uuid[i] & 0xff);
}
printf("\n");
u = u->next;
}
return 0;
}
/*
* taken from util-linux 2.11g and hacked into nash
*
* mount_by_label.c - aeb
*
* 1999-02-22 Arkadiusz Mi<4D>kiewicz <misiek@pld.ORG.PL>
* - added Native Language Support
* 2000-01-20 James Antill <james@and.org>
* - Added error message if /proc/partitions cannot be opened
* 2000-05-09 Erik Troan <ewt@redhat.com>
* - Added cache for UUID and disk labels
* 2000-11-07 Nathan Scott <nathans@sgi.com>
* - Added XFS support
*/
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <fcntl.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
#include "linux_fs.h"
#include "mount_by_label.h"
#define PROC_PARTITIONS "/proc/partitions"
#define DEVLABELDIR "/dev"
#define _(str) (str)
static struct uuidCache_s {
struct uuidCache_s *next;
char uuid[16];
char *device;
char *label;
int major, minor;
} *uuidCache = NULL;
/* for now, only ext2, ext3 and xfs are supported */
static int
get_label_uuid(const char *device, char **label, char *uuid) {
/* start with ext2/3 and xfs tests, taken from mount_guess_fstype */
/* should merge these later */
int fd;
int rv = 1;
size_t namesize;
struct ext2_super_block e2sb;
struct xfs_super_block xfsb;
fd = open(device, O_RDONLY);
if (fd < 0)
return rv;
if (lseek(fd, 1024, SEEK_SET) == 1024
&& read(fd, (char *) &e2sb, sizeof(e2sb)) == sizeof(e2sb)
&& (ext2magic(e2sb) == EXT2_SUPER_MAGIC)) {
memcpy(uuid, e2sb.s_uuid, sizeof(e2sb.s_uuid));
namesize = sizeof(e2sb.s_volume_name);
if ((*label = calloc(namesize + 1, 1)) != NULL)
memcpy(*label, e2sb.s_volume_name, namesize);
rv = 0;
}
else if (lseek(fd, 0, SEEK_SET) == 0
&& read(fd, (char *) &xfsb, sizeof(xfsb)) == sizeof(xfsb)
&& (strncmp((char *)xfsb.s_magic, XFS_SUPER_MAGIC, 4) == 0)) {
memcpy(uuid, xfsb.s_uuid, sizeof(xfsb.s_uuid));
namesize = sizeof(xfsb.s_fname);
if ((*label = calloc(namesize + 1, 1)) != NULL)
memcpy(*label, xfsb.s_fname, namesize);
rv = 0;
}
close(fd);
return rv;
}
static void
uuidcache_addentry(char * device, int major, int minor, char *label, char *uuid) {
struct uuidCache_s *last;
if (!uuidCache) {
last = uuidCache = malloc(sizeof(*uuidCache));
} else {
for (last = uuidCache; last->next; last = last->next) ;
last->next = malloc(sizeof(*uuidCache));
last = last->next;
}
last->next = NULL;
last->label = label;
last->device = device;
last->major = major;
last->minor = minor;
memcpy(last->uuid, uuid, sizeof(last->uuid));
}
static void
uuidcache_init(void) {
char line[100];
char *s;
int ma, mi, sz;
static char ptname[100];
FILE *procpt;
char uuid[16], *label;
char device[110];
int firstPass;
int handleOnFirst;
char * chptr, * endptr;
if (uuidCache)
return;
procpt = fopen(PROC_PARTITIONS, "r");
if (!procpt) {
static int warn = 0;
if (!warn++)
fprintf (stderr, _("mount: could not open %s, so UUID and LABEL "
"conversion cannot be done.\n"),
PROC_PARTITIONS);
return;
}
for (firstPass = 1; firstPass >= 0; firstPass--) {
fseek(procpt, 0, SEEK_SET);
while (fgets(line, sizeof(line), procpt)) {
/* The original version of this code used sscanf, but
diet's sscanf is quite limited */
chptr = line;
if (*chptr++ != ' ') continue;
ma = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
mi = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
sz = strtol(chptr, &endptr, 0);
if (endptr == chptr) continue;
while (isspace(*endptr)) endptr++;
chptr = endptr;
while (!isspace(*endptr) && *endptr != '\n') endptr++;
if (chptr == endptr) continue;
strncpy(ptname, chptr, endptr - chptr);
ptname[endptr - chptr] = '\0';
/* skip extended partitions (heuristic: size 1) */
if (sz == 1)
continue;
/* look only at md devices on first pass */
handleOnFirst = !strncmp(ptname, "md", 2);
if (firstPass != handleOnFirst)
continue;
/* skip entire disk (minor 0, 64, ... on ide;
0, 16, ... on sd) */
/* heuristic: partition name ends in a digit */
for(s = ptname; *s; s++);
if (isdigit(s[-1])) {
char * ptr;
char * deviceDir = NULL;
int mustRemove = 0;
int mustRemoveDir = 0;
int i;
sprintf(device, "%s/%s", DEVLABELDIR, ptname);
if (access(device, F_OK)) {
ptr = device;
i = 0;
while (*ptr)
if (*ptr++ == '/')
i++;
if (i > 2) {
deviceDir = alloca(strlen(device) + 1);
strcpy(deviceDir, device);
ptr = deviceDir + (strlen(device) - 1);
while (*ptr != '/')
*ptr-- = '\0';
if (mkdir(deviceDir, 0644)) {
printf("mkdir: cannot create directory %s: %d\n", deviceDir, errno);
} else {
mustRemoveDir = 1;
}
}
mknod(device, S_IFBLK | 0600, makedev(ma, mi));
mustRemove = 1;
}
if (!get_label_uuid(device, &label, uuid))
uuidcache_addentry(strdup(device), ma, mi,
label, uuid);
if (mustRemove) unlink(device);
if (mustRemoveDir) rmdir(deviceDir);
}
}
}
fclose(procpt);
}
#define UUID 1
#define VOL 2
static char *
get_spec_by_x(int n, const char *t, int * majorPtr, int * minorPtr) {
struct uuidCache_s *uc;
uuidcache_init();
uc = uuidCache;
while(uc) {
switch (n) {
case UUID:
if (!memcmp(t, uc->uuid, sizeof(uc->uuid))) {
*majorPtr = uc->major;
*minorPtr = uc->minor;
return uc->device;
}
break;
case VOL:
if (!strcmp(t, uc->label)) {
*majorPtr = uc->major;
*minorPtr = uc->minor;
return uc->device;
}
break;
}
uc = uc->next;
}
return NULL;
}
static unsigned char
fromhex(char c) {
if (isdigit(c))
return (c - '0');
else if (islower(c))
return (c - 'a' + 10);
else
return (c - 'A' + 10);
}
char *
get_spec_by_uuid(const char *s, int * major, int * minor) {
unsigned char uuid[16];
int i;
if (strlen(s) != 36 ||
s[8] != '-' || s[13] != '-' || s[18] != '-' || s[23] != '-')
goto bad_uuid;
for (i=0; i<16; i++) {
if (*s == '-') s++;
if (!isxdigit(s[0]) || !isxdigit(s[1]))
goto bad_uuid;
uuid[i] = ((fromhex(s[0])<<4) | fromhex(s[1]));
s += 2;
}
return get_spec_by_x(UUID, (char *)uuid, major, minor);
bad_uuid:
fprintf(stderr, _("mount: bad UUID"));
return 0;
}
char *
get_spec_by_volume_label(const char *s, int * major, int * minor) {
return get_spec_by_x(VOL, s, major, minor);
}
int display_uuid_cache(void) {
struct uuidCache_s * u;
size_t i;
uuidcache_init();
u = uuidCache;
while (u) {
printf("%s %s ", u->device, u->label);
for (i = 0; i < sizeof(u->uuid); i++) {
if (i == 4 || i == 6 || i == 8 || i == 10)
printf("-");
printf("%x", u->uuid[i] & 0xff);
}
printf("\n");
u = u->next;
}
return 0;
}

View File

@@ -1,2 +1,2 @@
char * get_spec_by_uuid(const char *uuid, int * major, int * minor);
char * get_spec_by_volume_label(const char *volumelabel, int * major, int * minor);
char * get_spec_by_uuid(const char *uuid, int * major, int * minor);
char * get_spec_by_volume_label(const char *volumelabel, int * major, int * minor);

139
src/nash/name_to_dev_t.c Normal file
View File

@@ -0,0 +1,139 @@
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <ctype.h>
#include <stdio.h>
#include <fcntl.h>
static dev_t try_name(char *name, int part)
{
char path[64];
char buf[32];
int range;
dev_t res;
char *s;
int len;
int fd;
unsigned int maj, min;
/* read device number from .../dev */
sprintf(path, "/sys/block/%s/dev", name);
fd = open(path, O_RDONLY);
if (fd < 0)
goto fail;
len = read(fd, buf, 32);
close(fd);
if (len <= 0 || len == 32 || buf[len - 1] != '\n')
goto fail;
buf[len - 1] = '\0';
if (sscanf(buf, "%u:%u", &maj, &min) != 2)
goto fail;
res = makedev(maj, min);
if (maj != major(res) || min != minor(res))
goto fail;
/* if it's there and we are not looking for a partition - that's it */
if (!part)
return res;
/* otherwise read range from .../range */
snprintf(path, 64, "/sys/block/%s/range", name);
fd = open(path, O_RDONLY);
if (fd < 0)
goto fail;
len = read(fd, buf, 32);
close(fd);
if (len <= 0 || len == 32 || buf[len - 1] != '\n')
goto fail;
buf[len - 1] = '\0';
range = strtoul(buf, &s, 10);
if (*s)
goto fail;
/* if partition is within range - we got it */
if (part < range)
return res + part;
fail:
return 0;
}
/*
* Convert a name into device number. We accept the following variants:
*
* 1) device number in hexadecimal represents itself
* 2) /dev/nfs represents Root_NFS (0xff)
* 3) /dev/<disk_name> represents the device number of disk
* 4) /dev/<disk_name><decimal> represents the device number
* of partition - device number of disk plus the partition number
* 5) /dev/<disk_name>p<decimal> - same as the above, that form is
* used when disk name of partitioned disk ends on a digit.
*
* If name doesn't have fall into the categories above, we return 0.
* sysfs is used to check if something is a disk name - it has
* all known disks under bus/block/devices. If the disk name
* contains slashes, name of driverfs node has them replaced with
* bangs. try_name() does the actual checks, assuming that sysfs
* is mounted on /sys.
*
* Note that cases (1) and (2) are already handled by the kernel,
* so we can ifdef them out, provided that we check real-root-dev
* first.
*/
dev_t name_to_dev_t(char *name)
{
char s[32];
char *p;
dev_t res = 0;
int part;
if (strncmp(name, "/dev/", 5) != 0) {
#if 1 /* kernel used to do this */
unsigned maj, min;
if (sscanf(name, "%u:%u", &maj, &min) == 2) {
res = makedev(maj, min);
if (maj != major(res) || min != minor(res))
return 0;
} else {
res = strtoul(name, &p, 16);
if (*p)
return 0;
}
#endif
return res;
}
name += 5;
#if 1 /* kernel used to do this */
if (strcmp(name, "nfs") == 0)
return makedev(0, 255);
#endif
if (strlen(name) > 31)
return 0;
strcpy(s, name);
for (p = s; *p; p++)
if (*p == '/')
*p = '!';
res = try_name(s, 0);
if (res)
return res;
while (p > s && isdigit(p[-1]))
p--;
if (p == s || !*p || *p == '0')
return 0;
part = strtoul(p, NULL, 10);
*p = '\0';
res = try_name(s, part);
if (res)
return res;
if (p < s + 2 || !isdigit(p[-2]) || p[-1] != 'p')
return 0;
p[-1] = '\0';
return try_name(s, part);
}

View File

@@ -1,5 +1,4 @@
.TH NASH 8 "Sat Mar 27 1999"
.UC 4
.TH NASH 8 "Mon Aug 02 2004"
.SH NAME
nash \- script interpretor to interpret linuxrc images
.SH SYNOPSIS
@@ -69,6 +68,12 @@ Creates a device inode for \fIpath\fR. This is identical to \fBmkdev\fR(1)
which the exceptions that it will not create named pipes and if the directories
in \fIpath\fR do not exist they will be automatically created.
.TP
\fBmkdmnod\fR
Creates a device inode for the device mapper control inode as
\fI/dev/mapper/control\fR. If it already exists with the correct
major/minor, it will not be recreated.
.TP
\fBmkrootdev \fIpath\fR
Makes \fIpath\fR a block inode for the device which should be mounted
@@ -93,15 +98,33 @@ The \fBdefaults\fR mount option is silently ignored.
Makes the filesystem mounted at \fInewrootpath\fR the new root filesystem,
and mounts the current root filesystem as \fIoldrootpath\fR.
.TP
\fBreadlink \fIpath\fR
Displays the value of the symbolic link \fIpath\fR.
.TP
\fBraidautorun \fImddevice\fR
Runs raid autodetection on all raid-typed partitions. \fImddevice\fR must
be a raid device (any will do).
.TP
\fBsetquiet\fR
Cause any later echos in this script to not be displayed.
.TP
\fBshowlabels\fR
Display a table of devices, their filesystem labels, and their uuids.
.TP
\fBsleep \fInum\fR
Sleep for \fInum\fR seconds
.TP
\fBswitchroot \fInewrootpath\fR
Makes the filesystem mounted at \fInewrootpath\fR the new root
filesystem by moving the mountpoint. This will only work in 2.6 or
later kernels.
.TP
\fBumount \fIpath\fR
Unmounts the filesystem mounted at \fIpath\fR.

File diff suppressed because it is too large Load Diff