mirror of
https://github.com/vincentmli/bpfire.git
synced 2026-04-09 18:45:54 +02:00
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:
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
#
|
||||
|
||||
27
config/rootfiles/common/GD-Graph
Normal file
27
config/rootfiles/common/GD-Graph
Normal 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
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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 " </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'> </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'> </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'> </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> </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'}: <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'}: <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'} <img src='/blob.gif' alt='*' /></td>
|
||||
<td width='25%'><input type='text' name='SERVICENAME' value='$pppsettings{'SERVICENAME'}' /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </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> </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> </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'} <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> </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> </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> </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> </td>
|
||||
<td colspan='4'><hr /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </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'> </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'> </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> </td>
|
||||
<td> </td>
|
||||
<td><input type='radio' name='METHOD' value='PPPOE_PLUGIN' $checked{'METHOD'}{'PPPOE_PLUGIN'} />PPPoE plugin</td>
|
||||
<td align='right'>$Lang::tr{'service name'} <img src='/blob.gif' alt='*' /></td>
|
||||
<td><input type='text' name='SERVICENAME' value='$pppsettings{'SERVICENAME'}' /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </td>
|
||||
<td> </td>
|
||||
<td><input type='radio' name='METHOD' value='PPPOE' $checked{'METHOD'}{'PPPOE'} />$Lang::tr{'pppoe'}</td>
|
||||
<td align='right'>$Lang::tr{'concentrator name'} <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'> </td>
|
||||
<td colspan='3'><hr /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </td>
|
||||
<td> </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> </td>
|
||||
<td> </td>
|
||||
<td align='right'>$Lang::tr{'gateway ip'}:</td>
|
||||
<td><input type='text' size='16' name='GATEWAY' value='$pppsettings{'GATEWAY'}' /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </td>
|
||||
<td> </td>
|
||||
<td align='right'>$Lang::tr{'netmask'}:</td>
|
||||
<td><input type='text' size='16' name='NETMASK' value='$pppsettings{'NETMASK'}' /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </td>
|
||||
<td> </td>
|
||||
<td align='right' nowrap='nowrap'>$Lang::tr{'broadcast'}: <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'> </td>
|
||||
<td colspan='3'><hr /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td> </td>
|
||||
<td> </td>
|
||||
<td><input type='radio' name='METHOD' value='DHCP' $checked{'METHOD'}{'DHCP'} />$Lang::tr{'dhcp mode'}</td>
|
||||
<td align='right'>$Lang::tr{'hostname'}: <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> </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'> </td></tr>\n";
|
||||
} else {
|
||||
print "<td>$Lang::tr{'not present'}</td><td colspan='3'> </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'> </td></tr>\n";
|
||||
} else {
|
||||
print "<td>$Lang::tr{'not present'}</td><td colspan='3'> </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'> </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'> </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'} <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'} <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> </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='*' /> $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='*' /> $Lang::tr{'this field may be blank'}</td>
|
||||
</tr>
|
||||
</table>
|
||||
END
|
||||
|
||||
79
lfs/GD-Graph
Normal file
79
lfs/GD-Graph
Normal 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)
|
||||
14
lfs/initrd
14
lfs/initrd
@@ -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/
|
||||
|
||||
1
make.sh
1
make.sh
@@ -393,6 +393,7 @@ buildipfire() {
|
||||
ipfiremake ez-ipupdate
|
||||
ipfiremake fcron
|
||||
ipfiremake GD
|
||||
ipfiremake GD-Graph
|
||||
ipfiremake gnupg
|
||||
ipfiremake hdparm
|
||||
ipfiremake ibod
|
||||
|
||||
@@ -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");
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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])
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
|
||||
@@ -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
139
src/nash/name_to_dev_t.c
Normal 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);
|
||||
}
|
||||
@@ -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.
|
||||
|
||||
2942
src/nash/nash.c
2942
src/nash/nash.c
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user