Btrfs: update space balancing code
[linux-2.6] / Documentation / kernel-docs.txt
1
2     Index of Documentation for People Interested in Writing and/or
3
4                    Understanding the Linux Kernel.
5
6           Juan-Mariano de Goyeneche <jmseyas@dit.upm.es>
7
8 /*
9  * The latest version of this document may be found at:
10  *   http://www.dit.upm.es/~jmseyas/linux/kernel/hackers-docs.html
11  */
12
13    The need for a document like this one became apparent in the
14    linux-kernel mailing list as the same questions, asking for pointers
15    to information, appeared again and again.
16    
17    Fortunately, as more and more people get to GNU/Linux, more and more
18    get interested in the Kernel. But reading the sources is not always
19    enough. It is easy to understand the code, but miss the concepts, the
20    philosophy and design decisions behind this code.
21    
22    Unfortunately, not many documents are available for beginners to
23    start. And, even if they exist, there was no "well-known" place which
24    kept track of them. These lines try to cover this lack. All documents
25    available on line known by the author are listed, while some reference
26    books are also mentioned.
27    
28    PLEASE, if you know any paper not listed here or write a new document,
29    send me an e-mail, and I'll include a reference to it here. Any
30    corrections, ideas or comments are also welcomed.
31    
32    The papers that follow are listed in no particular order. All are
33    cataloged with the following fields: the document's "Title", the
34    "Author"/s, the "URL" where they can be found, some "Keywords" helpful
35    when searching for specific topics, and a brief "Description" of the
36    Document.
37    
38    Enjoy!
39    
40      ON-LINE DOCS:
41        
42      * Title: "Linux Device Drivers, Third Edition"
43        Author: Jonathan Corbet, Alessandro Rubini, Greg Kroah-Hartman
44        URL: http://lwn.net/Kernel/LDD3/
45        Description: A 600-page book covering the (2.6.10) driver
46        programming API and kernel hacking in general.  Available under the
47        Creative Commons Attribution-ShareAlike 2.0 license.
48
49      * Title: "The Linux Kernel"
50        Author: David A. Rusling.
51        URL: http://www.tldp.org/LDP/tlk/tlk.html
52        Keywords: everything!, book.
53        Description: On line, 200 pages book describing most aspects of
54        the Linux Kernel. Probably, the first reference for beginners.
55        Lots of illustrations explaining data structures use and
56        relationships in the purest Richard W. Stevens' style. Contents:
57        "1.-Hardware Basics, 2.-Software Basics, 3.-Memory Management,
58        4.-Processes, 5.-Interprocess Communication Mechanisms, 6.-PCI,
59        7.-Interrupts and Interrupt Handling, 8.-Device Drivers, 9.-The
60        File system, 10.-Networks, 11.-Kernel Mechanisms, 12.-Modules,
61        13.-The Linux Kernel Sources, A.-Linux Data Structures, B.-The
62        Alpha AXP Processor, C.-Useful Web and FTP Sites, D.-The GNU
63        General Public License, Glossary". In short: a must have.
64
65      * Title: "Linux Device Drivers, 2nd Edition"
66        Author: Alessandro Rubini and Jonathan Corbet.
67        URL: http://www.xml.com/ldd/chapter/book/index.html
68        Keywords: device drivers, modules, debugging, memory, hardware,
69        interrupt handling, char drivers, block drivers, kmod, mmap, DMA,
70        buses.
71        Description: O'Reilly's popular book, now also on-line under the
72        GNU Free Documentation License.
73        Notes: You can also buy it in paper-form from O'Reilly. See below
74        under BOOKS (Not on-line).
75
76      * Title: "Conceptual Architecture of the Linux Kernel"
77        Author: Ivan T. Bowman.
78        URL: http://plg.uwaterloo.ca/~itbowman/papers/CS746G-a1.html
79        Keywords: conceptual software architecture, extracted design,
80        reverse engineering, system structure.
81        Description: Conceptual software architecture of the Linux kernel,
82        automatically extracted from the source code. Very detailed. Good
83        figures. Gives good overall kernel understanding.
84
85      * Title: "Concrete Architecture of the Linux Kernel"
86        Author: Ivan T. Bowman, Saheem Siddiqi, and Meyer C. Tanuan.
87        URL: http://plg.uwaterloo.ca/~itbowman/papers/CS746G-a2.html
88        Keywords: concrete architecture, extracted design, reverse
89        engineering, system structure, dependencies.
90        Description: Concrete architecture of the Linux kernel,
91        automatically extracted from the source code. Very detailed. Good
92        figures. Gives good overall kernel understanding. This papers
93        focus on lower details than its predecessor (files, variables...).
94
95      * Title: "Linux as a Case Study: Its Extracted Software
96        Architecture"
97        Author: Ivan T. Bowman, Richard C. Holt and Neil V. Brewster.
98        URL: http://plg.uwaterloo.ca/~itbowman/papers/linuxcase.html
99        Keywords: software architecture, architecture recovery,
100        redocumentation.
101        Description: Paper appeared at ICSE'99, Los Angeles, May 16-22,
102        1999. A mixture of the previous two documents from the same
103        author.
104
105      * Title: "Overview of the Virtual File System"
106        Author: Richard Gooch.
107        URL: http://www.atnf.csiro.au/~rgooch/linux/vfs.txt
108        Keywords: VFS, File System, mounting filesystems, opening files,
109        dentries, dcache.
110        Description: Brief introduction to the Linux Virtual File System.
111        What is it, how it works, operations taken when opening a file or
112        mounting a file system and description of important data
113        structures explaining the purpose of each of their entries.
114
115      * Title: "The Linux RAID-1, 4, 5 Code"
116        Author: Ingo Molnar, Gadi Oxman and Miguel de Icaza.
117        URL: http://www.linuxjournal.com/article.php?sid=2391
118        Keywords: RAID, MD driver.
119        Description: Linux Journal Kernel Korner article. Here is it's
120        abstract: "A description of the implementation of the RAID-1,
121        RAID-4 and RAID-5 personalities of the MD device driver in the
122        Linux kernel, providing users with high performance and reliable,
123        secondary-storage capability using software".
124
125      * Title: "Dynamic Kernels: Modularized Device Drivers"
126        Author: Alessandro Rubini.
127        URL: http://www.linuxjournal.com/article.php?sid=1219
128        Keywords: device driver, module, loading/unloading modules,
129        allocating resources.
130        Description: Linux Journal Kernel Korner article. Here is it's
131        abstract: "This is the first of a series of four articles
132        co-authored by Alessandro Rubini and Georg Zezchwitz which present
133        a practical approach to writing Linux device drivers as kernel
134        loadable modules. This installment presents an introduction to the
135        topic, preparing the reader to understand next month's
136        installment".
137
138      * Title: "Dynamic Kernels: Discovery"
139        Author: Alessandro Rubini.
140        URL: http://www.linuxjournal.com/article.php?sid=1220
141        Keywords: character driver, init_module, clean_up module,
142        autodetection, mayor number, minor number, file operations,
143        open(), close().
144        Description: Linux Journal Kernel Korner article. Here is it's
145        abstract: "This article, the second of four, introduces part of
146        the actual code to create custom module implementing a character
147        device driver. It describes the code for module initialization and
148        cleanup, as well as the open() and close() system calls".
149
150      * Title: "The Devil's in the Details"
151        Author: Georg v. Zezschwitz and Alessandro Rubini.
152        URL: http://www.linuxjournal.com/article.php?sid=1221
153        Keywords: read(), write(), select(), ioctl(), blocking/non
154        blocking mode, interrupt handler.
155        Description: Linux Journal Kernel Korner article. Here is it's
156        abstract: "This article, the third of four on writing character
157        device drivers, introduces concepts of reading, writing, and using
158        ioctl-calls".
159
160      * Title: "Dissecting Interrupts and Browsing DMA"
161        Author: Alessandro Rubini and Georg v. Zezschwitz.
162        URL: http://www.linuxjournal.com/article.php?sid=1222
163        Keywords: interrupts, irqs, DMA, bottom halves, task queues.
164        Description: Linux Journal Kernel Korner article. Here is it's
165        abstract: "This is the fourth in a series of articles about
166        writing character device drivers as loadable kernel modules. This
167        month, we further investigate the field of interrupt handling.
168        Though it is conceptually simple, practical limitations and
169        constraints make this an ``interesting'' part of device driver
170        writing, and several different facilities have been provided for
171        different situations. We also investigate the complex topic of
172        DMA".
173
174      * Title: "Device Drivers Concluded"
175        Author: Georg v. Zezschwitz.
176        URL: http://www.linuxjournal.com/article.php?sid=1287
177        Keywords: address spaces, pages, pagination, page management,
178        demand loading, swapping, memory protection, memory mapping, mmap,
179        virtual memory areas (VMAs), vremap, PCI.
180        Description: Finally, the above turned out into a five articles
181        series. This latest one's introduction reads: "This is the last of
182        five articles about character device drivers. In this final
183        section, Georg deals with memory mapping devices, beginning with
184        an overall description of the Linux memory management concepts".
185
186      * Title: "Network Buffers And Memory Management"
187        Author: Alan Cox.
188        URL: http://www.linuxjournal.com/article.php?sid=1312
189        Keywords: sk_buffs, network devices, protocol/link layer
190        variables, network devices flags, transmit, receive,
191        configuration, multicast.
192        Description: Linux Journal Kernel Korner. Here is the abstract:
193        "Writing a network device driver for Linux is fundamentally
194        simple---most of the complexity (other than talking to the
195        hardware) involves managing network packets in memory".
196        
197      * Title: "Writing Linux Device Drivers"
198        Author: Michael K. Johnson.
199        URL: http://users.evitech.fi/~tk/rtos/writing_linux_device_d.html
200        Keywords: files, VFS, file operations, kernel interface, character
201        vs block devices, I/O access, hardware interrupts, DMA, access to
202        user memory, memory allocation, timers.
203        Description: Introductory 50-minutes (sic) tutorial on writing
204        device drivers. 12 pages written by the same author of the "Kernel
205        Hackers' Guide" which give a very good overview of the topic.
206        
207      * Title: "The Venus kernel interface"
208        Author: Peter J. Braam.
209        URL:
210        http://www.coda.cs.cmu.edu/doc/html/kernel-venus-protocol.html
211        Keywords: coda, filesystem, venus, cache manager.
212        Description: "This document describes the communication between
213        Venus and kernel level file system code needed for the operation
214        of the Coda filesystem. This version document is meant to describe
215        the current interface (version 1.0) as well as improvements we
216        envisage".
217
218      * Title: "Programming PCI-Devices under Linux"
219        Author: Claus Schroeter.
220        URL:
221        ftp://ftp.llp.fu-berlin.de/pub/linux/LINUX-LAB/whitepapers/pcip.ps.gz
222        Keywords: PCI, device, busmastering.
223        Description: 6 pages tutorial on PCI programming under Linux.
224        Gives the basic concepts on the architecture of the PCI subsystem,
225        as long as basic functions and macros to read/write the devices
226        and perform busmastering.
227
228      * Title: "Writing Character Device Driver for Linux"
229        Author: R. Baruch and C. Schroeter.
230        URL:
231        ftp://ftp.llp.fu-berlin.de/pub/linux/LINUX-LAB/whitepapers/drivers.ps.gz
232        Keywords: character device drivers, I/O, signals, DMA, accessing
233        ports in user space, kernel environment.
234        Description: 68 pages paper on writing character drivers. A little
235        bit old (1.993, 1.994) although still useful.
236
237      * Title: "Design and Implementation of the Second Extended
238        Filesystem"
239        Author: Rémy Card, Theodore Ts'o, Stephen Tweedie.
240        URL: http://web.mit.edu/tytso/www/linux/ext2intro.html
241        Keywords: ext2, linux fs history, inode, directory, link, devices,
242        VFS, physical structure, performance, benchmarks, ext2fs library,
243        ext2fs tools, e2fsck.
244        Description: Paper written by three of the top ext2 hackers.
245        Covers Linux filesystems history, ext2 motivation, ext2 features,
246        design, physical structure on disk, performance, benchmarks,
247        e2fsck's passes description... A must read!
248        Notes: This paper was first published in the Proceedings of the
249        First Dutch International Symposium on Linux, ISBN 90-367-0385-9.
250
251      * Title: "Analysis of the Ext2fs structure"
252        Author: Louis-Dominique Dubeau.
253        URL: http://www.nondot.org/sabre/os/files/FileSystems/ext2fs/
254        Keywords: ext2, filesystem, ext2fs.
255        Description: Description of ext2's blocks, directories, inodes,
256        bitmaps, invariants...
257
258      * Title: "Journaling the Linux ext2fs Filesystem"
259        Author: Stephen C. Tweedie.
260        URL:
261        ftp://ftp.uk.linux.org/pub/linux/sct/fs/jfs/journal-design.ps.gz
262        Keywords: ext3, journaling.
263        Description: Excellent 8-pages paper explaining the journaling
264        capabilities added to ext2 by the author, showing different
265        problems faced and the alternatives chosen.
266
267      * Title: "Kernel API changes from 2.0 to 2.2"
268        Author: Richard Gooch.
269        URL:
270        http://www.atnf.csiro.au/~rgooch/linux/docs/porting-to-2.2.html
271        Keywords: 2.2, changes.
272        Description: Kernel functions/structures/variables which changed
273        from 2.0.x to 2.2.x.
274
275      * Title: "Kernel API changes from 2.2 to 2.4"
276        Author: Richard Gooch.
277        URL:
278        http://www.atnf.csiro.au/~rgooch/linux/docs/porting-to-2.4.html
279        Keywords: 2.4, changes.
280        Description: Kernel functions/structures/variables which changed
281        from 2.2.x to 2.4.x.
282        
283      * Title: "Linux Kernel Module Programming Guide"
284        Author: Ori Pomerantz.
285        URL: http://tldp.org/LDP/lkmpg/2.6/html/index.html
286        Keywords: modules, GPL book, /proc, ioctls, system calls,
287        interrupt handlers .
288        Description: Very nice 92 pages GPL book on the topic of modules
289        programming. Lots of examples.
290        
291      * Title: "I/O Event Handling Under Linux"
292        Author: Richard Gooch.
293        URL: http://www.atnf.csiro.au/~rgooch/linux/docs/io-events.html
294        Keywords: IO, I/O, select(2), poll(2), FDs, aio_read(2), readiness
295        event queues.
296        Description: From the Introduction: "I/O Event handling is about
297        how your Operating System allows you to manage a large number of
298        open files (file descriptors in UNIX/POSIX, or FDs) in your
299        application. You want the OS to notify you when FDs become active
300        (have data ready to be read or are ready for writing). Ideally you
301        want a mechanism that is scalable. This means a large number of
302        inactive FDs cost very little in memory and CPU time to manage".
303        
304      * Title: "The Kernel Hacking HOWTO"
305        Author: Various Talented People, and Rusty.
306        Location: in kernel tree, Documentation/DocBook/kernel-hacking/
307        (must be built as "make {htmldocs | psdocs | pdfdocs})
308        Keywords: HOWTO, kernel contexts, deadlock, locking, modules,
309        symbols, return conventions.
310        Description: From the Introduction: "Please understand that I
311        never wanted to write this document, being grossly underqualified,
312        but I always wanted to read it, and this was the only way. I
313        simply explain some best practices, and give reading entry-points
314        into the kernel sources. I avoid implementation details: that's
315        what the code is for, and I ignore whole tracts of useful
316        routines. This document assumes familiarity with C, and an
317        understanding of what the kernel is, and how it is used. It was
318        originally written for the 2.3 kernels, but nearly all of it
319        applies to 2.2 too; 2.0 is slightly different".
320        
321      * Title: "Writing an ALSA Driver"
322        Author: Takashi Iwai <tiwai@suse.de>
323        URL: http://www.alsa-project.org/~iwai/writing-an-alsa-driver/index.html
324        Keywords: ALSA, sound, soundcard, driver, lowlevel, hardware.
325        Description: Advanced Linux Sound Architecture for developers,
326        both at kernel and user-level sides. ALSA is the Linux kernel
327        sound architecture in the 2.6 kernel version.
328        
329      * Title: "Programming Guide for Linux USB Device Drivers"
330        Author: Detlef Fliegl.
331        URL: http://usb.in.tum.de/usbdoc/
332        Keywords: USB, universal serial bus.
333        Description: A must-read. From the Preface: "This document should
334        give detailed information about the current state of the USB
335        subsystem and its API for USB device drivers. The first section
336        will deal with the basics of USB devices. You will learn about
337        different types of devices and their properties. Going into detail
338        you will see how USB devices communicate on the bus. The second
339        section gives an overview of the Linux USB subsystem [2] and the
340        device driver framework. Then the API and its data structures will
341        be explained step by step. The last section of this document
342        contains a reference of all API calls and their return codes".
343        Notes: Beware: the main page states: "This document may not be
344        published, printed or used in excerpts without explicit permission
345        of the author". Fortunately, it may still be read...
346
347      * Title: "Linux Kernel Mailing List Glossary"
348        Author: various
349        URL: http://kernelnewbies.org/glossary/
350        Keywords: glossary, terms, linux-kernel.
351        Description: From the introduction: "This glossary is intended as
352        a brief description of some of the acronyms and terms you may hear
353        during discussion of the Linux kernel".
354        
355      * Title: "Linux Kernel Locking HOWTO"
356        Author: Various Talented People, and Rusty.
357        Location: in kernel tree, Documentation/DocBook/kernel-locking/
358        (must be built as "make {htmldocs | psdocs | pdfdocs})
359        Keywords: locks, locking, spinlock, semaphore, atomic, race
360        condition, bottom halves, tasklets, softirqs.
361        Description: The title says it all: document describing the
362        locking system in the Linux Kernel either in uniprocessor or SMP
363        systems.
364        Notes: "It was originally written for the later (>2.3.47) 2.3
365        kernels, but most of it applies to 2.2 too; 2.0 is slightly
366        different". Freely redistributable under the conditions of the GNU
367        General Public License.
368
369      * Title: "Global spinlock list and usage"
370        Author: Rick Lindsley.
371        URL: http://lse.sourceforge.net/lockhier/global-spin-lock
372        Keywords: spinlock.
373        Description: This is an attempt to document both the existence and
374        usage of the spinlocks in the Linux 2.4.5 kernel. Comprehensive
375        list of spinlocks showing when they are used, which functions
376        access them, how each lock is acquired, under what conditions it
377        is held, whether interrupts can occur or not while it is held...
378
379      * Title: "Porting Linux 2.0 Drivers To Linux 2.2: Changes and New
380        Features "
381        Author: Alan Cox.
382        URL: http://www.linux-mag.com/1999-05/gear_01.html
383        Keywords: ports, porting.
384        Description: Article from Linux Magazine on porting from 2.0 to
385        2.2 kernels.
386
387      * Title: "Porting Device Drivers To Linux 2.2: part II"
388        Author: Alan Cox.
389        URL: http://www.linux-mag.com/1999-06/gear_01.html
390        Keywords: ports, porting.
391        Description: Second part on porting from 2.0 to 2.2 kernels.
392
393      * Title: "How To Make Sure Your Driver Will Work On The Power
394        Macintosh"
395        Author: Paul Mackerras.
396        URL: http://www.linux-mag.com/1999-07/gear_01.html
397        Keywords: Mac, Power Macintosh, porting, drivers, compatibility.
398        Description: The title says it all.
399
400      * Title: "An Introduction to SCSI Drivers"
401        Author: Alan Cox.
402        URL: http://www.linux-mag.com/1999-08/gear_01.html
403        Keywords: SCSI, device, driver.
404        Description: The title says it all.
405
406      * Title: "Advanced SCSI Drivers And Other Tales"
407        Author: Alan Cox.
408        URL: http://www.linux-mag.com/1999-09/gear_01.html
409        Keywords: SCSI, device, driver, advanced.
410        Description: The title says it all.
411
412      * Title: "Writing Linux Mouse Drivers"
413        Author: Alan Cox.
414        URL: http://www.linux-mag.com/1999-10/gear_01.html
415        Keywords: mouse, driver, gpm.
416        Description: The title says it all.
417
418      * Title: "More on Mouse Drivers"
419        Author: Alan Cox.
420        URL: http://www.linux-mag.com/1999-11/gear_01.html
421        Keywords: mouse, driver, gpm, races, asynchronous I/O.
422        Description: The title still says it all.
423
424      * Title: "Writing Video4linux Radio Driver"
425        Author: Alan Cox.
426        URL: http://www.linux-mag.com/1999-12/gear_01.html
427        Keywords: video4linux, driver, radio, radio devices.
428        Description: The title says it all.
429
430      * Title: "Video4linux Drivers, Part 1: Video-Capture Device"
431        Author: Alan Cox.
432        URL: http://www.linux-mag.com/2000-01/gear_01.html
433        Keywords: video4linux, driver, video capture, capture devices,
434        camera driver.
435        Description: The title says it all.
436
437      * Title: "Video4linux Drivers, Part 2: Video-capture Devices"
438        Author: Alan Cox.
439        URL: http://www.linux-mag.com/2000-02/gear_01.html
440        Keywords: video4linux, driver, video capture, capture devices,
441        camera driver, control, query capabilities, capability, facility.
442        Description: The title says it all.
443
444      * Title: "PCI Management in Linux 2.2"
445        Author: Alan Cox.
446        URL: http://www.linux-mag.com/2000-03/gear_01.html
447        Keywords: PCI, bus, bus-mastering.
448        Description: The title says it all.
449
450      * Title: "Linux 2.4 Kernel Internals"
451        Author: Tigran Aivazian and Christoph Hellwig.
452        URL: http://www.moses.uklinux.net/patches/lki.html
453        Keywords: Linux, kernel, booting, SMB boot, VFS, page cache.
454        Description: A little book used for a short training course.
455        Covers building the kernel image, booting (including SMP bootup),
456        process management, VFS and more.
457
458      * Title: "Linux IP Networking. A Guide to the Implementation and
459        Modification of the Linux Protocol Stack."
460        Author: Glenn Herrin.
461        URL: http://www.cs.unh.edu/cnrg/gherrin
462        Keywords: network, networking, protocol, IP, UDP, TCP, connection,
463        socket, receiving, transmitting, forwarding, routing, packets,
464        modules, /proc, sk_buff, FIB, tags.
465        Description: Excellent paper devoted to the Linux IP Networking,
466        explaining anything from the kernel's to the user space
467        configuration tools' code. Very good to get a general overview of
468        the kernel networking implementation and understand all steps
469        packets follow from the time they are received at the network
470        device till they are delivered to applications. The studied kernel
471        code is from 2.2.14 version. Provides code for a working packet
472        dropper example.
473        
474      * Title: "Get those boards talking under Linux."
475        Author: Alex Ivchenko.
476        URL: http://www.edn.com/article/CA46968.html
477        Keywords: data-acquisition boards, drivers, modules, interrupts,
478        memory allocation.
479        Description: Article written for people wishing to make their data
480        acquisition boards work on their GNU/Linux machines. Gives a basic
481        overview on writing drivers, from the naming of functions to
482        interrupt handling.
483        Notes: Two-parts article. Part II is at
484        URL: http://www.edn.com/article/CA46998.html
485        
486      * Title: "Linux PCMCIA Programmer's Guide"
487        Author: David Hinds.
488        URL: http://pcmcia-cs.sourceforge.net/ftp/doc/PCMCIA-PROG.html
489        Keywords: PCMCIA.
490        Description: "This document describes how to write kernel device
491        drivers for the Linux PCMCIA Card Services interface. It also
492        describes how to write user-mode utilities for communicating with
493        Card Services.
494
495      * Title: "The Linux Kernel NFSD Implementation"
496        Author: Neil Brown.
497        URL:
498        http://www.cse.unsw.edu.au/~neilb/oss/linux-commentary/nfsd.html
499        Keywords: knfsd, nfsd, NFS, RPC, lockd, mountd, statd.
500        Description: The title says it all.
501        Notes: Covers knfsd's version 1.4.7 (patch against 2.2.7 kernel).
502        
503      * Title: "A Linux vm README"
504        Author: Kanoj Sarcar.
505        URL: http://reality.sgi.com/kanoj_engr/vm229.html
506        Keywords: virtual memory, mm, pgd, vma, page, page flags, page
507        cache, swap cache, kswapd.
508        Description: Telegraphic, short descriptions and definitions
509        relating the Linux virtual memory implementation.
510        
511      * Title: "(nearly) Complete Linux Loadable Kernel Modules. The
512        definitive guide for hackers, virus coders and system
513        administrators."
514        Author: pragmatic/THC.
515        URL: http://packetstormsecurity.org/docs/hack/LKM_HACKING.html
516        Keywords: syscalls, intercept, hide, abuse, symbol table.
517        Description: Interesting paper on how to abuse the Linux kernel in
518        order to intercept and modify syscalls, make
519        files/directories/processes invisible, become root, hijack ttys,
520        write kernel modules based virus... and solutions for admins to
521        avoid all those abuses.
522        Notes: For 2.0.x kernels. Gives guidances to port it to 2.2.x
523        kernels.
524        
525      BOOKS: (Not on-line)
526    
527      * Title: "Linux Device Drivers"
528        Author: Alessandro Rubini.
529        Publisher: O'Reilly & Associates.
530        Date: 1998.
531        Pages: 439.
532        ISBN: 1-56592-292-1
533        
534      * Title: "Linux Device Drivers, 2nd Edition"
535        Author: Alessandro Rubini and Jonathan Corbet.
536        Publisher: O'Reilly & Associates.
537        Date: 2001.
538        Pages: 586.
539        ISBN: 0-59600-008-1
540        Notes: Further information in
541        http://www.oreilly.com/catalog/linuxdrive2/
542
543      * Title: "Linux Device Drivers, 3nd Edition"
544        Authors: Jonathan Corbet, Alessandro Rubini, and Greg Kroah-Hartman
545        Publisher: O'Reilly & Associates.
546        Date: 2005.
547        Pages: 636.
548        ISBN: 0-596-00590-3
549        Notes: Further information in
550        http://www.oreilly.com/catalog/linuxdrive3/
551        PDF format, URL: http://lwn.net/Kernel/LDD3/
552
553      * Title: "Linux Kernel Internals"
554        Author: Michael Beck.
555        Publisher: Addison-Wesley.
556        Date: 1997.
557        ISBN: 0-201-33143-8 (second edition)
558        
559      * Title: "The Design of the UNIX Operating System"
560        Author: Maurice J. Bach.
561        Publisher: Prentice Hall.
562        Date: 1986.
563        Pages: 471.
564        ISBN: 0-13-201757-1
565        
566      * Title: "The Design and Implementation of the 4.3 BSD UNIX
567        Operating System"
568        Author: Samuel J. Leffler, Marshall Kirk McKusick, Michael J.
569        Karels, John S. Quarterman.
570        Publisher: Addison-Wesley.
571        Date: 1989 (reprinted with corrections on October, 1990).
572        ISBN: 0-201-06196-1
573        
574      * Title: "The Design and Implementation of the 4.4 BSD UNIX
575        Operating System"
576        Author: Marshall Kirk McKusick, Keith Bostic, Michael J. Karels,
577        John S. Quarterman.
578        Publisher: Addison-Wesley.
579        Date: 1996.
580        ISBN: 0-201-54979-4
581        
582      * Title: "Programmation Linux 2.0 API systeme et fonctionnement du
583        noyau"
584        Author: Remy Card, Eric Dumas, Franck Mevel.
585        Publisher: Eyrolles.
586        Date: 1997.
587        Pages: 520.
588        ISBN: 2-212-08932-5
589        Notes: French.
590
591      * Title: "Unix internals -- the new frontiers"
592        Author: Uresh Vahalia.
593        Publisher: Prentice Hall.
594        Date: 1996.
595        Pages: 600.
596        ISBN: 0-13-101908-2
597
598      * Title:  "The  Design  and Implementation of the 4.4 BSD UNIX
599        Operating System"
600        Author: Marshall Kirk McKusick, Keith Bostic, Michael J. Karels,
601        John S. Quarterman.
602        Publisher: Addison-Wesley.
603        Date: 1996.
604        ISBN: 0-201-54979-4
605
606      * Title: "Programming for the real world - POSIX.4"
607        Author: Bill O. Gallmeister.
608        Publisher: O'Reilly & Associates, Inc..
609        Date: 1995.
610        Pages: ???.
611        ISBN: I-56592-074-0
612        Notes: Though not being directly about Linux, Linux aims to be
613        POSIX. Good reference.
614
615      * Title:  "UNIX  Systems  for  Modern Architectures: Symmetric
616        Multiprocesssing and Caching for Kernel Programmers"
617        Author: Curt Schimmel.
618        Publisher: Addison Wesley.
619        Date: June, 1994.
620        Pages: 432.
621        ISBN: 0-201-63338-8
622
623      * Title:  "The  Design  and Implementation of the 4.3 BSD UNIX
624        Operating System"
625        Author: Samuel J. Leffler, Marshall Kirk McKusick, Michael J.
626        Karels, John S. Quarterman.
627        Publisher: Addison-Wesley.
628        Date: 1989 (reprinted with corrections on October, 1990).
629        ISBN: 0-201-06196-1
630
631      * Title: "The Design of the UNIX Operating System"
632        Author: Maurice J. Bach.
633        Publisher: Prentice Hall.
634        Date: 1986.
635        Pages: 471.
636        ISBN: 0-13-201757-1
637
638      MISCELLANEOUS:
639
640      * Name: linux/Documentation
641        Author: Many.
642        URL: Just look inside your kernel sources.
643        Keywords: anything, DocBook.
644        Description: Documentation that comes with the kernel sources,
645        inside the Documentation directory. Some pages from this document
646        (including this document itself) have been moved there, and might
647        be more up to date than the web version.
648
649      * Name: "Linux Source Driver"
650        URL: http://lsd.linux.cz
651        Keywords: Browsing source code.
652        Description: "Linux Source Driver (LSD) is an application, which
653        can make browsing source codes of Linux kernel easier than you can
654        imagine. You can select between multiple versions of kernel (e.g.
655        0.01, 1.0.0, 2.0.33, 2.0.34pre13, 2.0.0, 2.1.101 etc.). With LSD
656        you can search Linux kernel (fulltext, macros, types, functions
657        and variables) and LSD can generate patches for you on the fly
658        (files, directories or kernel)".
659
660      * Name: "Linux Kernel Source Reference"
661        Author: Thomas Graichen.
662        URL: http://innominate.org/~graichen/projects/lksr/
663        Keywords: CVS, web, cvsweb, browsing source code.
664        Description: Web interface to a CVS server with the kernel
665        sources. "Here you can have a look at any file of the Linux kernel
666        sources of any version starting from 1.0 up to the (daily updated)
667        current version available. Also you can check the differences
668        between two versions of a file".
669
670      * Name: "Cross-Referencing Linux"
671        URL: http://lxr.linux.no/source/
672        Keywords: Browsing source code.
673        Description: Another web-based Linux kernel source code browser.
674        Lots of cross references to variables and functions. You can see
675        where they are defined and where they are used.
676
677      * Name: "Linux Weekly News"
678        URL: http://lwn.net
679        Keywords: latest kernel news.
680        Description: The title says it all. There's a fixed kernel section
681        summarizing developers' work, bug fixes, new features and versions
682        produced during the week. Published every Thursday.
683
684      * Name: "Kernel Traffic"
685        URL: http://kt.zork.net/kernel-traffic/
686        Keywords: linux-kernel mailing list, weekly kernel news.
687        Description: Weekly newsletter covering the most relevant
688        discussions of the linux-kernel mailing list.
689
690      * Name: "CuTTiNG.eDGe.LiNuX"
691        URL: http://edge.kernelnotes.org
692        Keywords: changelist.
693        Description: Site which provides the changelist for every kernel
694        release. What's new, what's better, what's changed. Myrdraal reads
695        the patches and describes them. Pointers to the patches are there,
696        too.
697
698      * Name: "New linux-kernel Mailing List FAQ"
699        URL: http://www.tux.org/lkml/
700        Keywords: linux-kernel mailing list FAQ.
701        Description: linux-kernel is a mailing list for developers to
702        communicate. This FAQ builds on the previous linux-kernel mailing
703        list FAQ maintained by Frohwalt Egerer, who no longer maintains
704        it. Read it to see how to join the mailing list. Dozens of
705        interesting questions regarding the list, Linux, developers (who
706        is ...?), terms (what is...?) are answered here too. Just read it.
707
708      * Name: "Linux Virtual File System"
709        Author: Peter J. Braam.
710        URL: http://www.coda.cs.cmu.edu/doc/talks/linuxvfs/
711        Keywords: slides, VFS, inode, superblock, dentry, dcache.
712        Description: Set of slides, presumably from a presentation on the
713        Linux VFS layer. Covers version 2.1.x, with dentries and the
714        dcache.
715
716      * Name: "Gary's Encyclopedia - The Linux Kernel"
717        Author: Gary (I suppose...).
718        URL: http://slencyclopedia.berlios.de/index.html
719        Keywords: linux, community, everything!
720        Description: Gary's Encyclopedia exists to allow the rapid finding
721        of documentation and other information of interest to GNU/Linux
722        users. It has about 4000 links to external pages in 150 major
723        categories. This link is for kernel-specific links, documents,
724        sites...  This list is now hosted by developer.Berlios.de,
725        but seems not to have been updated since sometime in 1999.
726
727      * Name: "The home page of Linux-MM"
728        Author: The Linux-MM team.
729        URL: http://linux-mm.org/
730        Keywords: memory management, Linux-MM, mm patches, TODO, docs,
731        mailing list.
732        Description: Site devoted to Linux Memory Management development.
733        Memory related patches, HOWTOs, links, mm developers... Don't miss
734        it if you are interested in memory management development!
735
736      * Name: "Kernel Newbies IRC Channel"
737        URL: http://www.kernelnewbies.org
738        Keywords: IRC, newbies, channel, asking doubts.
739        Description: #kernelnewbies on irc.openprojects.net. From the web
740        page: "#kernelnewbies is an IRC network dedicated to the 'newbie'
741        kernel hacker. The audience mostly consists of people who are
742        learning about the kernel, working on kernel projects or
743        professional kernel hackers that want to help less seasoned kernel
744        people. [...] #kernelnewbies is on the Open Projects IRC Network,
745        try irc.openprojects.net or irc.<country>.openprojects.net as your
746        server and then /join #kernelnewbies". It also hosts articles,
747        documents, FAQs...
748        
749      * Name: "linux-kernel mailing list archives and search engines"
750        URL: http://vger.kernel.org/vger-lists.html
751        URL: http://www.uwsg.indiana.edu/hypermail/linux/kernel/index.html
752        URL: http://marc.theaimsgroup.com/?l=linux-kernel
753        URL: http://groups.google.com/group/mlist.linux.kernel
754        URL: http://www.cs.helsinki.fi/linux/linux-kernel/
755        URL: http://www.lib.uaa.alaska.edu/linux-kernel/
756        Keywords: linux-kernel, archives, search.
757        Description: Some of the linux-kernel mailing list archivers. If
758        you have a better/another one, please let me know.
759      _________________________________________________________________
760    
761    Document last updated on Sat 2005-NOV-19