home *** CD-ROM | disk | FTP | other *** search
/ PC World 1999 August / PCWorld_1999-08_cd.bin / doc / FAQ / txt / Linux-FAQ < prev    next >
Text File  |  1999-04-09  |  122KB  |  2,975 lines

  1.                  Linux Frequently Asked Questions with Answers
  2.                                        
  3.  
  4.    October 4, 1998
  5.    
  6.    This is the list of Frequently Asked Questions for Linux, the free
  7.    Unix for just about every computer hardware platform on the planet.
  8.    Originally written for 386/486/586 Intel/ISA bus machines, versions
  9.    exist for Alpha, MIPS, ARM, 680x0, and PPC processors, and many
  10.    others. (See the question, "What is Linux? " below.) This
  11.    document should be read in conjunction with the Linux Documentation
  12.    Project's HOWTO series. ("Where can I get Linux material by FTP?
  13.    " and, "Where can I get the HOWTO's and other documentation? ")
  14.    The INFO-SHEET and META-FAQ, which are found in the same place, als
  15.    list sources of Linux information. Please look at these documents,
  16.    and, "You still haven't answered my question! " before posting
  17.    to a Usenet news group. You can also get Postscript, HTML, SGML, an
  18.    plain ASCII versions of this document. ("Formats in which this
  19.    FAQ is available. ")
  20.    
  21. 1. Introduction and General Information 
  22.  
  23.      * 1.1 What is Linux? 
  24.      * 1.2 Where do I start? 
  25.      * 1.3 What software does Linux support? 
  26.      * 1.4 Does Linux run on my computer? What hardware is supported?
  27.      * 1.5 What ports to other processors are there? 
  28.      * 1.6 How much hard disk space does Linux need? 
  29.      * 1.7 How much memory does Linux need? 
  30.      * 1.8 How much memory can Linux use? 
  31.      * 1.9 Is Linux public domain? Copyrighted? 
  32.        
  33. 2. Network sources and resources. 
  34.  
  35.      * 2.1 Where can I get the HOWTO's and other documentation? 
  36.      * 2.2 Where should I look on the World Wide Web for Linux stuff?
  37.      * 2.3 What newsgroups are there for Linux? 
  38.      * 2.4 Where can I find out about Linux and the Millennium (Y2K)
  39.        bug? 
  40.      * 2.5 Where can I get Linux material by FTP? 
  41.      * 2.6 I don't have FTP access. Where do I get Linux? 
  42.      * 2.7 I don't have Usenet access. Where do I get information? 
  43.      * 2.8 What mailing lists are there? 
  44.      * 2.9 Are the newsgroups archived anywhere? 
  45.        
  46. 3. Compatibility with other operating systems. 
  47.  
  48.      * 3.1 Can Linux share my disk with DOS? OS/2? 386BSD? Win95? 
  49.      * 3.2 How do I access files on my DOS partition or floppy? 
  50.      * 3.3 Does Linux support compressed ext2 file systems? 
  51.      * 3.4 Can I use my Stacked/DBLSPC/etc. DOS drive? 
  52.      * 3.5 Can I access OS/2 HPFS partitions from Linux? 
  53.      * 3.6 Can Linux access Amiga file systems? 
  54.      * 3.7 Can Linux access BSD, SysV, etc. UFS? 
  55.      * 3.8 Can Linux access SMB file systems? 
  56.      * 3.9 Can Linux access Macintosh file systems? 
  57.      * 3.10 Can I run Microsoft Windows programs under Linux? 
  58.      * 3.11 How can I boot Linux from OS/2's Boot Manager? 
  59.      * 3.12 How can I share a swap partition between Linux and MS
  60.        Windows? 
  61.        
  62. 4. Linux's handling of file systems, disks, and drives 
  63.  
  64.      * 4.1 How can I get Linux to work with my disk? 
  65.      * 4.2 How can I undelete files? 
  66.      * 4.3 Is there a defragmenter for ext2fs etc.? 
  67.      * 4.4 How do I format and create a file system on a floppy? 
  68.      * 4.5 I get nasty messages about inodes, blocks, and the like. 
  69.      * 4.6 My swap area isn't working. 
  70.      * 4.7 How do I remove LILO so my system boots DOS again? 
  71.      * 4.8 Why can't I use fdformat except as root? 
  72.      * 4.9 My ext2fs partitions are checked each time I reboot. 
  73.      * 4.10 My root file system is read-only! 
  74.      * 4.11 I have a huge /proc/kcore! Can I delete it? 
  75.      * 4.12 My AHA1542C doesn't work with Linux. 
  76.        
  77. 5. Porting, compiling and obtaining programs 
  78.  
  79.      * 5.1 How do I compile programs? 
  80.      * 5.2 How do I port XXX to Linux? 
  81.      * 5.3 What is ld.so and where do I get it? 
  82.      * 5.4 How do I upgrade the libraries withough trashing my
  83.        system? 
  84.      * 5.5 Has anyone ported / compiled / written XXX for Linux? 
  85.      * 5.6 Can I use code or a compiler compiled for a 486 on my 386?
  86.      * 5.7 What does gcc -O6 do? 
  87.      * 5.8 Where are linux/*.h and asm/*.h? 
  88.      * 5.9 I get errors when I try to compile the kernel. 
  89.      * 5.10 How do I make a shared library? 
  90.      * 5.11 My executables are (very) large. 
  91.      * 5.12 Does Linux support threads or lightweight processes? 
  92.      * 5.13 Where can I get `lint' for Linux? 
  93.      * 5.14 Where can I find kermit for Linux? 
  94.        
  95. 6. Solutions to common miscellaneous problems. 
  96.  
  97.      * 6.1 free dumps core. 
  98.      * 6.2 My clock is very wrong. 
  99.      * 6.3 Setuid scripts don't seem to work. 
  100.      * 6.4 Free memory as reported by free keeps shrinking. 
  101.      * 6.5 When I add more memory, the system slows to a crawl. 
  102.      * 6.6 Some programs (e.g. xdm) won't let me log in. 
  103.      * 6.7 Some programs let me log in with no password. 
  104.      * 6.8 My machine runs very slowly when I run GCC / X / ... 
  105.      * 6.9 I can only log in as root. 
  106.      * 6.10 My screen is all full of weird characters instead of
  107.        letters. 
  108.      * 6.11 I have screwed up my system and can't log in to fix it. 
  109.      * 6.12 I've discovered a huge security hole in rm! 
  110.      * 6.13 lpr(1) and/or lpd(8) don't work. 
  111.      * 6.14 Timestamps on files on MS-DOS partitions are set
  112.        incorrectly. 
  113.      * 6.15 How do I get LILO to boot the vmlinux file? 
  114.        
  115. 7. How do I do this or find out that ... ? 
  116.  
  117.      * 7.1 How can I get scrollback in text mode? 
  118.      * 7.2 How do I switch virtual consoles? How do I enable them? 
  119.      * 7.3 How do I set the time zone? 
  120.      * 7.4 What version of Linux and what machine name am I using? 
  121.      * 7.5 How can I enable or disable core dumps? 
  122.      * 7.6 How do I upgrade/recompile my kernel? 
  123.      * 7.7 Can I have more than 3 serial ports by sharing interrupts?
  124.      * 7.8 How do I make a bootable floppy? 
  125.      * 7.9 How do I remap my keyboard to UK, French, etc.? 
  126.      * 7.10 How do I get NUM LOCK to default to on? 
  127.      * 7.11 How do I set (or reset) my initial terminal colors?
  128.      * 7.12 How can I have more than 128Mb of swap? 
  129.        
  130. 8. Miscellaneous information and questions answered. 
  131.  
  132.      * 8.1 How do I program XYZ under Linux? 
  133.      * 8.2 What's all this about ELF? 
  134.      * 8.3 What is a .gz file ? And a .tgz ? And ... ? 
  135.      * 8.4 What does VFS stand for? 
  136.      * 8.5 What is a BogoMip? 
  137.      * 8.6 What is the Linux Journal and where can I get it? 
  138.      * 8.7 What online/free periodicals exist for Linux? 
  139.      * 8.8 How many people use Linux? 
  140.      * 8.9 How should I pronounce Linux? 
  141.        
  142. 9. Frequently encountered error messages. 
  143.  
  144.      * 9.1 Modprobe can't locate module, "XXX," and similar
  145.        messages. 
  146.      * 9.2 Unknown terminal type linux and similar. 
  147.      * 9.3 lp1 on fire 
  148.      * 9.4 INET: Warning: old style ioctl... called! 
  149.      * 9.5 ld: unrecognized option '-m486' 
  150.      * 9.6 GCC says Internal compiler error. 
  151.      * 9.7 make says Error 139 
  152.      * 9.8 shell-init: permission denied when I log in. 
  153.      * 9.9 No utmp entry. You must exec ... when I log in. 
  154.      * 9.10 Warning--bdflush not running. 
  155.      * 9.11 Warning: obsolete routing request made. 
  156.      * 9.12 EXT2-fs: warning: mounting unchecked file system. 
  157.      * 9.13 EXT2-fs warning: maximal count reached. 
  158.      * 9.14 EXT2-fs warning: checktime reached. 
  159.      * 9.15 df says Cannot read table of mounted file systems. 
  160.      * 9.16 fdisk says Partition X has different physical/logical
  161.        ... 
  162.      * 9.17 fdisk: Partition 1 does not start on cylinder boundary. 
  163.      * 9.18 fdisk says partition n has an odd number of sectors. 
  164.      * 9.19 mtools says cannot initialize drive XYZ 
  165.      * 9.20 At the start of booting: Memory tight 
  166.      * 9.21 My syslog says `end_request: I/O error, ...'. 
  167.      * 9.22 You don't exist. Go away. 
  168.        
  169. 10. The X Window System. 
  170.  
  171.      * 10.1 Does Linux support X Windows? 
  172.      * 10.2 Where can I get an XF86Config for my system? 
  173.      * 10.3 xterm logins show up strangely in who, finger. 
  174.      * 10.4 I can't get X Windows to work right. 
  175.        
  176. 11. Questions applicable to very out-of-date software. 
  177.  
  178.      * 11.1 fdisk says cannot use nnn sectors of this partition. 
  179.      * 11.2 GCC sometimes uses huge amounts of virtual memory and
  180.        thrashes.
  181.        
  182. 12. How to get further assistance. 
  183.  
  184.      * 12.1 You still haven't answered my question! 
  185.      * 12.2 What to put in a request for help. 
  186.      * 12.3 I want to mail someone about my problem. 
  187.        
  188. 13. Administrative information and acknowledgments. 
  189.  
  190.      * 13.1 Feedback is invited. 
  191.      * 13.2 Formats in which this FAQ is available. 
  192.      * 13.3 Authorship and acknowledgments. 
  193.      * 13.4 Disclaimer and Copyright. 
  194.    
  195.    
  196.    
  197. 1. Introduction and General Information
  198.  
  199. 1.1 What is Linux?
  200.  
  201.    Linux is the free Unix written from scratch by Linus Torvalds with
  202.    assistance from a loosely-knit team of hackers from across the
  203.    Internet. Linux aims towards POSIX compliance, and has all of the
  204.    features you would expect of a modern, fully fledged Unix: true
  205.    multitasking, virtual memory, shared libraries, demand loading,
  206.    shared, copy-on-write executables, proper memory management, and
  207.    TCP/IP networking.
  208.    
  209.    Linux runs mainly on 386/486/586-based PC's, using the hardware
  210.    facilities of the 80386 processor family (TSS segments, et al.) to
  211.    implement these features. Ports to other architectures are underway
  212.    (See, "What ports to other processors are there? ")
  213.    
  214.    See the Linux INFO-SHEET for more details. ("Where can I get
  215.    the HOWTO's and other documentation? ")
  216.    
  217.    The Linux kernel is distributed under the GNU General Public Licens
  218.    ("Is Linux public domain? Copyrighted? ")
  219.    
  220.    
  221. 1.2 Where do I start?
  222.  
  223.    There are a handful of major Linux distributions. For information
  224.    about them, and how they are installed, see Matthew Welsh's
  225.    Installation and Getting Started, or IGS for short. It's located at
  226.    the Linux Documentation Project Home Page,
  227.    http://sunsite.unc.edu/LDP.
  228.    
  229.    There is also an Installation HOWTO on the LDP Home Page.
  230.    
  231.    Most of the distributions are available via anonymous FTP from vari
  232.    Linux archive sites. ("Where can I get Linux material by FTP?
  233.    ") There are also a large number of other releases which are
  234.    distributed less globally that suit special local and national need
  235.    
  236.    
  237. 1.3 What software does Linux support?
  238.  
  239.    Linux supports GCC, Emacs, the X Window System, all the standard Un
  240.    utilities, TCP/IP (including SLIP and PPP), and all of the hundreds
  241.    programs that people have compiled or ported to it.
  242.    
  243.    There is a DOS emulator, called DOSEMU. The latest stable release i
  244.    0.98.1. The FTP archives are at ftp://ftp.dosemu.org/dosemu. The
  245.    Web site is htmlurl url="http://www.dosemu.org"
  246.    name="http://www.dosemu.org">.
  247.    
  248.    The emulator can run DOS itself and some (but not all) DOS
  249.    applications. Be sure to look at the README file to determine which
  250.    version you should get. Also, see the DOSEMU-HOWTO (slightly dated 
  251.    this point--it doesn't cover the most recent version of the program
  252.    at sunsite.unc.edu/pub/Linux/docs/HOWTO.
  253.    
  254.    Work has been progressing on an emulator for Microsoft Windows
  255.    binaries. ("Can I run Microsoft Windows programs under Linux?
  256.    ")
  257.    
  258.    iBCS2 (Intel Binary Compatibility Standard) emulator code for SVR4 
  259.    and SVR3.2 COFF binaries can be included in the kernel as a
  260.    compile-time option. There is information at
  261.    tsx-11.mit.edu/pub/linux/BETA/ibcs2/README.
  262.    
  263.    For more information see the INFO-SHEET, which is one of the HOWTO'
  264.    ("Where can I get the HOWTO's and other documentation? " and,
  265.    "How do I port XXX to Linux? ")
  266.    
  267.    Some companies have commercial software available, including Motif.
  268.    They announce their availability in comp.os.linux.announce--try
  269.    searching the archives. ("Are the newsgroups archived anywhere?
  270.    ")
  271.    
  272.    
  273. 1.4 Does Linux run on my computer? What hardware is supported?
  274.  
  275.    Giving Linux a try requires a machine with an Intel '386, '486, or
  276.    '586 processor with at least 2Mb of RAM and a single floppy drive. 
  277.    do anything useful, more RAM and disk space is needed. ("How
  278.    much memory does Linux need? ")
  279.    
  280.    VESA Local Bus and PCI are supported.
  281.    
  282.    MCA (IBM's proprietary bus) and ESDI hard drives are mostly support
  283.    There is further information on the MCA bus and what cards Linux
  284.    supports on the Micro Channel Linux Web page,
  285.    http://glycerine.itsmm.uni.edu/mca.
  286.    
  287.    Linux runs on '386 family based laptops, with X on most of them. Th
  288.    is a Web page at
  289.    http://www.cs.utexas.edu/users/kharker/linux-laptop/.
  290.    
  291.    For details of exactly which PC's, video cards, disk controllers, e
  292.    work see the INFO-SHEET and the Hardware-HOWTO. (See "Where can
  293.    I get the HOWTO's and other documentation? ")
  294.    
  295.    There is a port of Linux to the 8086, known as the Embeddable Linux
  296.    Kernel Subset (ELKS). This is a 16-bit subset of the Linux kernel
  297.    which will mainly be used for embedded systems. See
  298.    http://www.linux.org.uk/Linux8086.html for more information.
  299.    Linux will never run fully on an 8086 or '286, because it requires
  300.    task-switching and memory management facilities not found on these
  301.    processors.
  302.    
  303.    Linux supports multiprocessing with Intel MP architecture. See the
  304.    file Documentation/smp.tex in the Linux kernel source code
  305.    distribution.
  306.    
  307.    See the next question for a (probably incomplete) list of hardware
  308.    platforms Linux has been ported to.
  309.    
  310.    
  311. 1.5 What ports to other processors are there?
  312.  
  313.    There is a reasonably complete list of Linux ports at
  314.    http://www.ctv.es/USERS/xose/linux/linux_ports.html, and at
  315.    http://www.linuxhq.com/dist-index.html.
  316.    
  317.    A project has been underway for a while to port Linux to suitable
  318.    68000-series based systems like Amigas and Ataris. The Linux/m68K F
  319.    is located at www.clark.net/pub/lawrencc/linux/faq/faq.html. The
  320.    URL of the Linux/m68k home page is www.linux-m68k.
  321.    
  322.    There is a linux-680x0 mailing list. ("What mailing lists are
  323.    there? ")
  324.    
  325.    There is (or was) a FTP site for the Linux-m68k project on
  326.    ftp.phil.uni-sb.de/pub/atari/linux-68k, but this address may no
  327.    longer be current.
  328.    
  329.    Debian GNU/Linux is being ported to Alpha, Sparc, PowerPC, and ARM
  330.    platforms. There are mailing lists for all of them. See
  331.    http://www.debian.org/MailingLists/subscribe.
  332.    
  333.    One of the Linux-PPC project pages has moved recently. Its location
  334.    http://www.linuxppc.org, and the archive site is
  335.    ftp.linuxppc.org/linuxppc.
  336.    
  337.    There is a Linux-PPC support page at www.cs.nmt.edu/~linuxppc/.
  338.    There you will find the kernel that is distributed with Linux.
  339.    
  340.    Apple now supports MkLinux development on Power Macs, based on OSF 
  341.    the Mach microkernel. See http://www.mklinux.apple.com.
  342.    
  343.    A port to the 64-bit DEC Alpha/AXP is at
  344.    http://www.azstarnet.com/~axplinux/. There is a mailing list at
  345.    vger.rutgers.edu. ("What mailing lists are there? ")
  346.    
  347.    Ralf Baechle is working on a port to the MIPS, initially for the R4
  348.    on Deskstation Tyne machines. The Linux-MIPS FTP sites are
  349.    ftp.fnet.fr/linux-mips and
  350.    ftp://ftp.linux.sgi.com/pub/mips-linux. Interested people may
  351.    mail their questions and offers of assistance to
  352.    linux@waldorf-gmbh.de.
  353.    
  354.    There is also a MIPS channel on the Linux Activists mail server and
  355.    linux-mips mailing list. ("What mailing lists are there? ")
  356.    
  357.    There are currently two ports of Linux to the ARM family of
  358.    processors. One of these is for the ARM3, fitted to the Acorn A5000
  359.    and it includes I/O drivers for the 82710/11 as appropriate. The ot
  360.    is to the ARM610 of the Acorn RISC PC. The RISC PC port is currentl
  361.    in its early to middle stages, owing to the need to rewrite much of
  362.    the memory handling. The A5000 port is in restricted beta testing. 
  363.    release is likely soon.
  364.    
  365.    For more, up-to-date information, read the newsgroup
  366.    comp.sys.acorn.misc. There is a FAQ at
  367.    http://www.arm.uk.linux.org
  368.    
  369.    The Linux SPARC project is a hotbed of activity. There is a FAQ
  370.    available from Jim Mintha's Linux for SPARC Processors page,
  371.    http://www.geog.ubc.ca/sparclinux.html. The SPARC/Linux archives
  372.    are at vger.rutgers.edu/pub/linux/Sparc.
  373.    
  374.    There is also a port ("Hardhat") to SGI/Indy machines. The URL is
  375.    http://www.linux.sgi.com.
  376.    
  377.    
  378. 1.6 How much hard disk space does Linux need?
  379.  
  380.    About 10Mb for a very minimal installation, suitable for trying Lin
  381.    and not much else.
  382.    
  383.    You can fit an installation that includes X into 80Mb. Installing
  384.    Debian GNU/Linux takes 500Mb--1GB, including kernel source code, so
  385.    space for user files, and spool areas.
  386.    
  387.    
  388. 1.7 How much memory does Linux need?
  389.  
  390.    At least 4MB, and then you will need to use special installation
  391.    procedures until the disk swap space is installed. Linux will run
  392.    comfortably in 4MB of RAM, although X Windows Apps will run slowly
  393.    because they need to swap out to disk.
  394.    
  395.    Some recent applications, like Netscape, require 64MB of physical
  396.    memory.
  397.    
  398.    
  399. 1.8 How much memory can Linux use?
  400.  
  401.    A number of people have asked how to address more than 64 MB of
  402.    memory, which is the default upper limit. Place the following in yo
  403.    lilo.conf file:
  404. append="mem=XXM"
  405.  
  406.    Where "XX" is the amount of memory, specified as megabytes; for
  407.    example, '128M'. For further details, see the lilo manual page.
  408.    
  409.    
  410. 1.9 Is Linux public domain? Copyrighted?
  411.  
  412.    The Linux kernel copyright belongs to Linus Torvalds. He has placed
  413.    under the GNU General Public License, which basically means that yo
  414.    may freely copy, change, and distribute it, but you may not impose 
  415.    restrictions on further distribution, and you must make the source
  416.    code available.
  417.    
  418.    This is not the same as Public Domain. See the Copyright FAQ,
  419.    rtfm.mit.edu/pub/usenet/news.answers/law/copyright, for details.
  420.    
  421.    Full details are in the file COPYING in the Linux kernel sources
  422.    (probably in /usr/src/linux on your system).
  423.    
  424.    The licenses of the utilities and programs which come with the
  425.    installations vary. Much of the code is from the GNU Project at the
  426.    Free Software Foundation, and is also under the GPL.
  427.    
  428.    Note that discussion about the merits or otherwise of the GPL shoul
  429.    be posted to the news group gnu.misc.discuss, and not to the
  430.    comp.os.linux hierarchy.
  431.    
  432.    
  433.    
  434.    
  435. 2. Network sources and resources.
  436.  
  437.    
  438. 2.1 Where can I get the HOWTO's and other documentation?
  439.  
  440.    Look in the following places, and the sites that mirror them.
  441.      * ftp.funet.fi : /pub/OS/Linux/doc/HOWTO
  442.      * tsx-11.mit.edu : /pub/linux/docs/HOWTO
  443.      * sunsite.unc.edu : /pub/Linux/docs/HOWTO
  444.        
  445.    For a complete list of Linux FTP sites, see, "Where can I get
  446.    Linux material by FTP? "
  447.    
  448.    If you don't have access to FTP, try the FTP-by-mail servers at
  449.    ftpmail@decwrl.dec.com, ftpmail@doc.ic.ac.uk, or
  450.    ftp-mailer@informatik.tu-muenchen.de.
  451.    
  452.    A complete list of HOWTO's and Mini-HOWTO's is available in the fil
  453.    HOWTO-INDEX in the docs/HOWTO directory at the FTP sites, and on th
  454.    Web at http://sunsite.unc.edu/LDP/HOWTO/HOWTO-INDEX.html, but
  455.    here is a (possibly incomplete) list:
  456. AX25-HOWTO                             Access-HOWTO
  457. Assembly-HOWTO                         Benchmarking-HOWTO
  458. BootPrompt-HOWTO                       Bootdisk-HOWTO
  459. CD-Writing-HOWTO                       CDROM-HOWTO
  460. Chinese-HOWTO                          Commercial-HOWTO
  461. Consultants-HOWTO                      Cyrillic-HOWTO
  462. DNS-HOWTO                              DOS-to-Linux-HOWTO
  463. DOSEMU-HOWTO                           Danish-HOWTO
  464. Distribution-HOWTO                     ELF-HOWTO
  465. Emacspeak-HOWTO                        Ethernet-HOWTO
  466. Finnish-HOWTO                          Firewall-HOWTO
  467. Ftape-HOWTO                            GCC-HOWTO
  468. German-HOWTO                           HAM-HOWTO
  469. HOWTO-INDEX                            Hardware-HOWTO
  470. Hebrew-HOWTO                           IPX-HOWTO
  471. ISP-Hookup-HOWTO                       Installation-HOWTO
  472. Intranet-Server-HOWTO                  Italian-HOWTO
  473. Java-CGI-HOWTO                         Kernel-HOWTO
  474. Keyboard-and-Console-HOWTO             MGR-HOWTO
  475. MILO-HOWTO                             Mail-HOWTO
  476. NET-3-HOWTO                            NFS-HOWTO
  477. NIS-HOWTO                              News-HOWTO
  478. Optical-Disk-HOWTO                     PCI-HOWTO
  479. PCMCIA-HOWTO                           PPP-HOWTO
  480. Pilot-HOWTO                            Polish-HOWTO
  481. Printing-HOWTO                         Printing-Usage-HOWTO
  482. RPM-HOWTO                              Reading-List-HOWTO
  483. SCSI-HOWTO                             SCSI-Programming-HOWTO
  484. SMB-HOWTO                              Serial-HOWTO
  485. Serial-Programming-HOWTO               Shadow-Password-HOWTO
  486. Slovenian-HOWTO                        Sound-HOWTO
  487. Sound-Playing-HOWTO                    Spanish-HOWTO
  488. TeTeX-HOWTO                            Thai-HOWTO
  489. Tips-HOWTO                             UMSDOS-HOWTO
  490. UPS-HOWTO                              UUCP-HOWTO
  491. User-Group-HOWTO                       VAR-HOWTO
  492. VMS-to-Linux-HOWTO                     XFree86-HOWTO
  493. XFree86-Video-Timings-HOWTO
  494. 3-Button-Mouse
  495.  
  496.    The following Mini-HOWTO's are available from
  497.    http://sunsite.unc.edu/pub/Linux/HOWTO/mini:
  498. ADSM-Backup                            AI-Alife
  499. Advocacy                               Backup-With-MSDOS
  500. Battery-Powered                        Boca
  501. BogoMips                               Bridge
  502. Bridge+Firewall                        Clock
  503. Colour-ls                              Comeau-C++
  504. DHCPd                                  Dial-On-Demand
  505. Diald                                  Dip+SLiRP+CSLIP
  506. Diskless                               Dynamic-IP-Hacks
  507. Ext2fs-Undeletion                      GTEK-BBS-550
  508. HTML-Validation                        IO-Port-Programming
  509. IP-Alias                               IP-Masquerade
  510. IP-Subnetworking                       JE
  511. Jaz-Drive                              Kerneld
  512. Key-Setup                              LBX
  513. Large-Disk                             Linux+DOS+Win95
  514. Linux+DOS+Win95+OS2                    Linux+NT-Loader
  515. Linux+OS2+DOS                          Linux+Win95
  516. Loadlin+Win95                          Locales
  517. MIDI+SB                                Mail-Queue
  518. Mail2News                              Man-Page
  519. Multiple-Disks-Layout                  Multiple-Ethernet
  520. NFS-Root                               NFS-Root-Client
  521. Netscape+Proxy                         Offline-Mailing
  522. Online-Support                         PLIP
  523. PPP-over-minicom                       Pager
  524. Partition                              Print2Win
  525. Process-Accounting                     Proxy-ARP
  526. Public-Web-Browser                     Qmail+MH
  527. Quota                                  RCS
  528. Remote-Boot                            Remote-X-Apps
  529. SLIP+proxyARP                          SLIP-PPP-Emulator
  530. Sendmail+UUCP                          Software-Building
  531. Software-RAID                          Soundblaster-16
  532. Soundblaster-AWE64                     StarOffice
  533. Swap-Space                             Term-Firewall
  534. Tiny-News                              Token-Ring
  535. Upgrade                                VPN
  536. Virtual-wu-ftpd                        Visual-Bell
  537. Win95+Win+Linux                        Windows-Modem-Sharing
  538. WordPerfect                            X-Big-Cursor
  539. XFree86-XInside                        Xterm-Title
  540. Xterminal                              ZIP-Drive
  541. ZIP-Install
  542.  
  543.    In addition, translations of the HOWTO's are available from
  544.    sunsite.unc.edu/pub/Linux/docs/HOWTO/translations and mirrors
  545.    worldwide. Translations in the following languages are available:
  546.    
  547. Chinese (zh)                    Croatian(hr)
  548. French (fr)                     German (de)
  549. Hellenic (el)                   Indonesian (id)
  550. Italian (it)                    Japanese (jp)
  551. Korean (ko)                     Polish (pl)
  552. Spanish (es)                    Slovenian (sl)
  553. Swedish (sv)                    Turkish (tr)
  554.  
  555.    The HOWTO's are also on the Web, at the Linux Documentation Project
  556.    Home Page, http://sunsite.unc.edu/LDP.
  557.    
  558.    More of these documents are always in preparation. Please get in to
  559.    with Timothy Bynum, tjbynum@sunsite.unc.edu, the HOWTO
  560.    coordinator, if you are interested in writing one. The file
  561.    sunsite.unc.edu/pub/Linux/HOWTO/HOWTO-INDEX contains guidelines
  562.    for writing a HOWTO. He has a Web page that lists current HOWTO
  563.    updates and additions at
  564.    wallybox.cei.net/~tjbynum/HOWTO/projects.
  565.    
  566.    The Guide Series produced by the Linux Documentation Project is
  567.    available from http://sunsite.unc.edu/LDP. Please read them if
  568.    you are new to Unix and Linux. Here is a list of those available so
  569.    far:
  570.    
  571.      * The Linux Documentation Project Manifesto, by Matt Welsh.
  572.      * Installation and Getting Started Guide, by Matt Welsh.
  573.      * The Linux Kernel, by David Rusling.
  574.      * The Network Administrator's Guide, by Olaf Kirch.
  575.      * The Linux Programmer's Guide, by Sven Goldt, Sven van der
  576.        Meer, Scott Burkett, and Matt Welsh.
  577.      * The Linux System Administrator's Guide, Version 0.5, by Lars
  578.        Wirzenius.
  579.        
  580.    In addition, there is a FAQ for Linux kernel developers at
  581.    http://www.tux.org/html/.
  582.    
  583.    
  584. 2.2 Where should I look on the World Wide Web for Linux stuff?
  585.  
  586.    Two Web pages in particular provide good starting point for general
  587.    Linux information: Linux International's Home Page, at
  588.    http://www.li.org, and the Linux Online's Linux Home Page at
  589.    http://www.linux.org/.
  590.    
  591.    Both of these pages provide links to other sites, information about
  592.    general information, distributions, new software, documentation, an
  593.    news.
  594.    
  595.    Greg Hankins, gregh@cc.gatech.edu, maintains the Linux
  596.    Documentation Project Home Page, at http://sunsite.unc.edu/LDP.
  597.    This page refers to all of the HOWTO's and FAQ's, both those which 
  598.    available in HTML (WWW) format, and those which aren't.
  599.    
  600.    
  601. 2.3 What newsgroups are there for Linux?
  602.  
  603.    Comp.os.linux.announce is the moderated announcements group; you
  604.    should read this if you intend to use Linux: it contains informatio
  605.    about software updates, new ports, user group meetings, and commerc
  606.    products. It is the ONLY newsgroup that may carry commercial postin
  607.    Submissions for that group should be e-mailed to
  608.    linux-announce@news.ornl.gov.
  609.    
  610.    comp.os.linux.announce, however, is not archived on DejaNews or Alt
  611.    Vista. The only archive for the news group seems to be
  612.    www.iki.fi/mjr/linux/cola.html.
  613.    
  614.    [Axel Boldt]
  615.    
  616.    Also worth reading are the following other groups in the
  617.    comp.os.linux.* hierarchy--you may find many common problems too
  618.    recent for the documentation but are answered in the newsgroups.
  619. comp.os.linux.setup
  620. comp.os.linux.hardware
  621. comp.os.linux.networking
  622. comp.os.linux.x
  623. comp.os.linux.development.apps
  624. comp.os.linux.development.system
  625. comp.os.linux.advocacy
  626. comp.os.linux.misc
  627.  
  628.    Remember that Linux is POSIX compatible, and most all of the materi
  629.    in comp.unix.* and comp.windows.x.* groups will be relevant. Apart
  630.    from hardware considerations, and some obscure or very technical
  631.    low-level issues, you'll find that these groups are good places to
  632.    start.
  633.    
  634.    Please read "You still haven't answered my question! " before
  635.    posting. Cross posting between different comp.os.linux.* groups is
  636.    rarely a good idea.
  637.    
  638.    There may well be Linux groups local to your institution or
  639.    area--check there first.
  640.    
  641.    See also "I don't have Usenet access. Where do I get
  642.    information? "
  643.    
  644.    Other regional and local newsgroups also exist--you may find the
  645.    traffic more manageable there. The French Linux newsgroup is
  646.    fr.comp.os.linux. The German one is de.comp.os.linux. In Australia,
  647.    try aus.computers.linux. In Croatia there is hr.comp.linux. In Ital
  648.    there is it.comp.linux.
  649.    
  650.    
  651. 2.4 Where can I find out about Linux and the Millennium (Y2K) bug?
  652.  
  653.    The Debian/GNU Linux people have a statement on their Web site at
  654.    http://www.debian.org
  655.    
  656.    Essentially, Linux uses libraries that store dates as 32-bit intege
  657.    which count the seconds since 1970. This counter will not overflow
  658.    until the year 2038, by which time the library programmers will
  659.    (hopefully) have upgraded the system software to store dates as 64-
  660.    integers.
  661.    
  662.    This, of course, does not mean that applications are not susceptibl
  663.    to the millennium bug, if they do not use the standard library
  664.    routines.
  665.    
  666.    The Free Software Foundation has a Web page about Y2K issues in GNU
  667.    software at http://www.fsf.org/software/year2000.html
  668.    
  669.    There is also a Usenet newsgroup, comp.software.year-2000, for gene
  670.    discussion of Y2K issues.
  671.    
  672.    
  673. 2.5 Where can I get Linux material by FTP?
  674.  
  675.    There are three main archive sites for Linux:
  676.      * ftp.funet.fi (Finland) : /pub/OS/Linux
  677.      * sunsite.unc.edu (US) : /pub/Linux
  678.      * tsx-11.mit.edu (US) : /pub/linux
  679.        
  680.    The best place to get the Linux kernel is
  681.    ftp.cs.helsinki.fi/pub/Linux_Kernel. Linus Torvalds uploads the
  682.    most recent kernel versions to this site.
  683.    
  684.    Of the U.S. distributions, Debian GNU/Linux is available at
  685.    ftp.debian.org/pub/debian. Red Hat Linux's home site is
  686.    ftp.redhat.com, and Linux Slackware's is ftp.cdrom.com.
  687.    
  688.    The contents of these sites is mirrored (copied, usually approximat
  689.    daily) by a number of other sites. Please use a site close to you--
  690.    will be faster for you and easier on the network.
  691.      * ftp.sun.ac.za/pub/linux/sunsite/ (South Africa)
  692.      * ftp.is.co.za/linux/sunsite/ (South Africa)
  693.      * ftp.cs.cuhk.hk/pub/Linux/ (Hong Kong)
  694.      * ftp.cs.cuhk.hk/pub/Linux/ (Hong Kong)
  695.      * ftp.spin.ad.jp/pub/linux/sunsite.unc.edu/ (Japan)
  696.      * ftp.nuri.net/pub/Linux/ (Korea)
  697.      * ftp.jaring.my/pub/Linux/ (Malaysia)
  698.      * ftp.nus.sg/pub/unix/Linux/ (Singapore)
  699.      * ftp.nectec.or.th/pub/mirrors/linux/ (Thailand)
  700.      * mirror.aarnet.edu.au/pub/linux/ (Australia)
  701.      * sunsite.anu.edu.au/pub/linux/ (Australia)
  702.      * ftp.monash.edu.au/pub/linux/ (Australia)
  703.      * ftp.univie.ac.at/systems/linux/sunsite/ (Austria)
  704.      * ftp.fi.muni.cz/pub/UNIX/linux/ (Czech Republic)
  705.      * ftp://sunsite.fri.uni-lj.si/pub/linux/ (Slovenia)
  706.      * ftp.funet.fi/pub/Linux/sunsite/ (Finland)
  707.      * ftp.univ-angers.fr/pub/Linux/ (France)
  708.      * ftp.iut-bm.univ-fcomte.fr (France)
  709.      * ftp.ibp.fr/pub/linux/sunsite/ (France)
  710.      * ftp.loria.fr/pub/linux/sunsite/ (France)
  711.      * ftp.dfv.rwth-aachen.de/pub/linux/sunsite/ (Germany)
  712.      * ftp.germany.eu.net/pub/os/Linux/Mirror.SunSITE/ (Germany)
  713.      * ftp.tu-dresden.de/pub/Linux/sunsite/ (Germany)
  714.      * ftp.uni-erlangen.de/pub/Linux/MIRROR.sunsite/ (Germany)
  715.      * ftp.gwdg.de/pub/linux/mirrors/sunsite/ (Germany)
  716.      * ftp.rz.uni-karlsruhe.de/pub/linux/mirror.sunsite/ (Germany)
  717.      * ftp.ba-mannheim.de/pub/linux/mirror.sunsite/ (Germany)
  718.      * ftp.uni-paderborn.de/pub/Mirrors/sunsite.unc.edu/ (Germany)
  719.      * ftp.uni-rostock.de/Linux/sunsite/ (Germany)
  720.      * tp.rus.uni-stuttgart.de/pub/unix/systems/linux/MIRROR.sunsite
  721.        / (Germany)
  722.      * ftp.uni-tuebingen.de/pub/linux/Mirror.sunsite/ (Germany)
  723.      * ftp.rz.uni-ulm.de/pub/mirrors/linux/sunsite/ (Germany)
  724.      * ftp.kfki.hu/pub/linux/ (Hungary)
  725.      * linux.italnet.it/pub/Linux/ (Italy)
  726.      * ftp.unina.it/pub/linux/sunsite/ (Italy)
  727.      * giotto.unipd.it/pub/unix/Linux/ (Italy)
  728.      * cnuce-arch.cnr.it/pub/Linux/ (Italy)
  729.      * ftp.flashnet.it/mirror2/sunsite.unc.edu/ (Italy)
  730.      * ftp.nijenrode.nl/pub/linux/sunsite.unc-mirror/ (Netherlands)
  731.      * ftp.LeidenUniv.nl/pub/linux/sunsite/ (Netherlands)
  732.      * ftp.nvg.unit.no/pub/linux/sunsite/ (Norway)
  733.      * ftp://sunsite.icm.edu.pl/pub/Linux/sunsite.unc.edu/ (Poland)
  734.      * ftp.rediris.es/software/os/linux/sunsite/ (Spain)
  735.      * sunsite.rediris.es/software/linux/ (Spain)
  736.      * ftp.cs.us.es/pub/Linux/sunsite-mirror/ (Spain)
  737.      * ftp.etse.urv.es/pub/mirror/linux/ (Spain)
  738.      * ftp.etsimo.uniovi.es/pub/linux/ (Spain)
  739.      * ftp.luna.gui.es/pub/linux.new/ (Spain)
  740.      * ftp.switch.ch/mirror/linux/ (Switzerland)
  741.      * ftp.metu.edu.tr/pub/linux/sunsite/ (Turkey)
  742.      * unix.hensa.ac.uk/mirrors/sunsite/pub/Linux/ (UK)
  743.      * ftp.maths.warwick.ac.uk/mirrors/linux/sunsite.unc-mirror/
  744.        (UK)
  745.      * ftp.idiscover.co.uk/pub/Linux/sunsite.unc-mirror/ (UK)
  746.      * sunsite.doc.ic.ac.uk/packages/linux/sunsite.unc-mirror/ (UK)
  747.      * ftp.dungeon.com/pub/linux/sunsite-mirror/ (UK)
  748.      * ftp.io.org/pub/mirrors/linux/sunsite/ (Canada)
  749.      * ftp.cc.gatech.edu/pub/linux/ (US)
  750.      * ftp.cdrom.com/pub/linux/sunsite/ (US)
  751.      * ftp.siriuscc.com/pub/Linux/Sunsite/ (US)
  752.      * ftp.engr.uark.edu/pub/linux/sunsite/ (US)
  753.      * ftp.infomagic.com/pub/mirrors/linux/sunsite/ (US)
  754.      * linux.if.usp.br/pub/mirror/sunsite.unc.edu/pub/Linux/
  755.        (Brazil)
  756.      * farofa.ime.usp.br/pub/linux/ (Brazil)
  757.        
  758.    Not all of these mirror all of the other "source" sites, and some
  759.    have material not available on the "source" sites.
  760.    
  761.    
  762. 2.6 I don't have FTP access. Where do I get Linux?
  763.  
  764.    The easiest thing is probably to find a friend with FTP access. If
  765.    there is a Linux user's group near you, they may be able to help.
  766.    
  767.    If you have a reasonably good email connection, you could try the
  768.    FTP-by-mail servers at ftpmail@ftp.sunet.se,
  769.    ftpmail@garbo.uwasa.fi, or ftpmail@ftp.uni-stuttgart.de.
  770.    
  771.    Linux is also available via traditional mail on CD-ROM. The file
  772.    sunsite.unc.edu/pub/Linux/docs/HOWTO/Installation-HOWTO, and the
  773.    file sunsite.unc.edu/pub/Linux/docs/HOWTO/Distribution-HOWTO
  774.    contain information on these distributions.
  775.    
  776.    
  777. 2.7 I don't have Usenet access. Where do I get information?
  778.  
  779.    A digest of comp.os.linux.announce is available by mailing the word
  780.    "subscribe" (without the quotes) as the body of a message to
  781.    linux-announce-REQUEST@news-digests.mit.edu. Subscribing to this
  782.    list is a good idea, as it carries important information and
  783.    documentation about Linux.
  784.    
  785.    Please remember to use the *-request addresses for your subscribe a
  786.    unsubscribe messages; mail to the other address is posted to the ne
  787.    group.
  788.    
  789.    
  790. 2.8 What mailing lists are there?
  791.  
  792.    The Linux developers now mainly use the Majordomo server at
  793.    majordomo@vger.rutgers.edu. Send a message with the word
  794.    "lists" (without the quotes) in the body to get a list of lists
  795.    there. Add a line with the word, "help," to get the standard
  796.    Majordomo help file that lists instructions for subscribing and
  797.    unsubscribing to the lists.
  798.    
  799.    Most of the lists are used by Linux developers to talk about techni
  800.    issues and future developments. These are not intended for new user
  801.    questions.
  802.    
  803.    There is a linux-newbie list where, "no question is too stupid."
  804.    Unfortunately, it seems that few experienced users read that list, 
  805.    it has very low volume.
  806.    
  807.    
  808. 2.9 Are the newsgroups archived anywhere?
  809.  
  810.    The Usenet Linux news groups are archived at
  811.    http://www.dejanews.com, http://www.reference.com, and
  812.    http://altavista.digital.com
  813.    
  814.    Sunsite.unc.edu/pub/Linux/docs/linux-announce.archive contains
  815.    archives of comp.os.linux.announce. These are mirrored from
  816.    src.doc.ic.ac.uk/usenet, which also archives comp.os.linux,
  817.    comp.os.linux.development.apps, and comp.os.linux.development.syste
  818.    
  819.    There is an `easy to access' archive of comp.os.linux.announce on t
  820.    World Wide Web at
  821.    http://www.leo.org/archiv/linux/archiv/ann_index.html which
  822.    supports searching and browsing.
  823.    
  824.    
  825.    contents
  826.    
  827.    
  828. 3. Compatibility with other operating systems.
  829.  
  830.    
  831. 3.1 Can Linux share my disk with DOS? OS/2? 386BSD? Win95?
  832.  
  833.    Yes. Linux uses the standard MS-DOS partitioning scheme, so it can
  834.    share your disk with other operating systems. Note, however, that m
  835.    other operating systems may not be exactly compatible. DOS's FDISK.
  836.    and FORMAT.EXE, for example, can overwrite data in a Linux partitio
  837.    because they sometimes incorrectly use partition data from the
  838.    partition's boot sector rather than the partition table.
  839.    
  840.    In order to prevent programs from doing this, it is a good idea to
  841.    zero out--under Linux--the start of a partition you created, before
  842.    you use MS-DOS--or whatever--to format it. Type:
  843. $ dd if=/dev/zero of=/dev/hdXY bs=512 count=1
  844.  
  845.    where hdXY is the relevant partition; e.g., /dev/hda1 for the first
  846.    partition of the first (IDE) disk.
  847.    
  848.    Linux can read and write the files on your DOS and OS/2 FAT partiti
  849.    and floppies using either the DOS file system type built into the
  850.    kernel or mtools. There is kernel support for the VFAT file system
  851.    used by Windows 9x and Windows NT.
  852.    
  853.    For information about FAT32 partition support, see
  854.    http://bmrc.berkeley.edu/people/chaffee/fat32.html.
  855.    
  856.    See, "What software does Linux support? " for details and
  857.    status of the emulators for DOS, MS Windows, and System V programs.
  858.    
  859.    See also, "Can Linux access Amiga file systems? ", "Can
  860.    Linux access Macintosh file systems? ", "Can Linux access BSD,
  861.    SysV, etc., UFS? ", and "Can Linux access SMB file systems? "
  862.    
  863.    There are said to be NTFS drivers under development, which should
  864.    support compression as a standard feature.
  865.    
  866.    
  867. 3.2 How do I access files on my DOS partition or floppy?
  868.  
  869.    Use the DOS file system, type, for example:
  870. $ mkdir /dos
  871. $ mount -t msdos -o conv=text,umask=022,uid=100,gid=100 /dev/hda3 /dos
  872.  
  873.    If it's a floppy, don't forget to umount it before ejecting it!
  874.    
  875.    You can use the conv=text/binary/auto, umask=nnn, uid=nnn, and gid=
  876.    options to control the automatic line-ending conversion, permission
  877.    and ownerships of the files in the DOS file system as they appear
  878.    under Linux. If you mount your DOS file system by putting it in you
  879.    /etc/fstab, you can record the options (comma-separated) there,
  880.    instead of defaults.
  881.    
  882.    Alternatively, you can use mtools, available in both binary and sou
  883.    form on the FTP sites. ("Where can I get Linux material by FTP?
  884.    ")
  885.    
  886.    A kernel patch (known as the fd-patches) is available which allows
  887.    floppies with nonstandard numbers of tracks and/or sectors to be us
  888.    this patch is included in the 1.1 alpha testing kernel series.
  889.    
  890.    
  891. 3.3 Does Linux support compressed ext2 file systems?
  892.  
  893.    As of recently, it does. Information about them is located at
  894.    http://www.netspace.net.au/~reiter/e2compr/.
  895.    
  896.    There is also a Web site for the e2compr patches The code is still
  897.    experimental and consists of patches for the 2.0 and 2.1 kernels. F
  898.    more information about the project, including the latest patches, a
  899.    the address of the mailing list, look up the URL at
  900.    http://debs.fuller.edu/e2compr/.
  901.    
  902.    [Roderich Schupp]
  903.    
  904.    Zlibc is a program that allows existing applications to read
  905.    compressed (GNU gzip'ed) files as if they were not compressed. Look
  906.    sunsite.unc.edu in /pub/Linux/libs/. The author is Alain Knuff.
  907.    
  908.    There is also a compressing block device driver, "DouBle," by
  909.    Jean-Marc Verbavatz, which can provide on-the-fly disk compression 
  910.    the kernel. The source-only distribution is located at sunsite.unc.
  911.    in the directory /pub/Linux/patches/diskdrives/. This driver
  912.    compresses inodes and directory information as well as files, so an
  913.    corruption of the file system is likely to be serious.
  914.    
  915.    There is also a package called tcx (Transparently Compressed
  916.    Executables), which allows you to keep infrequently compressed
  917.    executables compressed and only uncompress them temporarily when in
  918.    use. It is located on sunsite.unc.edu in the directory
  919.    /pub/Linux/utils/compress/.
  920.    
  921.    
  922. 3.4 Can I use my Stacked/DBLSPC/etc. DOS drive?
  923.  
  924.    Until recently, not very easily. You can access DOS 6.X volumes fro
  925.    the DOS emulator ("What software does Linux support? "), but
  926.    it's harder than accessing a normal DOS volume via the DOS kernel
  927.    option, a module, or mtools.
  928.    
  929.    There is a recently added package, dmsdos, which reads and writes
  930.    compressed file systems like DoubleSpace/DriveSpace in MS-DOS 6.x a
  931.    Win95, as well as Stacker versions 3 and 4. It is available in the
  932.    archives on
  933.    ftp://sunsite.unc.edu/pub/Linux/system/Filesystem/dosfs.
  934.    
  935.    There is a module available for the Linux kernel which can do
  936.    read-only access of compressed volume. Look at
  937.    sunsite.unc.edu/pub/Linux/system/filesystems/dosfs/.
  938.    
  939.    
  940. 3.5 Can I access OS/2 HPFS partitions from Linux?
  941.  
  942.    Yes, but Linux access to HPFS partitions is read-only. HPFS file
  943.    system access is available as an option when compiling the kernel o
  944.    as a module. See the Documentation/filesystems/hpfs.txt file in the
  945.    kernel source distribution. ("How do I upgrade/recompile my
  946.    kernel? ") Then you can mount HPFS partition, using, for example:
  947. $ mkdir /hpfs
  948. $ mount -t hpfs /dev/hda5 /hpfs
  949.  
  950.    
  951. 3.6 Can Linux access Amiga file systems?
  952.  
  953.    The Linux kernel has support for the Amiga Fast File System (AFFS)
  954.    version 1.3 and later, both as a compile-time option and as a modul
  955.    The file Documentation/filesystems/affs.txt in the Linux kernel sou
  956.    distribution has more information.
  957.    
  958.    See "How do I upgrade/recompile my kernel? ".
  959.    
  960.    Linux supports AFFS hard-drive partitions only. Floppy access is no
  961.    supported due to incompatibilities between Amiga floppy controllers
  962.    and PC and workstation controllers. The AFFS driver can also mount
  963.    disk partitions used by the Un*x Amiga Emulator, by Bernd Schmidt.
  964.    
  965.    
  966. 3.7 Can Linux access BSD, SysV, etc. UFS?
  967.  
  968.    Recent kernels can mount (read only) the UFS file system used by
  969.    System V; Coherent; Xenix; BSD; and derivatives like SunOS, FreeBSD
  970.    NetBSD, and NeXTStep. UFS support is available as a kernel
  971.    compile-time option and a module.
  972.    
  973.    See, "How do I upgrade/recompile my kernel? "
  974.    
  975.    
  976. 3.8 Can Linux access SMB file systems?
  977.  
  978.    Linux supports read/write access of Windows for Workgroups and Wind
  979.    NT SMB volumes. See the file Documentation/filesystems/smbfs.txt of
  980.    the Linux kernel source distribution, and "How do I
  981.    upgrade/recompile my kernel? " in this FAQ.
  982.    
  983.    There is also a suite of programs called Samba which provide suppor
  984.    for WfW networked file systems (provided they're for TCP/IP).
  985.    Information is available in the README file at
  986.    sunsite.unc.edu/pub/Linux/system/network/samba/.
  987.    
  988.    There is a SMB Web site at samba.anu.edu.au/samba/.
  989.    
  990.    
  991. 3.9 Can Linux access Macintosh file systems?
  992.  
  993.    There is a set of user-level programs that read and write the
  994.    Macintosh Hierarchical File System (HFS). It is available at
  995.    sunsite.unc.edu/pub/Linux/utils/disk-management.
  996.    
  997.    
  998. 3.10 Can I run Microsoft Windows programs under Linux?
  999.  
  1000.    WINE, a MS Windows emulator for Linux, is still not ready for gener
  1001.    distribution. If you want to contribute to its development, look fo
  1002.    the status reports in the comp.emulators.ms-windows.wine newsgroup.
  1003.    
  1004.    There is also a FAQ, compiled by P. David Gardner, at
  1005.    sunsite.unc.edu/pub/Linux/docs/faqs/Wine-FAQ/.
  1006.    
  1007.    In the meantime, if you need to run MS Windows programs, the best
  1008.    bet--seriously--is to reboot. LILO, the Linux boot loader, can boot
  1009.    one of several operating systems from a menu. See the LILO
  1010.    documentation for details.
  1011.    
  1012.    Also, LOADLIN (a DOS program to load a Linux, or other OS, kernel i
  1013.    one way to make Linux co-exist with DOS. LOADLIN is particularly ha
  1014.    when you want to install Linux on a 3rd or 4th drive on a system (o
  1015.    when you're adding a SCSI drive to a system with an existing IDE).
  1016.    
  1017.    In these cases, it is common for LILO's boot loader to be unable to
  1018.    find or load the kernel on the "other" drive. So you just create a
  1019.    C:\LINUX directory (or whatever), put LOADLIN in it with a copy of
  1020.    your kernel, and use that.
  1021.    
  1022.    LOADLIN is a VCPI compliant program. Win95 will want to, "shutdown
  1023.    into DOS mode," to run it (as it would with certain other DOS
  1024.    protected-mode programs).
  1025.    
  1026.    Earlier versions of LOADLIN sometimes required a package called
  1027.    REALBIOS.COM, which required a boot procedure on an (almost) blank
  1028.    floppy to map the REALBIOS interrupt vectors (prior to the loading 
  1029.    any software drivers). (Current versions don't seem to ship with it
  1030.    and don't seem to need it).
  1031.    
  1032.    [Jim Dennis]
  1033.    
  1034.    
  1035. 3.11 How can I boot Linux from OS/2's Boot Manager?
  1036.  
  1037.     1. Create a partition using OS/2's FDISK.EXE (Not Linux's fdisk).
  1038.     2. Format the partition under OS/2, either with FAT or HPFS. This 
  1039.        so that OS/2 knows about the partition being formatted. (This s
  1040.        is not necessary with OS/2 `warp' 3.0.)
  1041.     3. Add the partition to the Boot Manager.
  1042.     4. Boot Linux, and create a file system on the partition using mkf
  1043.        -t ext2 or mke2fs. At this point you may, if you like, use Linu
  1044.        fdisk to change the code of the new partition to type 83 (Linux
  1045.        Native)--this may help some automated installation scripts find
  1046.        the right partition to use.
  1047.     5. Install Linux on the partition.
  1048.     6. Install LILO on the Linux partition--NOT on the master boot rec
  1049.        of the hard drive. This installs LILO as a second-stage boot
  1050.        loader on the Linux partition itself, to start up the kernel
  1051.        specified in the LILO configuration file. To do this, you shoul
  1052.        put
  1053. boot = /dev/hda2
  1054.        (where /dev/hda2 is the partition you want to boot from) in you
  1055.        /etc/lilo/config or /etc/lilo.config file.
  1056.     7. Make sure that it is the Boot Manager partition that is marked
  1057.        active, so that you can use Boot Manager to choose what to boot
  1058.        
  1059.    There is a set of HOWTO's on the subject of multi-boot systems on t
  1060.    LDP Home Page, http://sunsite.unc.edu/LDP/.
  1061.    
  1062.    
  1063. 3.12 How can I share a swap partition between Linux and MS Windows?
  1064.  
  1065.    See the Mini-HOWTO on the subject. The Mini-HOWTO is currently
  1066.    unmaintained but is available at
  1067.    ftp://sunsite.unc.edu/pub/Linux/docs/HOWTO/mini/unmaintained.
  1068.    
  1069.    
  1070.    contents
  1071.    
  1072.    
  1073. 4. Linux's handling of file systems, disks, and drives
  1074.  
  1075.    
  1076. 4.1 How can I get Linux to work with my disk?
  1077.  
  1078.    If your disk is an IDE or EIDE drive, you should read the file
  1079.    /usr/src/linux/drivers/block/README.ide (part of the Linux kernel
  1080.    source code). This README contains many helpful hints about IDE
  1081.    drives. Many modern IDE controllers do translation between `physica
  1082.    cylinders/heads/sectors, and `logical' ones.
  1083.    
  1084.    SCSI disks are accessed by linear block numbers. The BIOS invents s
  1085.    `logical' cylinder/head/sector fiction to support DOS.
  1086.    
  1087.    An IBM PC-compatible BIOS will usually not be able to access
  1088.    partitions which extend beyond 1024 logical cylinders, and will mak
  1089.    booting a Linux kernel from such partitions using LILO problematic 
  1090.    best.
  1091.    
  1092.    You can still use such partitions for Linux or other operating syst
  1093.    that access the controller directly.
  1094.    
  1095.    It's recommend that you create at least one Linux partition entirel
  1096.    under the 1024 logical cylinder limit, and boot from that. The othe
  1097.    partitions will then be okay.
  1098.    
  1099.    Also there seems to be a bit of trouble with the newer Ultra-DMA
  1100.    drives. I haven't gotten the straight scoop on them--but they are
  1101.    becoming a very common problem at the SVLUG installfests. When you 
  1102.    get 8 to 12 Gig drives for $200 to $300 it's no wonder.
  1103.    
  1104.    [Jim Dennis]
  1105.    
  1106.    
  1107. 4.2 How can I undelete files?
  1108.  
  1109.    In general, this is very hard to do on Unices because of their
  1110.    multitasking nature. Undelete functionality for the ext2fs file sys
  1111.    is being worked on, but don't hold your breath.
  1112.    
  1113.    There are a number of packages available which instead provide new
  1114.    commands for deleting and copying which move deleted files into a
  1115.    `wastebasket' directory. The files can be recovered until cleaned o
  1116.    automatically by background processing.
  1117.    
  1118.    Alternatively, you can search the raw disk device which holds the f
  1119.    system in question. This is hard work, and you will need to be logg
  1120.    in as root to do this.
  1121.    
  1122.    
  1123. 4.3 Is there a defragmenter for ext2fs etc.?
  1124.  
  1125.    Yes. There is defrag, a Linux file system defragmenter for ext2,
  1126.    Minix, and old-style ext file systems. It is available at
  1127.    sunsite.unc.edu/pub/Linux/system/filesystems/defrag-0.70.tar.gz.
  1128.    
  1129.    Users of the ext2 file system can probably do without defrag, becau
  1130.    ext2 contains extra code to keep fragmentation reduced even in very
  1131.    full file systems.
  1132.    
  1133.    
  1134. 4.4 How do I format and create a file system on a floppy?
  1135.  
  1136.    To format a 3.5-inch, high density floppy:
  1137. $ fdformat /dev/fd0H1440
  1138. $ mkfs -t ext2 -m 0 /dev/fd0H1440 1440
  1139.  
  1140.    For a 5.25 inch floppy, use fd0h1200 and 1200 as appropriate. For t
  1141.    `B' drive use fd1 instead of fd0.
  1142.    
  1143.    The -m 0 option tells mkfs.ext2 not to reserve any space on the dis
  1144.    for the superuser--usually the last 10% is reserved for root.
  1145.    
  1146.    The first command performs a low-level format. The second creates a
  1147.    empty file system. You can mount the floppy like a hard disk partit
  1148.    and simply cp and mv files, etc.
  1149.    
  1150.    Device naming conventions generally are the same as for other Unice
  1151.    They can be found in Matt Welsh's Installation and Getting Started
  1152.    Guide. (See "Where can I get the HOWTO's and other
  1153.    documentation? ") A more detailed and technical description is Linu
  1154.    Allocated Devices by H. Peter Anvin, hpa@zytor.com, which is
  1155.    included in LaTeX and ASCII form in the kernel source distribution
  1156.    (probably in /usr/src/kernel/Documentation), as devices.tex and
  1157.    devices.txt.
  1158.    
  1159.    
  1160. 4.5 I get nasty messages about inodes, blocks, and the like.
  1161.  
  1162.    You may have a corrupted file system, probably caused by not shutti
  1163.    Linux down properly before turning off the power or resetting. You
  1164.    need to use a recent shutdown program to do this--for example, the 
  1165.    included in the util-linux package, available on sunsite and tsx-11
  1166.    
  1167.    If you're lucky, the program fsck (or e2fsck or xfsck as appropriat
  1168.    if you don't have the automatic fsck front-end) will be able to rep
  1169.    your file system. If you're unlucky, the file system is trashed, an
  1170.    you'll have to re-initialize it with mkfs (or mke2fs, mkxfs, etc.),
  1171.    and restore from a backup.
  1172.    
  1173.    NB: don't try to check a file system that's mounted read/write--thi
  1174.    includes the root partition, if you don't see
  1175.    VFS: mounted root ... read-only
  1176.  
  1177.    at boot time.
  1178.    
  1179.    
  1180. 4.6 My swap area isn't working.
  1181.  
  1182.    When you boot (or enable swapping manually) you should see
  1183.         Adding Swap: NNNNk swap-space
  1184.  
  1185.    If you don't see any messages at all you are probably missing
  1186. swapon -av
  1187.  
  1188.    (the command to enable swapping) in your /etc/rc.local or /etc/rc.d
  1189.    (the system startup scripts), or have forgotten to make the right
  1190.    entry in /etc/fstab:
  1191.    
  1192. /dev/hda2       none       swap       sw
  1193.  
  1194.    for example.
  1195.    
  1196.    If you see
  1197. Unable to find swap-space signature
  1198.  
  1199.    you have forgotten to run mkswap. See the manual page for details; 
  1200.    works much like mkfs.
  1201.    
  1202.    Running, 'free' in addition to showing free memory, should display:
  1203.              total       used       free
  1204. Swap:        10188       2960       7228
  1205.  
  1206.    [Andy Jefferson]
  1207.    
  1208.    Take a look also at the Installation HOWTO for detailed instruction
  1209.    of how to set up a swap area.
  1210.    
  1211.    
  1212. 4.7 How do I remove LILO so my system boots DOS again?
  1213.  
  1214.    Using DOS (MS-DOS 5.0 or later, or OS/2), type FDISK /MBR (which is
  1215.    not documented). This will restore a standard MS-DOS Master Boot
  1216.    Record. If you have DR-DOS 6.0, go into FDISK in the normal way and
  1217.    then select the `Re-write Master Boot Record' option.
  1218.    
  1219.    If you don't have MS-DOS or DR-DOS, you need to have the boot secto
  1220.    that LILO saved when you first installed it. You did keep that file
  1221.    didn't you? It's probably called boot.0301 or some such. Type
  1222.    dd if=boot.0301 of=/dev/hda bs=445 count=1
  1223.  
  1224.    (or /dev/sda if you're using a SCSI disk). This may also wipe out y
  1225.    partition table, so beware! If you're desperate, you could use
  1226.    dd if=/dev/zero of=/dev/hda bs=512 count=1
  1227.  
  1228.    This will erase your partition table and boot sector completely: yo
  1229.    can then reformat the disk using your favorite software. But this w
  1230.    render the contents of your disk inaccessible--you'll lose it all
  1231.    unless you're an expert.
  1232.    
  1233.    Note that the DOS MBR boots whichever (single!) partition is flagge
  1234.    as `active'. You may need to use fdisk to set and clear the active
  1235.    flags on partitions appropriately.
  1236.    
  1237.    
  1238. 4.8 Why can't I use fdformat except as root?
  1239.  
  1240.    The system call to format a floppy can only be done as root,
  1241.    regardless of the permissions of /dev/fd0*. If you want any user to
  1242.    able to format a floppy, try getting the fdformat2 program. This wo
  1243.    around the problems by being setuid to root.
  1244.    
  1245.    
  1246. 4.9 My ext2fs partitions are checked each time I reboot.
  1247.  
  1248.    See "EXT2-fs: warning: mounting unchecked file system.".
  1249.    
  1250.    
  1251. 4.10 My root file system is read-only!
  1252.  
  1253.    Remount it. If /etc/fstab is correct, you can simply
  1254. mount -n -o remount /
  1255.  
  1256.    If /etc/fstab is wrong, you must give the device name and possibly 
  1257.    type, too: e.g.
  1258. mount -n -o remount -t ext2 /dev/hda2 /
  1259.  
  1260.    To understand how you got into this state, see, "EXT2-fs:
  1261.    warning: mounting unchecked file system."
  1262.    
  1263.    
  1264. 4.11 I have a huge /proc/kcore! Can I delete it?
  1265.  
  1266.    None of the files in /proc are really there--they're all, "pretend,
  1267.    files made up by the kernel, to give you information about the syst
  1268.    and don't take up any hard disk space.
  1269.    
  1270.    /proc/kcore is like an `alias' for the memory in your computer. Its
  1271.    size is the same as the amount of RAM you have, and if you read it 
  1272.    a file, the kernel does memory reads.
  1273.    
  1274.    
  1275. 4.12 My AHA1542C doesn't work with Linux.
  1276.  
  1277.    The option to allow disks with more than 1024 cylinders is only
  1278.    required as a workaround for a PC-compatible BIOS misfeature and
  1279.    should be turned `off' under Linux. For older Linux kernels you nee
  1280.    to turn off most of the `advanced BIOS' options--all but the one ab
  1281.    scanning the bus for bootable devices.
  1282.    
  1283.    
  1284.    contents
  1285.    
  1286.    
  1287. 5. Porting, compiling and obtaining programs
  1288.  
  1289.    
  1290. 5.1 How do I compile programs?
  1291.  
  1292.    Most Linux software is written in C and compiled with the GNU C
  1293.    compiler. GCC is a part of every Linux distribution. The latest
  1294.    compiler version, documentation, and patches are on
  1295.    ftp://ftp.gnu.org/pub/gnu/.
  1296.    
  1297.    Programs that are written in C++ must be compiled with the GNU G++
  1298.    compiler, which is also included in Linux distributions and availab
  1299.    from the same place as GCC.
  1300.    
  1301.    To build version 2.0.x kernels, you will need GCC version 2.7.2.x.
  1302.    Trying to build a Linux kernel with a different compiler, like GCC
  1303.    2.8.x, EGCS, or PGCC, may cause problems until code dependencies of
  1304.    the 2.7.2.x compilers are fixed.
  1305.    
  1306.    Information on the EGCS compiler is at htmlurl
  1307.    url="http://egcs.cygnus.com" name="http://egcs.cygnus.com">.
  1308.    
  1309.    Note that at this time, the kernel developers are not answering bug
  1310.    requests for 2.0.x version kernels, but instead are concentrating o
  1311.    developing 2.1.x version kernels.
  1312.    
  1313.    [J.H.M. Dassen]
  1314.    
  1315.    
  1316. 5.2 How do I port XXX to Linux?
  1317.  
  1318.    In general, Unix programs need very little porting. Simply follow t
  1319.    installation instructions. If you don't know--and don't know how to
  1320.    find out--the answers to some of the questions asked during the
  1321.    installation procedure, you can guess, but this tends to produce bu
  1322.    programs. In this case, you're probably better off asking someone e
  1323.    to do the port.
  1324.    
  1325.    If you have a BSD-ish program, you should try using -I/usr/include/
  1326.    and -lbsd on the appropriate parts of the compilation lines.
  1327.    
  1328.    
  1329. 5.3 What is ld.so and where do I get it?
  1330.  
  1331.    Ld.so is the dynamic library loader. Each binary using shared
  1332.    libraries used to have about 3K of start-up code to find and load t
  1333.    shared libraries. Now that code has been put in a special shared
  1334.    library, /lib/ld.so, where all binaries can look for it, so that it
  1335.    wastes less disk space, and can be upgraded more easily.
  1336.    
  1337.    Ld.so can be obtained from tsx-11.mit.edu/pub/linux/packages/GCC/
  1338.    and mirror sites. The latest version at the time of writing is
  1339.    ld.so.1.9.5.tar.gz.
  1340.    
  1341.    /lib/ld-linux.so.1 is the same thing for ELF ("What's all this
  1342.    about ELF? ") and comes in the same package as the a.out loader.
  1343.    
  1344.    
  1345. 5.4 How do I upgrade the libraries withough trashing my system?
  1346.  
  1347.    Note: You should always have a rescue disk set ready when you perfo
  1348.    this procedure, in the likely event that something goes wrong!
  1349.    
  1350.    This procedure is especially difficult if you're upgrading very old
  1351.    libraries like libc4. But you should be able to keep libc4 on the s
  1352.    system with libc5 libraries for the programs that still need them. 
  1353.    same holds true for upgrading from libc5 to the newer-yet glibc2
  1354.    libraries.
  1355.    
  1356.    The problem with upgrading dynamic libraries is that, the moment yo
  1357.    remove the old libraries, the utilities that you need to upgrade to
  1358.    the new version of the libraries don't work. There are ways around
  1359.    around this. One is to temporarily place a spare copy of the run ti
  1360.    libraries, which are in /lib/, in /usr/lib/, or /usr/local/lib/, or
  1361.    another directory that is listed in the /etc/ld.so.conf file.
  1362.    
  1363.    For example, when upgrading libc5 libraries, the files in /lib/ mig
  1364.    look something like:
  1365.    
  1366. libc.so.5
  1367. libc.so.5.4.33
  1368. libm.so.5
  1369. libm.so.5.0.9
  1370.  
  1371.    These are the C libraries and the math libraries. Copy them to anot
  1372.    directory that is listed in /etc/ld.so.conf, like /usr/lib/.
  1373.    
  1374. cp -df /lib/libc.so.5* /usr/lib/
  1375. cp -df /lib/libm.so.5* /usr/lib/
  1376. ldconfig
  1377.  
  1378.    Be sure to run ldconfig to upgrade the library configuration.
  1379.    
  1380.    The files libc.so.5 and libm.so.5 are symbolic links to the actual
  1381.    library files. When you upgrade, the new links will not be created 
  1382.    the old links are still there, unless you use the -f flag with cp. 
  1383.    -d flag to cp will copy the symbolic link itself, and not the file 
  1384.    points to.
  1385.    
  1386.    If you need to overwrite the link to the library directly, use the 
  1387.    flag with ln.
  1388.    
  1389.    For example, to copy new libraries over the old ones, try this. Mak
  1390.    symbolic link to the new libraries first, then copy both the librar
  1391.    and the links to /lib/, with the following commands.
  1392. ln -sf ./libm.so.5.0.48 libm.so.5
  1393. ln -sf ./libc.so.5.0.48 libc.so.5
  1394. cp -df libm.so.5* /lib
  1395. cp -df libc.so.5* /lib
  1396.  
  1397.    Again, remember to run ldconfig after you copy the libraries.
  1398.    
  1399.    If you are satisfied that everything is working correctly, you can
  1400.    remove the temporary copies of the old libraries from /usr/lib/ or
  1401.    wherever you copied them.
  1402.    
  1403.    
  1404. 5.5 Has anyone ported / compiled / written XXX for Linux?
  1405.  
  1406.    First, look in the Linux Software Map--it's at
  1407.    sunsite.unc.edu/pub/Linux/docs/linux-software-map, and on the
  1408.    other FTP sites. A search engine is available on the World Wide Web
  1409.    http://www.boutell.com/lsm/.
  1410.    
  1411.    Check the FTP sites ("Where can I get Linux material by FTP?
  1412.    ") first--search the ls-lR or INDEX files for appropriate strings.
  1413.    
  1414.    Also look at the Linux Projects Map,
  1415.    ftp.ix.de/pub/ix/Linux/docs/Projects-Map.gz.
  1416.    
  1417.    There's a search engine for Linux FTP archives at
  1418.    http://lfw.linuxhq.com/
  1419.    
  1420.    Also check out the Freshmeat Web site http://www.freshmeat.org,
  1421.    which is really cool. ("What online/free periodicals exist for
  1422.    Linux? "
  1423.    
  1424.    If you don't find anything, you could download the sources to the
  1425.    program yourself and compile them. See "How do I port XXX to
  1426.    Linux? " If it's a large package that may require some porting, pos
  1427.    a message to comp.os.linux.development.apps.
  1428.    
  1429.    If you compile a large-ish program, please upload it to one or more
  1430.    the FTP sites, and post a message to comp.os.linux.announce (submit
  1431.    your posting to linux-announce@news.ornl.gov).
  1432.    
  1433.    If you're looking for an application program, the chances are that
  1434.    someone has already written a free version. The comp.sources.wanted
  1435.    FAQ has instructions for finding the source code.
  1436.    
  1437.    
  1438. 5.6 Can I use code or a compiler compiled for a 486 on my 386?
  1439.  
  1440.    Yes, unless it's the kernel.
  1441.    
  1442.    The -m486 option to GCC, which is used to compile binaries for x486
  1443.    machines, merely changes certain optimizations. This makes for
  1444.    slightly larger binaries that run somewhat faster on a 486. They st
  1445.    work fine on a 386, though, with a small performance hit.
  1446.    
  1447.    However, from version 1.3.35 the kernel uses 486 or Pentium-specifi
  1448.    instructions if configured for a 486 or Pentium, thus making it
  1449.    unusable on a 386.
  1450.    
  1451.    GCC can be configured for a 386 or 486; the only difference is that
  1452.    configuring it for a 386 makes -m386 the default and configuring fo
  1453.    486 makes -m486 the default. In either case, these can be overridde
  1454.    on a per-compilation basis or by editing
  1455.    /usr/lib/gcc-lib/i*-linux/n.n.n/specs.
  1456.    
  1457.    There is an Alpha version of GCC which knows how to do optimization
  1458.    well for the 586, but it is quite unreliable, especially at high
  1459.    optimization settings. The Pentium GCC can be found on tsx-11.mit.e
  1460.    in /pub/linux/ALPHA/pentium-gcc. I'd recommend using the ordinary 4
  1461.    GCC instead; word has it that using -m386 produces code that's bett
  1462.    for the Pentium, or at least slightly smaller.
  1463.    
  1464.    
  1465. 5.7 What does gcc -O6 do?
  1466.  
  1467.    Currently, the same as -O2 (GCC 2.5) or -O3 (GCC 2.6, 2.7). Any num
  1468.    greater than that does the same thing. The Makefiles of newer kerne
  1469.    use -O2, and you should probably do the same.
  1470.    
  1471.    
  1472. 5.8 Where are linux/*.h and asm/*.h?
  1473.  
  1474.    The files /usr/include/linux/ and /usr/include/asm/ are often soft
  1475.    links to the directories where the kernel headers are. They are
  1476.    usually under /usr/src/kernel*/.
  1477.    
  1478.    If you don't have the kernel sources, download them--see, "How
  1479.    do I upgrade/recompile my kernel? "
  1480.    
  1481.    Then, use rm to remove any garbage, and ln to create the links:
  1482. rm -rf /usr/include/linux /usr/include/asm
  1483. ln -sf /usr/src/linux/include/linux /usr/include/linux
  1484. ln -sf /usr/src/linux/include/asm /usr/include/asm
  1485.  
  1486.    /usr/src/linux/include/asm/ is a symbolic link to an
  1487.    architecture-specific asm directory--if you have a freshly unpacked
  1488.    kernel source tree, you must make symlinks. You'll also find that y
  1489.    may need to do `make config' in a newly-unpacked kernel source tree
  1490.    to create linux/autoconf.h.
  1491.    
  1492.    
  1493. 5.9 I get errors when I try to compile the kernel.
  1494.  
  1495.    See the previous question regarding the header files.
  1496.    
  1497.    Remember that when you apply a patch to the kernel, you must use th
  1498.    -p0 or -p1 option: otherwise, the patch may be misapplied. See the
  1499.    patch manual page for details.
  1500.    
  1501.    "ld: unrecognized option `-qmagic"' means that you should get a
  1502.    newer linker, from ftp://tsx-11.mit.edu/pub/linux/packages/GCC/,
  1503.    in the file binutils-2.8.1.0.1.bin.tar.gz.
  1504.    
  1505.    
  1506. 5.10 How do I make a shared library?
  1507.  
  1508.    For ELF,
  1509.    gcc -fPIC -c *.c
  1510.    gcc -shared -Wl,-soname,libfoo.so.1 -o libfoo.so.1.0 *.o
  1511.  
  1512.    For a.out, get tools-n.nn.tar.gz from tsx-11.mit.edu, in
  1513.    /pub/linux/packages/GCC/src/. It comes with documentation that will
  1514.    tell you what to do. Note that a.out shared libraries are a very
  1515.    tricky business. Consider upgrading your libraries to ELF shared
  1516.    libraries. See the ELF HOWTO, at
  1517.    sunsite.unc.edu/pub/Linux/docs/HOWTO/
  1518.    
  1519.    
  1520. 5.11 My executables are (very) large.
  1521.  
  1522.    With an ELF compiler ("What's all this about ELF? "), the most
  1523.    common cause of large executables is the lack of an appropriate .so
  1524.    library link for one of the libraries you're using. There should be
  1525.    link like libc.so for every library like libc.so.5.2.18.
  1526.    
  1527.    With an a.out compiler the most common cause of large executables i
  1528.    the -g linker (compiler) flag. This produces (as well as debugging
  1529.    information in the output file) a program which is statically
  1530.    linked--one which includes a copy of the C library instead of a
  1531.    dynamically linked copy.
  1532.    
  1533.    Other things worth investigating are -O and -O2, which enable
  1534.    optimization (check the GCC documentation), and -s (or the strip
  1535.    command) which strip the symbol information from the resulting bina
  1536.    (making debugging totally impossible).
  1537.    
  1538.    You may wish to use -N on very small executables (less than 8K with
  1539.    the -N), but you shouldn't do this unless you understand its
  1540.    performance implications, and definitely never with daemons.
  1541.    
  1542.    
  1543. 5.12 Does Linux support threads or lightweight processes?
  1544.  
  1545.    As well as the Unix multiprocessing model involving heavyweight
  1546.    processes, which is of course part of the standard Linux kernel, th
  1547.    are several implementations of lightweight processes or threads.
  1548.    Recent kernels implement a thread model, kthreads. In addition, the
  1549.    are the following packages available for Linux.
  1550.      * GNU glibc2 for Linux has optional support for threads. The arch
  1551.        is available from the same place as glibc2,
  1552.        ftp://ftp.gnu.org/pub/gnu
  1553.      * In sipb.mit.edu:/pub/pthread or
  1554.        ftp.ibp.fr:/pub/unix/threads/pthreads. Documentation isn't in t
  1555.        package, but is available on the World Wide Web at
  1556.        http://www.mit.edu:8001/people/proven/home_page.html. Newer Lin
  1557.        libc's contain the pthreads source. The GNU Ada compiler on
  1558.        sunsite.unc.edu in
  1559.        /pub/Linux/devel/lang/ada/gnat-3.01-linux+elf.tar.gz contains
  1560.        binaries made from that source code.
  1561.      * In ftp.cs.washington.edu:/pub/qt-001.tar.Z is QuickThreads. Mor
  1562.        information can be found in the technical report, available on 
  1563.        same site as /tr/1993/05/UW-CSE-93-05-06.PS.Z.
  1564.      * In gummo.doc.ic.ac.uk/rex/ is lwp, a very minimal implementatio
  1565.      * In ftp.cs.fsu.edu:/pub/PART/, an Ada implementation. This is
  1566.        useful mainly because it has a lot of Postscript papers that
  1567.        you'll find useful in learning more about threads. This is not
  1568.        directly usable under Linux.
  1569.        
  1570.    Please contact the authors of the packages in question for details.
  1571.    
  1572.    
  1573. 5.13 Where can I get `lint' for Linux?
  1574.  
  1575.    Roughly equivalent functionality is built into GCC. Use the -Wall
  1576.    option to turn on most of the useful extra warnings. See the GCC
  1577.    manual for more details (type control-h followed by i in Emacs and
  1578.    select the entry for GCC).
  1579.    
  1580.    There is a freely available program called `lclint' that does much 
  1581.    same thing as traditional lint. The announcement and source code ar
  1582.    available at on larch.lcs.mit.edu in /pub/Larch/lclint/; on the Wor
  1583.    Wide Web, look at http://larch-www.lcs.mit.edu:8001/larch/lclint.ht
  1584.    
  1585.    
  1586. 5.14 Where can I find kermit for Linux?
  1587.  
  1588.    Kermit is distributed under a non-GPL copyright that makes its term
  1589.    of distribution somewhat different. The sources and some binaries a
  1590.    available on kermit.columbia.edu.
  1591.    
  1592.    The WWW Home Page of the Columbia University Kermit project is
  1593.    http://www.columbia.edu/kermit/.
  1594.    
  1595.    
  1596.    contents
  1597.    
  1598.    
  1599. 6. Solutions to common miscellaneous problems.
  1600.  
  1601.    
  1602. 6.1 free dumps core.
  1603.  
  1604.    In Linux 1.3.57 and later, the format of /proc/meminfo was changed 
  1605.    a way that the implementation of free doesn't understand.
  1606.    
  1607.    Get the latest version, from sunsite.unc.edu, in
  1608.    /pub/Linux/system/Status/ps/procps-0.99.tgz.
  1609.    
  1610.    
  1611. 6.2 My clock is very wrong.
  1612.  
  1613.    There are two clocks in your computer. The hardware (CMOS) clock ru
  1614.    even when the computer is turned off, and is used when the system
  1615.    starts up and by DOS (if you use DOS). The ordinary system time, sh
  1616.    and set by "date," is maintained by the kernel while Linux is
  1617.    running.
  1618.    
  1619.    You can display the CMOS clock time, or set either clock from the
  1620.    other, with /sbin/clock program--see "man 8 clock."
  1621.    
  1622.    There are various other programs that can correct either or both
  1623.    clocks for system drift or transfer time across the network. Some o
  1624.    them may already be installed on your system. Try looking for adjti
  1625.    (corrects for drift), netdate, and getdate (get the time from the
  1626.    network), or xntp (accurate, full-featured network time daemon).
  1627.    
  1628.    
  1629. 6.3 Setuid scripts don't seem to work.
  1630.  
  1631.    That's right. This feature has been disabled in the Linux kernel on
  1632.    purpose, because setuid scripts are almost always a security hole.
  1633.    Sudo and SuidPerl can provide more security that setuid scripts or
  1634.    binaries, especially if execute permissions are limited to a certai
  1635.    user ID or group ID.
  1636.    
  1637.    If you want to know why setuid scripts are a security hole, read th
  1638.    FAQ for comp.unix.questions.
  1639.    
  1640.    
  1641. 6.4 Free memory as reported by free keeps shrinking.
  1642.  
  1643.    The "free" figure printed by free doesn't include memory used as a
  1644.    disk buffer cache--shown in the "buffers" column. If you want to
  1645.    know how much memory is really free add the "buffers" amount to
  1646.    "free"--newer versions of free print an extra line with this info.
  1647.    
  1648.    The disk buffer cache tends to grow soon after starting Linux up. A
  1649.    you load more programs and use more files, the contents get cached.
  1650.    will stabilize after a while.
  1651.    
  1652.    
  1653. 6.5 When I add more memory, the system slows to a crawl.
  1654.  
  1655.    This is a common symptom of a failure to cache the additional memor
  1656.    The exact problem depends on your motherboard.
  1657.    
  1658.    Sometimes you have to enable caching of certain regions in your BIO
  1659.    setup. Look in the CMOS setup and see if there is an option to cach
  1660.    the new memory area which is currently switched off. This is
  1661.    apparently most common on a '486.
  1662.    
  1663.    Sometimes the RAM has to be in certain sockets to be cached.
  1664.    
  1665.    Sometimes you have to set jumpers to enable caching.
  1666.    
  1667.    Some motherboards don't cache all of the RAM if you have more RAM p
  1668.    amount of cache than the hardware expects. Usually a full 256K cach
  1669.    will solve this problem.
  1670.    
  1671.    If in doubt, check the manual. If you still can't fix it because th
  1672.    documentation is inadequate, you might like to post a message to
  1673.    comp.os.linux.hardware giving all of the details--make, model numbe
  1674.    date code, etc., so other Linux users can avoid it.
  1675.    
  1676.    
  1677. 6.6 Some programs (e.g. xdm) won't let me log in.
  1678.  
  1679.    You are probably using non-shadow password programs and are using
  1680.    shadow passwords.
  1681.    
  1682.    If so, you have to get or compile a shadow password version of the
  1683.    programs in question. The shadow password suite can be found at
  1684.    tsx-11.mit.edu:/pub/linux/sources/usr.bin/shadow/. This is the sour
  1685.    code. The binaries are probably in linux/binaries/usr.bin/.
  1686.    
  1687.    
  1688. 6.7 Some programs let me log in with no password.
  1689.  
  1690.    You probably have the same problem as in "Some programs (e.g.
  1691.    xdm) won't let me log in. ", with an added wrinkle.
  1692.    
  1693.    If you are using shadow passwords, you should put a letter `x' or a
  1694.    asterisk in the password field of /etc/passwd for each account, so
  1695.    that if a program doesn't know about the shadow passwords it won't
  1696.    think it's a passwordless account and let anyone in.
  1697.    
  1698.    
  1699. 6.8 My machine runs very slowly when I run GCC / X / ...
  1700.  
  1701.    You may have too little real memory. If you have less RAM than all 
  1702.    programs you're running at once, Linux will swap to your hard disk
  1703.    instead and thrash horribly. The solution in this case is to not ru
  1704.    so many things at once or buy more memory. You can also reclaim som
  1705.    memory by compiling and using a kernel with less options configured
  1706.    See "How do I upgrade/recompile my kernel? ".
  1707.    
  1708.    You can tell how much memory and swap you're using with the free
  1709.    command, or by typing:
  1710. cat /proc/meminfo
  1711.  
  1712.    If your kernel is configured with a RAM disk, this is probably wast
  1713.    space and will cause things to go slowly. Use LILO or rdev to tell 
  1714.    kernel not to allocate a RAM disk (see the LILO documentation or ty
  1715.    man rdev).
  1716.    
  1717.    
  1718. 6.9 I can only log in as root.
  1719.  
  1720.    You probably have some permission problems, or you have a file
  1721.    /etc/nologin.
  1722.    
  1723.    In the latter case, put rm -f /etc/nologin in your /etc/rc.local or
  1724.    /etc/rc.d/* scripts.
  1725.    
  1726.    Otherwise, check the permissions on your shell, and any file names
  1727.    that appear in error messages, and also the directories that contai
  1728.    these files, up to and including the root directory.
  1729.    
  1730.    
  1731. 6.10 My screen is all full of weird characters instead of letters.
  1732.  
  1733.    You probably sent some binary data to your screen by mistake. Type
  1734.    echo '\033c' to fix it. Many Linux distributions have a command,
  1735.    "reset," that does this.
  1736.    
  1737.    If that doesn't help, try a direct screen escape command.
  1738. echo <Ctrl-V><Ctrl-O>
  1739.  
  1740.    This resets the default font of a Linux console. Remember to hold d
  1741.    the Control key and type the letter, instead of, for example,
  1742.    `Ctrl-V'. The sequence
  1743. echo <Ctrl-V><Esc>c
  1744.  
  1745.    causes a full screen reset. If there's data left on the shell comma
  1746.    line after typing a binary file, press Ctrl-C a few times to restor
  1747.    the shell command line.
  1748.    
  1749.    [Bernhard Gabler]
  1750.    
  1751.    
  1752. 6.11 I have screwed up my system and can't log in to fix it.
  1753.  
  1754.    Reboot from an emergency floppy or floppy pair. For example, the
  1755.    Slackware boot and root disk pair in the install subdirectory of th
  1756.    Slackware distribution.
  1757.    
  1758.    There are also two, do-it-yourself rescue disk creation packages in
  1759.    sunsite.unc.edu/pub/Linux/system/Recovery. These are better
  1760.    because they have your own kernel on them, so you don't run the ris
  1761.    of missing devices and file systems.
  1762.    
  1763.    Get to a shell prompt and mount your hard disk with something like
  1764. mount -t ext2 /dev/hda1 /mnt
  1765.  
  1766.    Then your file system is available under the directory /mnt and you
  1767.    can fix the problem. Remember to unmount your hard disk before
  1768.    rebooting (cd somewhere else first, or it will say it's busy).
  1769.    
  1770.    
  1771. 6.12 I've discovered a huge security hole in rm!
  1772.  
  1773.    No you haven't. You are obviously new to Unix and need to read a go
  1774.    book to find out how things work. Clue: the ability to delete files
  1775.    under Unix depends on permission to write in that directory.
  1776.    
  1777.    
  1778. 6.13 lpr(1) and/or lpd(8) don't work.
  1779.  
  1780.    First make sure that your /dev/lp* port is correctly configured. It
  1781.    IRQ (if any) and port address need to match the settings on the
  1782.    printer card. You should be able to dump a file directly to the
  1783.    printer.
  1784. cat the_file >/dev/lp1
  1785.  
  1786.    If lpr gives you a message like "myname@host: host not found," it
  1787.    may mean that the TCP/IP loopback interface, lo, isn't working
  1788.    properly. Loopback support is compiled into most distribution kerne
  1789.    Check that the interface is configured with the ifconfig command. B
  1790.    Internet convention, the network number is 127.0.0.0, and the local
  1791.    host address is 127.0.0.1. If everything is configured correctly, y
  1792.    should be able to telnet to your own machine and get a login prompt
  1793.    
  1794.    Make sure that /etc/hosts.lpd contains the machine's host name.
  1795.    
  1796.    If your machine has a network-aware lpd, like the one that comes wi
  1797.    LPRng, make sure that /etc/lpd.perms is configured correctly.
  1798.    
  1799.    Also look at the Printing-HOWTO "Where can I get the HOWTO's
  1800.    and other documentation? ".
  1801.    
  1802.    
  1803. 6.14 Timestamps on files on MS-DOS partitions are set incorrectly.
  1804.  
  1805.    There is a bug in the program "clock" (often found in /sbin). It
  1806.    miscounts a time zone offset, confusing seconds with minutes or
  1807.    something like that. Get a recent version.
  1808.    
  1809.    
  1810. 6.15 How do I get LILO to boot the vmlinux file?
  1811.  
  1812.    >From kernel versions 1.1.80 on, the compressed kernel image, which
  1813.    what LILO needs to find, is in arch/i386/boot/zImage. The vmlinux f
  1814.    in the root directory is the uncompressed kernel, and you shouldn't
  1815.    try to boot it.
  1816.    
  1817.    This was changed to make it easier to build kernel versions for
  1818.    several different processors from one source tree.
  1819.    
  1820.    
  1821.    contents
  1822.    
  1823.    
  1824. 7. How do I do this or find out that ... ?
  1825.  
  1826.    
  1827. 7.1 How can I get scrollback in text mode?
  1828.  
  1829.    With the default US keymap, you can use Shift with the PageUp and
  1830.    PageDown keys. (The gray ones, not the ones on the numeric keypad.)
  1831.    With other keymaps, look in /usr/lib/keytables. You can remap the
  1832.    ScrollUp and ScrollDown keys to be whatever you like. For example, 
  1833.    remap them to the keys on an 84-key, AT keyboard.
  1834.    
  1835.    The "screen" program,
  1836.    http://vector.co.jp/vpack/browse/person/an010455.html provides a
  1837.    searchable scrollback buffer and the ability to take "snapshots" of
  1838.    text-mode screens.
  1839.    
  1840.    You can't increase the amount of scrollback, because it is implemen
  1841.    using the video memory to store the scrollback text. You may be abl
  1842.    to get more scrollback in each virtual console by reducing the tota
  1843.    number of VC's. See linux/tty.h.
  1844.    
  1845.    
  1846. 7.2 How do I switch virtual consoles? How do I enable them?
  1847.  
  1848.    In text mode, press Left Alt-F1 to Alt-F12 to select the consoles t
  1849.    to tty12; Right Alt-F1 gives tty13 and so on. To switch out of X
  1850.    Windows you must press Ctrl-Alt-F1, etc; Alt-F5 or whatever will
  1851.    switch back.
  1852.    
  1853.    If you want to use a VC for ordinary login, it must be listed in
  1854.    /etc/inittab, which controls which terminals and virtual consoles h
  1855.    login prompts. The X Window System needs at least one free VC in or
  1856.    to start.
  1857.    
  1858.    
  1859. 7.3 How do I set the time zone?
  1860.  
  1861.    Change directory to /usr/lib/zoneinfo/. Get the time zone package i
  1862.    you don't have this directory. The source is available as
  1863.    sunsite.unc.edu/pub/Linux/system/admin/time/timesrc-1.2.tar.gz.
  1864.    
  1865.    Then make a symbolic link named localtime pointing to one of the fi
  1866.    in this directory (or a subdirectory), and one called posixrules
  1867.    pointing to localtime. For example:
  1868.    ln -sf US/Mountain localtime
  1869.    ln -sf localtime posixrules
  1870.  
  1871.    This change will take effect immediately--try date(1).
  1872.    
  1873.    The manual page for tzset describes setting the time zone. Some
  1874.    programs recognize the TZ environment variable, but this is not
  1875.    POSIX-correct.
  1876.    
  1877.    You should also make sure that your Linux kernel clock is set to th
  1878.    correct GMT time--type date -u and check that the correct UTC time 
  1879.    displayed. ("My clock is very wrong. ")
  1880.    
  1881.    
  1882. 7.4 What version of Linux and what machine name am I using?
  1883.  
  1884.    Type:
  1885. uname -a
  1886.  
  1887.    
  1888. 7.5 How can I enable or disable core dumps?
  1889.  
  1890.    By using the ulimit command in bash, the limit command in tcsh, or 
  1891.    rlimit command in ksh. See the appropriate manual page for details.
  1892.    
  1893.    This setting affects all programs run from the shell (directly or
  1894.    indirectly), not the whole system.
  1895.    
  1896.    If you wish to enable or disable core dumping for all processes by
  1897.    default, you can change the default setting in linux/sched.h--see t
  1898.    definition of INIT_TASK, and look also in linux/resource.h.
  1899.    
  1900.    
  1901. 7.6 How do I upgrade/recompile my kernel?
  1902.  
  1903.    See the Kernel HOWTO or the README files which come with the kernel
  1904.    release on ftp.cs.helsinki.fi, in /pub/Software/Linux/Kernel/ and
  1905.    mirrors. (See "Where can I get Linux material by FTP? ") You
  1906.    may already have a version of the kernel source code installed on y
  1907.    system, but if it is part of a standard distribution it is likely t
  1908.    be somewhat out of date (this is not a problem if you only want a
  1909.    custom configured kernel, but it probably is if you need to upgrade
  1910.    
  1911.    With newer kernels you can (and should) make all of the following
  1912.    targets. Don't forget that you can specify multiple targets with on
  1913.    command.
  1914. make clean dep install modules modules_install
  1915.  
  1916.    Also remember to update the module dependencies.
  1917. depmod -a
  1918.  
  1919.    Remember that to make the new kernel boot you must run LILO after
  1920.    copying the kernel into your root partition--the Makefile in recent
  1921.    kernels has a special zlilo target for this; try:
  1922. make zlilo
  1923.  
  1924.    Kernel version numbers with an odd minor version (ie, 1.1.x, 1.3.x)
  1925.    are the testing releases; stable production kernels have even minor
  1926.    versions (1.0.x, 1.2.x). If you want to try the testing kernels you
  1927.    should probably subscribe to the linux-kernel mailing list. (See "
  1928.    What mailing lists are there? .")
  1929.    
  1930.    
  1931. 7.7 Can I have more than 3 serial ports by sharing interrupts?
  1932.  
  1933.    Yes, but you won't be able to use simultaneously two ordinary ports
  1934.    which share an interrupt (without some trickery). This is a limitat
  1935.    of the ISA Bus architecture.
  1936.    
  1937.    See the Serial HOWTO for information about possible solutions and
  1938.    workarounds for this problem.
  1939.    
  1940.    
  1941. 7.8 How do I make a bootable floppy?
  1942.  
  1943.    Make a file system on it with bin, etc, lib and dev
  1944.    directories--everything you need. Install a kernel on it and arrang
  1945.    to have LILO boot it from the floppy (see the LILO documentation, i
  1946.    lilo.u.*.ps).
  1947.    
  1948.    If you build the kernel (or tell LILO to tell the kernel) to have a
  1949.    RAM disk the same size as the floppy the RAM disk will be loaded at
  1950.    boot time and mounted as root in place of the floppy.
  1951.    
  1952.    See the Bootdisk HOWTO.
  1953.    
  1954.    
  1955. 7.9 How do I remap my keyboard to UK, French, etc.?
  1956.  
  1957.    For recent kernels, get /pub/Linux/system/Keyboards/kbd-0.90.tar.gz
  1958.    from sunsite.unc.edu. Make sure you get the appropriate version; yo
  1959.    have to use the right keyboard mapping package for your kernel
  1960.    version.
  1961.    
  1962.    For older kernels you have to edit the top-level kernel Makefile, i
  1963.    /usr/src/linux.
  1964.    
  1965.    You may find more helpful information in The Linux Keyboard and
  1966.    Console HOWTO, by Andries Brouwer, at
  1967.    sunsite.unc.edu/pub/Linux/docs/HOWTO.
  1968.    
  1969.    
  1970. 7.10 How do I get NUM LOCK to default to on?
  1971.  
  1972.    Use the setleds program, for example (in /etc/rc.local or one of th
  1973.    /etc/rc.d/* files):
  1974. for t in 1 2 3 4 5 6 7 8
  1975. do
  1976.     setleds +num < /dev/tty$t > /dev/null
  1977. done
  1978.  
  1979.    Setleds is part of the kbd package ("How do I remap my keyboard
  1980.    to UK, French, etc.? ").
  1981.    
  1982.    Alternatively, patch your kernel. You need to arrange for KBD_DEFLE
  1983.    to be defined to (1 << VC_NUMLOCK) when compiling
  1984.    drivers/char/keyboard.c.
  1985.    
  1986.    
  1987. 7.11 How do I set (or reset) my initial terminal colors?
  1988.  
  1989.    The following shell script should work for VGA consoles:
  1990. for n in 1 2 4 5 6 7 8; do
  1991.         setterm -fore yellow -bold on -back blue -store > /dev/tty$n
  1992.         done
  1993.  
  1994.    Substitute your favorite colors, and use /dev/ttyS$n for serial
  1995.    terminals.
  1996.    
  1997.    To make sure they are reset when people log out (if they've been
  1998.    changed):
  1999.    
  2000.    Replace the references to "getty" (or "mingetty" or "uugetty" or
  2001.    whatever) in /etc/inittab with references to "/sbin/mygetty."
  2002. #!/bin/sh
  2003. setterm -fore yellow -bold on -back blue -store > $1
  2004. exec /sbin/mingetty $@
  2005.  
  2006.    [Jim Dennis]
  2007.    
  2008. 7.12 How can I have more than 128Mb of swap?
  2009.  
  2010.    Use several swap partitions or swap files--Linux supports up to 16
  2011.    swap areas, each of up to 128Mb.
  2012.    
  2013.    Very old kernels only supported swap partition sizes up to 16Mb.
  2014.    
  2015.    Linux on machines with 8KB paging, like Alpha and Sparc64, support 
  2016.    swap partition up to 512KB. The 128KB limitation comes from
  2017.    PAGE_SIZE*BITSPERBYTE on machines with 4KB paging, but is 512KB on
  2018.    machines with 8KB paging. The limit is due to the use of a single p
  2019.    allocation map.
  2020.    
  2021.    The file mm/swapfile.c has all of the gory details.
  2022.    
  2023.    [Peter Moulder, Gordon Weast]
  2024.    
  2025.    
  2026.    contents
  2027.    
  2028.    
  2029. 8. Miscellaneous information and questions answered.
  2030.  
  2031.    
  2032. 8.1 How do I program XYZ under Linux?
  2033.  
  2034.    Read the manuals, or a good book on Unix. Manual pages (type "man
  2035.    man") are usually a good source of reference information on exactly
  2036.    how to use a particular command or function.
  2037.    
  2038.    There is also a lot of GNU Info documentation, which is often more
  2039.    useful as a tutorial. Run Emacs and type C-h i, or type info info i
  2040.    you don't have or don't like Emacs. Note that the Emacs libc node m
  2041.    not exactly describe the latest Linux libc, or GNU glibc2. But the 
  2042.    progject and LDP are always looking for volunteers to upgrade their
  2043.    library documentation.
  2044.    
  2045.    Anyway, between the existing Texinfo documentation, and the manual
  2046.    pages in sections 2 and 3, should provide enough information to get
  2047.    started.
  2048.    
  2049.    As with all free software, the best tutorial is the source code
  2050.    itself.
  2051.    
  2052.    The latest release of the Linux manual pages, a collection of usefu
  2053.    GNU Info documentation, and various other information related to
  2054.    programming Linux, can be found on sunsite.unc.edu in
  2055.    /pub/Linux/docs/man-pages.
  2056.    
  2057.    
  2058. 8.2 What's all this about ELF?
  2059.  
  2060.    See the ELF HOWTO by Daniel Barlow--note, this is not the file
  2061.    move-to-elf, which is a blow-by-blow account of how to upgrade to E
  2062.    manually.
  2063.    
  2064.    Linux has two different formats for executables, object files, and
  2065.    object code libraries, known as, "ELF." (The old format is called
  2066.    `a.out'.) They have advantages, including better support for shared
  2067.    libraries and dynamic linking.
  2068.    
  2069.    Both a.out and ELF binaries can coexist on a system. However, they 
  2070.    different shared C libraries, both of which have to be installed.
  2071.    
  2072.    If you want to find out whether your system can run ELF binaries, l
  2073.    in /lib for a file named, "libc.so.5." If it's there, you probably
  2074.    have ELF libraries. If you want to know whether your installation
  2075.    actually is ELF you can pick a representative program, like ls, and
  2076.    run file on it:
  2077. -chiark:~> file /bin/ls
  2078. /bin/ls: Linux/i386 impure executable (OMAGIC) - stripped
  2079.  
  2080. valour:~> file /bin/ls
  2081. /bin/ls: ELF 32-bit LSB executable, Intel 80386, version 1, stripped
  2082.  
  2083.    There is a patch to get 1.2.x to compile using the ELF compilers, a
  2084.    produce ELF core dumps, at tsx-11.mit.edu in /pub/packages/GCC/. Yo
  2085.    do not need the patch merely to run ELF binaries. 1.3.x and later d
  2086.    not need the patch at all.
  2087.    
  2088.    
  2089. 8.3 What is a .gz file ? And a .tgz ? And ... ?
  2090.  
  2091.    .gz (and .z) files are compressed using GNU gzip. You need to use
  2092.    gunzip (which is a symlink to the gzip command which comes with mos
  2093.    Linux installations) to unpack the file.
  2094.    
  2095.    .taz and .tz are tar files (made with Unix tar) compressed using
  2096.    standard Unix compress.
  2097.    
  2098.    .tgz (or .tpz) is a tar file compressed with gzip.
  2099.    
  2100.    .lsm is a Linux Software Map entry, in the form of a short text fil
  2101.    Details about the LSM and the LSM itself are available in the docs
  2102.    subdirectory on sunsite.unc.edu.
  2103.    
  2104.    .deb is a Debian Binary Package - the binary package format used by
  2105.    the Debian GNU/Linux distribution. It is manipulated using dpkg and
  2106.    dpkg-deb (available on Debian systems and from ftp.debian.org).
  2107.    
  2108.    .rpm is a Red Hat RPM package, which is used in the Red Hat
  2109.    distribution. They can be found on ftp.redhat.com.
  2110.    
  2111.    .bz2 is a file compressed by the more recent bzip program.
  2112.    
  2113.    The "file" command can often tell you what a file is.
  2114.    
  2115.    If you find that gzip complains when you try to uncompress a gzip'e
  2116.    file you probably downloaded it in ASCII mode by mistake. You must
  2117.    download most things in binary mode--remember to type binary as a
  2118.    command in FTP before using, "get," to get the file.
  2119.    
  2120.    
  2121. 8.4 What does VFS stand for?
  2122.  
  2123.    Virtual File System. It's the abstraction layer between the user an
  2124.    real file systems like ext2, Minix and MS-DOS. Among other things, 
  2125.    job is to flush the read buffer when it detects a disk change on th
  2126.    floppy disk drive.
  2127. VFS: Disk change detected on device 2/0
  2128.  
  2129.    
  2130. 8.5 What is a BogoMip?
  2131.  
  2132.    "BogoMips" is a contraction of "Bogus MIPS." MIPS stands for
  2133.    (depending who you listen to) Millions of Instructions per Second, 
  2134.    Meaningless Indication of Processor Speed.
  2135.    
  2136.    The number printed at boot time is the result of a kernel timing
  2137.    calibration, used for very short delay loops by some device drivers
  2138.    
  2139.    As a very rough guide, the BogoMips rating for your machine will be
  2140.    approximately:
  2141.      386SX              clock * 0.14
  2142.      386DX              clock * 0.18
  2143.      486Cyrix/IBM       clock * 0.33
  2144.      486SX/DX/DX2       clock * 0.50
  2145.      586                clock * 0.39
  2146.  
  2147.    If the number is wildly lower, you may have the Turbo button or CPU
  2148.    speed set incorrectly, or have some kind of caching problem (as
  2149.    described in "When I add more memory, the system slows to a
  2150.    crawl. .")
  2151.    
  2152.    For values people have seen with other, rarer, chips, see the BogoM
  2153.    Mini-HOWTO, on sunsite.unc.edu in
  2154.    /pub/Linux/docs/howto/mini/BogoMips/.
  2155.    
  2156.    
  2157. 8.6 What is the Linux Journal and where can I get it?
  2158.  
  2159.    The Linux Journal is a monthly magazine (printed on paper) that is
  2160.    available on news stands and via subscription worldwide. Email
  2161.    linux@ssc.com for details. Their URL is http://www.ssc.com/.
  2162.    
  2163.    
  2164. 8.7 What online/free periodicals exist for Linux?
  2165.  
  2166.    There are a number of recent additions to the list of periodicals
  2167.    devoted to Linux.
  2168.      * Linux Gazette. http://www.linuxgazette.com.
  2169.      * Linux Weekly News. http://www.lwn.net.
  2170.      * Slashdot. http://www.slashdot.org.
  2171.      * Freshmeat. http://www.freshmeat.org.
  2172.        
  2173.    [Jim Dennis, Robert Kiesling]
  2174.    
  2175.    
  2176. 8.8 How many people use Linux?
  2177.  
  2178.    Linux is freely available, and no one is required to register their
  2179.    copy with any central authority, so it is difficult to know. Severa
  2180.    businesses survive solely on selling and supporting Linux. The Linu
  2181.    newsgroups are some of the most heavily read on Usenet, so the numb
  2182.    is likely in the hundreds of thousands. Accurate numbers probably
  2183.    don't exist.
  2184.    
  2185.    However, one brave soul, Harald T. Alvestrand,
  2186.    Harald.T.Alvestrand@uninett.no, has decided to try, and asks that
  2187.    if you use Linux, send a message to linux-counter@uninett.no with
  2188.    one of the following subjects: "I use Linux at home," "I use Linux
  2189.    at work," or, "I use Linux at home and at work." He will also
  2190.    accept `third party' registrations--ask him for details.
  2191.    
  2192.    Alternatively, you can register using the WWW forms found at
  2193.    http://domen.uninett.no/~hta/linux/counter.html.
  2194.    
  2195.    He posts his counts to aun.uninett.no in /pub/misc/linux-counter/ o
  2196.    at the web page above.
  2197.    
  2198.    
  2199. 8.9 How should I pronounce Linux?
  2200.  
  2201.    This is a matter of religious debate, of course!
  2202.    
  2203.    If you want to hear Linus himself say how he pronounces it, downloa
  2204.    english.au or swedish.au from ftp.funet.fi (in
  2205.    /pub/Linux/PEOPLE/Linus/SillySounds/). If you have a sound card or 
  2206.    PC-speaker audio driver you can hear them by typing
  2207. cat english.au >/dev/audio
  2208.  
  2209.    The difference isn't in the pronunciation of Linux but in the langu
  2210.    Linus uses to say, "hello."
  2211.    
  2212.    For the benefit of those who don't have the equipment or inclinatio
  2213.    Linus pronounces Linux approximately as Leenus, where the "ee" is
  2214.    pronounced as in "feet," but rather shorter, and the "u" is like a
  2215.    much shorter version of the French "eu" sound in "peur"
  2216.    (pronouncing it as the "u" in "put" is probably passable).
  2217.    
  2218.    
  2219.    contents
  2220.    
  2221.    
  2222. 9. Frequently encountered error messages.
  2223.  
  2224.    
  2225. 9.1 Modprobe can't locate module, "XXX," and similar messages.
  2226.  
  2227.    These types of messages mostly occur at boot time or shutdown. If
  2228.    modprobe, insmod, or rmmod complain about not being able to find a
  2229.    module, add the following to the /etc/modules.conf or
  2230.    /etc/modutils/aliases file, whichever is present on your system.
  2231. alias <module-name> off
  2232.  
  2233.    And use the name of the module that appears in the error message.
  2234.    
  2235.    [J.H.M. Dassen]
  2236.    
  2237.    
  2238. 9.2 Unknown terminal type linux and similar.
  2239.  
  2240.    In early kernels the default console terminal type has changed from
  2241.    "console" to "linux." You must edit /etc/termcap to change the
  2242.    line reading:
  2243. console|con80x25:\
  2244.  
  2245.    to
  2246. linux|console|con80x25:\
  2247.  
  2248.    (there may be an additional dumb in there--if so it should be
  2249.    removed.)
  2250.    
  2251.    To get the editor to work you may need say
  2252. TERM=console
  2253.  
  2254.    (for bash and ksh), or
  2255. setenv TERM console
  2256.  
  2257.    for csh or tcsh.
  2258.    
  2259.    Some programs use /usr/lib/terminfo instead of /etc/termcap. For th
  2260.    programs you should upgrade your terminfo, which is part of ncurses
  2261.    
  2262.    
  2263. 9.3 lp1 on fire
  2264.  
  2265.    This is a joke/traditional error message indicating that some sort 
  2266.    error is being reported by your printer, but that the error status
  2267.    isn't a valid one. It may be that you have some kind of I/O or IRQ
  2268.    conflict-- check your cards' settings. Some people report that they
  2269.    get this message when their printer is switched off. Hopefully it
  2270.    isn't really on fire ...
  2271.    
  2272.    In newer kernels, this message reads, "lp1 reported invalid error
  2273.    status (on fire, eh?)"
  2274.    
  2275.    
  2276. 9.4 INET: Warning: old style ioctl... called!
  2277.  
  2278.    You are trying to use the old network configuration utilities. The 
  2279.    ones can be found on ftp.linux.org.uk in
  2280.    /pub/linux/Networking/PROGRAMS/NetTools/ (source only, I'm afraid).
  2281.    
  2282.    Note that they cannot be used just like the old-style programs. See
  2283.    the NET-2 HOWTO for instructions on how to set up the old-style
  2284.    networking programs correctly. Even better, see the NET-3 HOWTO and
  2285.    upgrade your networking software.
  2286.    
  2287.    
  2288. 9.5 ld: unrecognized option '-m486'
  2289.  
  2290.    You have an old version of ld. Install a newer binutils package--th
  2291.    will contain an updated ld. Look on tsx-11.mit.edu in
  2292.    /pub/linux/packages/GCC/ for binutils-2.6.0.2.bin.tar.gz.
  2293.    
  2294.    
  2295. 9.6 GCC says Internal compiler error.
  2296.  
  2297.    If the fault is repeatable (i.e., it always happens at the same pla
  2298.    in the same file--even after rebooting and trying again, using a
  2299.    stable kernel) you have discovered a bug in GCC. See the GCC Info
  2300.    documentation (type Control-h i in Emacs, and select GCC from the
  2301.    menu) for details on how to report the error--make sure you have th
  2302.    latest version, though.
  2303.    
  2304.    Note that this is probably not a Linux-specific problem. Unless you
  2305.    are compiling a program many other Linux users also compile, you
  2306.    should not post your bug report to any of the comp.os.linux groups.
  2307.    
  2308.    If the problem is not repeatable, you may be experiencing memory
  2309.    corruption--see make says Error 139 .
  2310.    
  2311.    
  2312. 9.7 make says Error 139
  2313.  
  2314.    Your compiler driver (gcc) dumped core. You probably have a corrupt
  2315.    buggy, or old version of GCC--get the latest release. Alternatively
  2316.    you may be running out of swap space--see My machine runs very
  2317.    slowly when I run GCC / X / ... .
  2318.    
  2319.    If this doesn't fix the problem, you are probably having problems w
  2320.    memory or disk corruption. Check that the clock rate, wait states, 
  2321.    refresh timing for your SIMMS and cache are correct (hardware manua
  2322.    are sometimes wrong, too). If so, you may have some marginal SIMMS,
  2323.    a faulty motherboard or hard disk or controller.
  2324.    
  2325.    Linux, like any Unix, is a very good memory tester--much better tha
  2326.    MS-DOS based memory test programs.
  2327.    
  2328.    Reportedly, some clone x87 math coprocessors can cause problems. Tr
  2329.    compiling a kernel with math emulation ( How do I
  2330.    upgrade/recompile my kernel? .) You may need to use the "no387"
  2331.    kernel command line flag on the LILO prompt to force the kernel to 
  2332.    math emulation, or it may be able to work and still use the '387, w
  2333.    the math emulation compiled in but mainly unused.
  2334.    
  2335.    More information about this problem is available on the Web at
  2336.    http://www.bitwizard.nl/sig11/.
  2337.    
  2338.    
  2339. 9.8 shell-init: permission denied when I log in.
  2340.  
  2341.    Your root directory and all the directories up to your home directo
  2342.    must be readable and executable by everybody. See the manual page f
  2343.    chmod or a book on Unix for how to fix the problem.
  2344.    
  2345.    
  2346. 9.9 No utmp entry. You must exec ... when I log in.
  2347.  
  2348.    Your /var/run/utmp is screwed up. You should have
  2349. > /var/run/utmp
  2350.  
  2351.    in your /etc/rc.local or /etc/rc.d/*. See ("I have screwed up
  2352.    my system and can't log in to fix it. ") Note that the utmp may als
  2353.    be found in /var/adm/ or /etc/ on some older systems.
  2354.    
  2355.    
  2356. 9.10 Warning--bdflush not running.
  2357.  
  2358.    Modern kernels use a better strategy for writing cached disk blocks
  2359.    In addition to the kernel changes, this involves replacing the old
  2360.    update program which used to write everything every 30 seconds with
  2361.    more subtle daemon (actually a pair), known as bdflush.
  2362.    
  2363.    Get bdflush-n.n.tar.gz from the same place as the kernel source cod
  2364.    How do I upgrade/recompile my kernel? ) and compile and install
  2365.    it. Bdflush should be started before the usual boot-time file syste
  2366.    checks. It will work fine with older kernels as well, so there's no
  2367.    need to keep the old update around.
  2368.    
  2369.    
  2370. 9.11 Warning: obsolete routing request made.
  2371.  
  2372.    This is nothing to worry about. The message means that your version
  2373.    route is a little out of date, compared to the kernel. You can make
  2374.    the message go away by getting a new version of route from the same
  2375.    place as the kernel source code. ( How do I upgrade/recompile my
  2376.    kernel? )
  2377.    
  2378.    
  2379. 9.12 EXT2-fs: warning: mounting unchecked file system.
  2380.  
  2381.    You need to run e2fsck (or fsck -t ext2 if you have the fsck front 
  2382.    program) with the -a option to get it to clear the `dirty' flag, an
  2383.    then cleanly unmount the partition during each shutdown.
  2384.    
  2385.    The easiest way to do this is to get the latest fsck, umount, and
  2386.    shutdown commands, available in Rik Faith's util-linux package (`
  2387.    Where can I get Linux material by FTP? ") You have to make sure
  2388.    that your /etc/rc*/ scripts use them correctly.
  2389.    
  2390.    NB: don't try to check a file system that's mounted read/write--thi
  2391.    includes the root partition if you don't see
  2392. VFS: mounted root ... read-only
  2393.  
  2394.    at boot time. You must arrange to mount the root file system read/o
  2395.    to start with, check it if necessary, and then remount it read/writ
  2396.    Read the documentation that comes with util-linux to find out how t
  2397.    do this.
  2398.    
  2399.    Note that you need to specify the -n option to mount so it won't tr
  2400.    to update /etc/mtab, since the root file system is still read-only,
  2401.    and this will otherwise cause it to fail.
  2402.    
  2403.    
  2404. 9.13 EXT2-fs warning: maximal count reached.
  2405.  
  2406.    This message is issued by the kernel when it mounts a file system
  2407.    that's marked as clean, but whose "number of mounts since check"
  2408.    counter has reached the predefined value. The solution is to get th
  2409.    latest version of the ext2fs utilities (e2fsprogs-0.5b.tar.gz at th
  2410.    time of writing) from the usual sites. (` Where can I get Linux
  2411.    material by FTP? ")
  2412.    
  2413.    The maximal number of mounts value can be examined and changed usin
  2414.    the tune2fs program from this package.
  2415.    
  2416.    
  2417. 9.14 EXT2-fs warning: checktime reached.
  2418.  
  2419.    Kernels from 1.0 onwards support checking a file system based on th
  2420.    elapsed time since the last check as well as by the number of mount
  2421.    Get the latest version of the ext2fs utilities. "( EXT2-fs
  2422.    warning: maximal count reached. ")
  2423.    
  2424.    
  2425. 9.15 df says Cannot read table of mounted file systems.
  2426.  
  2427.    There is probably something wrong with your /etc/mtab or /etc/fstab
  2428.    files. If you have a reasonably new version of mount, /etc/mtab sho
  2429.    be emptied or deleted at boot time (in /etc/rc.local or /etc/rc.d/*
  2430.    using something like
  2431. rm -f /etc/mtab*
  2432.  
  2433.    Some versions of SLS have an entry for the root partition in /etc/m
  2434.    made in /etc/rc* by using rdev. This is incorrect--the newer versio
  2435.    of mount do this automatically.
  2436.    
  2437.    Other versions of SLS have a line in /etc/fstab that looks like:
  2438. /dev/sdb1   /root   ext2   defaults
  2439.  
  2440.    This is wrong. /root should read simply /.
  2441.    
  2442.    
  2443. 9.16 fdisk says Partition X has different physical/logical ...
  2444.  
  2445.    If the partition number (X, above) is 1, this is the same problem a
  2446.    in "fdisk: Partition 1 does not start on cylinder boundary. "
  2447.    
  2448.    If the partition begins or ends on a cylinder numbered greater than
  2449.    1024, this is because the standard DOS disk geometry information
  2450.    format in the partition table can't cope with cylinder numbers with
  2451.    more than 10 bits. You should see "How can I get Linux to work
  2452.    with my disk? "
  2453.    
  2454.    
  2455. 9.17 fdisk: Partition 1 does not start on cylinder boundary.
  2456.  
  2457.    The version of fdisk that comes with many Linux systems creates
  2458.    partitions that fail its own validity checking. Unfortunately, if
  2459.    you've already installed your system, there's not much you can do
  2460.    about this, apart from copying the data off the partition, deleting
  2461.    and remaking it, and copying the data back.
  2462.    
  2463.    You can avoid the problem by getting the latest version of fdisk, f
  2464.    Rik Faith's util-linux package (available on all the usual FTP site
  2465.    Alternatively, if you are creating a new partition 1 that starts in
  2466.    the first cylinder, you can do the following to get a partition tha
  2467.    fdisk likes.
  2468.      * Create partition 1 in the normal way. A `p' listing will produc
  2469.        the mismatch complaint.
  2470.      * Type `u' to set sector mode and do `p' again. Copy down the num
  2471.        from the "End" column.
  2472.      * Delete partition 1.
  2473.      * While still in sector mode, re-create partition 1. Set the firs
  2474.        sector to match the number of sectors per track. This is the
  2475.        sector number in the first line of the `p' output. Set the last
  2476.        sector to the value you wrote down in the step above.
  2477.      * Type `u' to reset cylinder mode and continue with other
  2478.        partitions.
  2479.        
  2480.    Ignore the message about unallocated sectors--they refer to the
  2481.    sectors on the first track apart from the Master Boot Record, and t
  2482.    are not used if you start the first partition in track 2.
  2483.    
  2484.    
  2485. 9.18 fdisk says partition n has an odd number of sectors.
  2486.  
  2487.    The PC disk partitioning scheme works in 512-byte sectors, but Linu
  2488.    uses 1K blocks. If you have a partition with an odd number of secto
  2489.    the last sector is wasted. Ignore the message.
  2490.    
  2491.    
  2492. 9.19 mtools says cannot initialize drive XYZ
  2493.  
  2494.    This means that mtools is having trouble accessing the drive. This 
  2495.    be due to several things.
  2496.    
  2497.    Often this is due to the permissions on floppy drive devices
  2498.    (/dev/fd0* and /dev/fd1*) being incorrect--the user running mtools
  2499.    must have the appropriate access. See the manual page for chmod for
  2500.    details.
  2501.    
  2502.    Most versions of mtools distributed with Linux systems (not the
  2503.    standard GNU version) use the contents of a file /etc/mtools to
  2504.    determine which devices and densities to use, in place of having th
  2505.    information compiled into the binary. Mistakes in this file often
  2506.    cause problems. There is often no documentation about this.
  2507.    
  2508.    For the easiest way to access your MS-DOS files (especially those o
  2509.    hard disk partition) see How do I access files on my DOS
  2510.    partition or floppy? Note--you should never use mtools to access fi
  2511.    on an msdosfs mounted partition or disk!
  2512.    
  2513.    
  2514. 9.20 At the start of booting: Memory tight
  2515.  
  2516.    This means that you have an extra-large kernel, which means that Li
  2517.    has to do some special memory-management magic to be able to boot
  2518.    itself from the BIOS. It isn't related to the amount of physical
  2519.    memory in your machine. Ignore the message, or compile a kernel
  2520.    containing only the drivers and features you need. ("How do I
  2521.    upgrade/recompile my kernel? )"
  2522.    
  2523.    
  2524. 9.21 My syslog says `end_request: I/O error, ...'.
  2525.  
  2526.    This error message, and messages like it, almost always indicate a
  2527.    hardware error with a hard drive.
  2528.    
  2529.    This commonly indicates a hard drive defect. The only way to avoid
  2530.    further data loss is to completely shut own the system. You must al
  2531.    make sure that whatever data is on the drive is backed up, and rest
  2532.    it to a non-defective hard drive.
  2533.    
  2534.    This error message may also indicate a bad connection to the drive,
  2535.    especially with homebrew systems. If you install an IDE drive, ALWA
  2536.    use new cables. It's probably is a good idea with SCSI drives, too.
  2537.    
  2538.    In one instance, this error also seemed to coincide with a bad grou
  2539.    between the system board and the chassis. Be sure that all electric
  2540.    connections are clean and tight before placing the blame on the har
  2541.    drive itself.
  2542.    
  2543.    [Peter Moulder, Theodore T'so]
  2544.    
  2545.    
  2546. 9.22 You don't exist. Go away.
  2547.  
  2548.    This is not a viral infection :-). It comes from programs like writ
  2549.    talk, and wall, if your invoking UID doesn't correspond to a valid
  2550.    user (probably due to /etc/passwd being corrupted), or if the sessi
  2551.    (pseudoterminal, specifically) you're using isn't properly register
  2552.    in the utmp file (probably because you invoked it in a funny way).
  2553.    
  2554.    
  2555.    contents
  2556.    
  2557.    
  2558. 10. The X Window System.
  2559.  
  2560.    
  2561. 10.1 Does Linux support X Windows?
  2562.  
  2563.    Yes. Linux uses XFree86 (the current version is 3.3.2, which is bas
  2564.    on X11R6). You need to have a video card which is supported by
  2565.    XFree86. See the Linux XFree86 HOWTO for more details.
  2566.    
  2567.    Most Linux distributions nowadays come with an X installation.
  2568.    
  2569.    However, you can install or upgrade your own, from
  2570.    /pub/Linux/X11/Xfree86-* on sunsite.unc.edu and its mirror sites.
  2571.    
  2572.    
  2573. 10.2 Where can I get an XF86Config for my system?
  2574.  
  2575.    See the Linux XFree86 HOWTO, recent versions of Installation and
  2576.    Getting Started, and the instructions for the XF86Setup program.
  2577.    
  2578.    The contents of the XF86Config file depend on the your exact
  2579.    combination of video card and monitor. It can either be configured 
  2580.    hand, or using the XF86Setup utility. Read the instructions that ca
  2581.    with XFree86, in /usr/X11R6/lib/X11/etc. The file you probably need
  2582.    look at most is README.Config.
  2583.    
  2584.    You should not use the sample XF86Config.eg file which is included
  2585.    with newer versions of XFree86 verbatim, because the wrong video cl
  2586.    settings can damage your monitor.
  2587.    
  2588.    Please don't post to comp.os.linux.x asking for an XF86Config, and
  2589.    please don't answer such requests.
  2590.    
  2591.    
  2592. 10.3 xterm logins show up strangely in who, finger.
  2593.  
  2594.    The xterm that comes with XFree86 2.1 and earlier doesn't correctly
  2595.    understand the format that Linux uses for the /var/adm/utmp file,
  2596.    where the system records who is logged in. It therefore doesn't set
  2597.    all the information correctly.
  2598.    
  2599.    The Xterms in XFree86 3.1 and later versions fix this problem.
  2600.    
  2601.    
  2602. 10.4 I can't get X Windows to work right.
  2603.  
  2604.    Read the XFree86 HOWTO--note the question and answer section.
  2605.    
  2606.    Try reading comp.windows.x.i386unix--specifically read the the FAQ 
  2607.    that group.
  2608.    
  2609.    Please don't post X Windows or XFree86 related questions to
  2610.    comp.os.linux.x unless they are Linux-specific.
  2611.    
  2612.    
  2613.    contents
  2614.    
  2615.    
  2616. 11. Questions applicable to very out-of-date software.
  2617.  
  2618.    The questions in this section are only relevant to users of softwar
  2619.    that is at least three months old.
  2620.    
  2621.    Please let me know if you find the answer to a problem you had here
  2622.    as unused questions in this section will eventually disappear. (See
  2623.    Feedback is invited. ")
  2624.    
  2625.    
  2626. 11.1 fdisk says cannot use nnn sectors of this partition.
  2627.  
  2628.    Originally Linux only supported the Minix file system, which cannot
  2629.    use more than 64Mb per partition. This limitation is not present in
  2630.    the more advanced file systems that are now available, such as ext2
  2631.    (the 2nd version of the Extended File System, the `standard' Linux
  2632.    file system).
  2633.    
  2634.    If you intend to use ext2fs you can ignore the message.
  2635.    
  2636.    
  2637. 11.2 GCC sometimes uses huge amounts of virtual memory and thrashes.
  2638.  
  2639.    Older versions of GCC had a bug which made them use lots of memory 
  2640.    you tried to compile a program which had a large static data table 
  2641.    it.
  2642.    
  2643.    You can either upgrade your version of GCC, or add more swap space 
  2644.    necessary, or just wait for the program to finish compiling.
  2645.    
  2646.    
  2647.    contents
  2648.    
  2649.    
  2650. 12. How to get further assistance.
  2651.  
  2652.    
  2653. 12.1 You still haven't answered my question!
  2654.  
  2655.    Please read all of this answer before posting. I know it's a bit lo
  2656.    but you may be about to make a fool of yourself in front of 50,000
  2657.    people and waste hundreds of hours of their time. Don't you think i
  2658.    worth spending some of your time to read and follow these
  2659.    instructions?
  2660.    
  2661.    If you think an answer is incomplete or inaccurate, please e-mail
  2662.    Robert Kiesling at kiesling@terracom.net.
  2663.    
  2664.    Read the appropriate Linux Documentation Project books--see "
  2665.    Where can I get the HOWTO's and other documentation? "
  2666.    
  2667.    If you're a Unix newbie, read the FAQ for comp.unix.questions, and
  2668.    those for any of the other comp.unix.* groups that may be relevant.
  2669.    
  2670.    Linux has so much in common with commercial Unices, that almost
  2671.    everything you read there will apply to Linux. The FAQs, like all
  2672.    FAQs, be found on rtfm.mit.edu in /pub/usenet/news.answers (the
  2673.    mail-server@rtfm.mit.edu can send you these files, if you don't
  2674.    have FTP access). There are mirrors of rtfm's FAQ archives on vario
  2675.    sites--check the Introduction to *.answers posting, posted, or look
  2676.    news-answers/introduction in the directory above.
  2677.    
  2678.    Check the relevant HOWTO for the subject in question, if there is o
  2679.    or an appropriate old style sub-FAQ document. Check the FTP sites.
  2680.    
  2681.    Try experimenting--that's the best way to get to know Unix and Linu
  2682.    
  2683.    Read the documentation. Check the manual pages (type "man man" if
  2684.    you don't know about manual pages. Try "man -k subject"--it often
  2685.    lists useful and relevant manual pages.
  2686.    
  2687.    Check the Info documentation (type C-h i, i.e. Control H followed b
  2688.    in Emacs). This isn't just for Emacs. For example, the GCC
  2689.    documentation lives here as well.
  2690.    
  2691.    There will also often be a README file with a package that gives
  2692.    installation and/or usage instructions.
  2693.    
  2694.    Make sure you don't have a corrupted or out-of-date copy of the
  2695.    program in question. If possible, download it again and re-install
  2696.    it--you probably made a mistake the first time.
  2697.    
  2698.    Read comp.os.linux.announce--this often contains very important
  2699.    information for all Linux users.
  2700.    
  2701.    General X Window System questions belong in comp.windows.x.i386unix
  2702.    not in comp.os.linux.x. But read the group first (including the FAQ
  2703.    before you post.
  2704.    
  2705.    Only if you have done all of these things and are still stuck, shou
  2706.    you post to the appropriate comp.os.linux.* newsgroup. Make sure yo
  2707.    read the next question first. "( What to put in a request for
  2708.    help. )"
  2709.    
  2710.    
  2711. 12.2 What to put in a request for help.
  2712.  
  2713.    Please read the following advice carefully about how to write your
  2714.    posting or email. Making a complete posting will greatly increase t
  2715.    chances that an expert or fellow user reading it will have enough
  2716.    information and motivation to reply.
  2717.    
  2718.    This advice applies both to postings asking for advice and to perso
  2719.    email sent to experts and fellow users.
  2720.    
  2721.    Make sure you give full details of the problem, including:
  2722.      * What program, exactly, you are having problems with. Include th
  2723.        version number if known and say where you got it. Many standard
  2724.        commands tell you their version number if you give them a
  2725.        --version option.
  2726.      * Which Linux release you're using (Red Hat, Slackware, Debian, o
  2727.        whatever) and what version of that release.
  2728.      * The exact and complete text of any error messages printed.
  2729.      * Exactly what behavior you expected, and exactly what behavior y
  2730.        observed. A transcript of an example session is a good way to s
  2731.        this.
  2732.      * The contents of any configuration files used by the program in
  2733.        question and any related programs.
  2734.      * What version of the kernel and shared libraries you have
  2735.        installed. The kernel version can be found by typing uname -a, 
  2736.        the shared library version by typing ls -l /lib/libc.so.4.
  2737.      * Details of what hardware you're running on, if it seems
  2738.        appropriate.
  2739.        
  2740.    You are in little danger of making your posting too long unless you
  2741.    include large chunks of source code or uuencoded files, so err on t
  2742.    side of giving too much information.
  2743.    
  2744.    Use a clear, detailed Subject line. Don't put things like `doesn't
  2745.    work', `Linux', `help', or `question' in it--we already know that.
  2746.    Save the space for the name of the program, a fragment of an error
  2747.    message, or summary of the unusual behavior.
  2748.    
  2749.    If you report an `unable to handle kernel paging request' message,
  2750.    follow the instructions in the Linux kernel sources README file for
  2751.    turning the numbers into something more meaningful. If you don't do
  2752.    this, no one who reads your post will be able to do it for you. The
  2753.    mapping from numbers to function names varies from one kernel to
  2754.    another.
  2755.    
  2756.    Put a summary paragraph at the top of your posting.
  2757.    
  2758.    At the bottom of your posting, ask for responses by email and say
  2759.    you'll post a summary. Back this up by using Followup-To: poster.
  2760.    Then, actually post the summary in a few days or a week or so. Don'
  2761.    just concatenate the replies you got--summarize. Putting the word
  2762.    SUMMARY in your summary's Subject line is also a good idea. Conside
  2763.    submitting the summary to comp.os.linux.announce.
  2764.    
  2765.    Make sure your posting doesn't have an inappropriate References:
  2766.    header line. This marks your article as part of the thread of the
  2767.    article referred to, which will often cause it to be junked by
  2768.    readers, along with the rest of a boring thread.
  2769.    
  2770.    You might like to say in your posting that you've read this FAQ and
  2771.    the appropriate HOWTO's--this may make people less likely to skip y
  2772.    posting.
  2773.    
  2774.    Remember that you should not post email sent to you personally with
  2775.    the sender's permission.
  2776.    
  2777.    
  2778. 12.3 I want to mail someone about my problem.
  2779.  
  2780.    Try to find the author or developer of whatever program or componen
  2781.    is causing you difficulty. If you have a contact point for your Lin
  2782.    distribution, you should use it.
  2783.    
  2784.    Please put everything in your e-mail message that you would put in 
  2785.    posting asking for help.
  2786.    
  2787.    Finally, remember that, despite the fact that most of the Linux
  2788.    community are very helpful and responsive to e-mailed questions,
  2789.    you're asking for help from unpaid volunteers, so you have no right
  2790.    expect an answer.
  2791.    
  2792.    
  2793.    
  2794.    
  2795. 13. Administrative information and acknowledgments.
  2796.  
  2797.    
  2798. 13.1 Feedback is invited.
  2799.  
  2800.    Please send me your comments on this FAQ.
  2801.    
  2802.    I accept contributions to the FAQ in any format. All contributions,
  2803.    comments, and corrections are gratefully received. Please send e-ma
  2804.    to kiesling@terracom.net.
  2805.    
  2806.    If you wish to refer to a question in the FAQ, it's better for me i
  2807.    you do so by the question heading, rather than number. The question
  2808.    numbers are generated automatically, and I don't see them in the
  2809.    source file I edit.
  2810.    
  2811.    I prefer comments in English to patch files--context diff is not my
  2812.    first language.
  2813.    
  2814.    
  2815. 13.2 Formats in which this FAQ is available.
  2816.  
  2817.    This document is available as an ASCII text file, an HTML World Wid
  2818.    Web page, Postscript, and as a USENET news posting.
  2819.    
  2820.    All of these formats are generated from SGML source using SGML Tool
  2821.    and the LinuxDoc DTD.
  2822.    
  2823.    The HTML version of this FAQ is available as
  2824.    http://sunsite.unc.edu/LDP/ at other sites.
  2825.    
  2826.    The Usenet version is posted regularly to news.answers, comp.answer
  2827.    comp.os.linux.misc, and comp.os.linux.announce. It is archived at
  2828.    ftp://rtfm.mit.edu/pub/usenet-by-hierarchy/comp/os/linux/misc/.
  2829.    
  2830.    The most recent text, HTML, SGML, and Postscript versions are
  2831.    available from the Linux archives at sunsite.unc.edu, and from
  2832.    http://www.terracom.net/~kiesling
  2833.    
  2834.    
  2835. 13.3 Authorship and acknowledgments.
  2836.  
  2837.    This FAQ is compiled and maintained by Robert Kiesling
  2838.    kiesling@ix.netcom.com, with assistance and comments from Linux
  2839.    activists all over the world.
  2840.    
  2841.    Special thanks are due to Matt Welsh, who moderated
  2842.    comp.os.linux.announce and comp.os.linux.answers, coordinated the
  2843.    HOWTO's and wrote substantial portions of many of them, Greg Hankin
  2844.    and Timothy Bynum, the former and current Linux Documentation Proje
  2845.    HOWTO maintainers, Lars Wirzenius and Mikko Rauhala, the former and
  2846.    current moderators of comp.os.linux.announce, Marc-Michel Corsini, 
  2847.    wrote the original Linux FAQ, and Ian Jackson, the previous FAQ
  2848.    maintainer. Thanks also to Roman Maurer for his many updates and
  2849.    additions, especially with European Web sites, translations, and
  2850.    general miscellany.
  2851.    
  2852.    Last but not least, thanks to Linus Torvalds and the other
  2853.    contributors to Linux for giving us something to talk about!
  2854.    
  2855.    
  2856. 13.4 Disclaimer and Copyright.
  2857.  
  2858.    Note that this document is provided `as is'. The information in it 
  2859.    not warranted to be correct. Use it at your own risk.
  2860.    
  2861.    Linux Frequently Asked Questions with Answers is Copyright (c) 1997
  2862.    1998 by Robert Kiesling kiesling@terracom.net, under the
  2863.    copyright of the Linux Documentation Project. The full text of the 
  2864.    copyright is available via anonymous FTP from sunsite.unc.edu, in t
  2865.    directory /pub/Linux/docs/LDP, and is included below.
  2866.    
  2867.    Portions are Copyright (c) 1994, 1995, 1996 by Ian Jackson, the
  2868.    previous Linux FAQ maintainer.
  2869.    
  2870.    Linux Frequently Asked Questions with Answers may be reproduced and
  2871.    distributed in its entirety (including this authorship, copyright, 
  2872.    permission notice), provided that no charge is made for the documen
  2873.    itself, without the author's consent. This includes "fair use"
  2874.    excerpts like reviews and advertising, and derivative works like
  2875.    translations.
  2876.    
  2877.    Note that this restriction is not intended to prohibit charging for
  2878.    the service of printing or copying the document.
  2879.    
  2880.    Exceptions to these rules may be granted. I would be happy to answe
  2881.    any questions regarding this copyright. E-mail me at
  2882.    kiesling@ix.netcom.com. As the license below says, these
  2883.    restrictions are here to protect the contributors, not to restrict 
  2884.    as educators and learners.
  2885.    
  2886.                   LINUX DOCUMENTATION PROJECT COPYING LICENSE
  2887.  
  2888.    Last modified 6 January 1997
  2889.  
  2890.  
  2891.    The following copyright license applies to all works by the Linux
  2892.    Documentation Project.
  2893.  
  2894.    Please read the license carefully---it is somewhat like the GNU
  2895.    General Public License, but there are several conditions in it that
  2896.    differ from what you may be used to. If you have any questions, ple
  2897.    email the LDP coordinator, mdw@sunsite.unc.edu.
  2898.  
  2899.    The Linux Documentation Project manuals may be reproduced and
  2900.    distributed in whole or in part, subject to the following condition
  2901.  
  2902.    All Linux Documentation Project manuals are copyrighted by their
  2903.    respective authors. THEY ARE NOT IN THE PUBLIC DOMAIN.
  2904.      * The copyright notice above and this permission notice must be
  2905.        preserved complete on all complete or partial copies.
  2906.      * Any translation or derivative work of Linux Installation and
  2907.        Getting Started must be approved by the author in writing befor
  2908.        distribution.
  2909.      * If you distribute Linux Installation and Getting Started in par
  2910.        instructions for obtaining the complete version of this manual
  2911.        must be included, and a means for obtaining a complete version
  2912.        provided.
  2913.      * Small portions may be reproduced as illustrations for reviews o
  2914.        quotes in other works without this permission notice if proper
  2915.        citation is given.
  2916.      * The GNU General Public License referenced below may be reproduc
  2917.        under the conditions given within it.
  2918.  
  2919.    Exceptions to these rules may be granted for academic purposes: Wri
  2920.    to the author and ask. These restrictions are here to protect us as
  2921.    authors, not to restrict you as educators and learners. All source
  2922.    code in Linux Installation and Getting Started is placed under the 
  2923.    General Public License, available via anonymous FTP from the GNU
  2924.    archive site.
  2925.  
  2926.  
  2927.  
  2928.                             PUBLISHING LDP MANUALS
  2929.  
  2930.     If you're a publishing company interested in distributing any of t
  2931.    LDP manuals, read on.
  2932.  
  2933.    By the license given in the previous section, anyone is allowed to
  2934.    publish and distribute verbatim copies of the Linux Documentation
  2935.    Project manuals. You don't need our explicit permission for this.
  2936.    However, if you would like to distribute a translation or derivativ
  2937.    work based on any of the LDP manuals, you must obtain permission fr
  2938.    the author, in writing, before doing so.
  2939.  
  2940.    All translations and derivative works of LDP manuals must be placed
  2941.    under the Linux Documentation License given in the previous section
  2942.    That is, if you plan to release a translation of one of the manuals
  2943.    it must be freely distributable by the above terms.
  2944.  
  2945.    You may, of course, sell the LDP manuals for profit. We encourage y
  2946.    to do so. Keep in mind, however, that because the LDP manuals are
  2947.    freely distributable, anyone may photocopy or distribute printed
  2948.    copies free of charge, if they wish to do so.
  2949.  
  2950.    We do not require to be paid royalties for any profit earned from
  2951.    selling LDP manuals. However, we would like to suggest that if you 
  2952.    sell LDP manuals for profit, that you either offer the author
  2953.    royalties, or donate a portion of your earnings to the author, the 
  2954.    as a whole, or to the Linux development community. You may also wis
  2955.    to send one or more free copies of the LDP manual that you are
  2956.    distributing to the author. Your show of support for the LDP and th
  2957.    Linux community will be very appreciated.
  2958.  
  2959.    We would like to be informed of any plans to publish or distribute 
  2960.    manuals, just so we know how they're becoming available. If you are
  2961.    publishing or planning to publish any LDP manuals, please send emai
  2962.    to Matt Welsh (email mdw@sunsite.unc.edu).
  2963.  
  2964.    We encourage Linux software distributors to distribute the LDP manu
  2965.    (such as the Installation and Getting Started Guide) with their
  2966.    software. The LDP manuals are intended to be used as the "official"
  2967.    Linux documentation, and we'd like to see mail-order distributors
  2968.    bundling the LDP manuals with the software. As the LDP manuals matu
  2969.    hopefully they will fulfill this goal more adequately.
  2970.  
  2971.  
  2972.     Matt Welsh, mdw@sunsite.unc.edu
  2973.    
  2974.  
  2975.