blob: 8b056363344299c3822cd38427429007bb1c44b7 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001
2This is a brief list of all the files in ./linux/Documentation and what
3they contain. If you add a documentation file, please list it here in
4alphabetical order as well, or risk being hunted down like a rabid dog.
5Please try and keep the descriptions small enough to fit on one line.
6 Thanks -- Paul G.
7
8Following translations are available on the WWW:
9
10 - Japanese, maintained by the JF Project (JF@linux.or.jp), at
11 http://www.linux.or.jp/JF/
12
1300-INDEX
14 - this file.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070015ABI/
16 - info on kernel <-> userspace ABI and relative interface stability.
Linus Torvalds1da177e2005-04-16 15:20:36 -070017BUG-HUNTING
18 - brute force method of doing binary search of patches to find bug.
19Changes
20 - list of changes that break older software packages.
21CodingStyle
22 - how the boss likes the C code in the kernel to look.
23DMA-API.txt
24 - DMA API, pci_ API & extensions for non-consistent memory machines.
25DMA-mapping.txt
26 - info for PCI drivers using DMA portably across all platforms.
27DocBook/
28 - directory with DocBook templates etc. for kernel documentation.
Greg Kroah-Hartmand36cc9d2005-11-18 09:31:11 -080029HOWTO
Jesper Juhlf6b07d32007-07-15 23:41:41 -070030 - the process and procedures of how to do Linux kernel development.
Linus Torvalds1da177e2005-04-16 15:20:36 -070031IO-mapping.txt
32 - how to access I/O mapped memory from within device drivers.
33IPMI.txt
34 - info on Linux Intelligent Platform Management Interface (IPMI) Driver.
35IRQ-affinity.txt
36 - how to select which CPU(s) handle which interrupt events on SMP.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070037IRQ.txt
38 - description of what an IRQ is.
Linus Torvalds1da177e2005-04-16 15:20:36 -070039ManagementStyle
40 - how to (attempt to) manage kernel hackers.
41MSI-HOWTO.txt
42 - the Message Signaled Interrupts (MSI) Driver Guide HOWTO and FAQ.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070043PCIEBUS-HOWTO.txt
44 - a guide describing the PCI Express Port Bus driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -070045RCU/
46 - directory with info on RCU (read-copy update).
47README.DAC960
48 - info on Mylex DAC960/DAC1100 PCI RAID Controller Driver for Linux.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070049README.cycladesZ
50 - info on Cyclades-Z firmware loading.
Linus Torvalds1da177e2005-04-16 15:20:36 -070051SAK.txt
52 - info on Secure Attention Keys.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070053SecurityBugs
54 - procedure for reporting security bugs found in the kernel.
55SubmitChecklist
56 - Linux kernel patch submission checklist.
Linus Torvalds1da177e2005-04-16 15:20:36 -070057SubmittingDrivers
58 - procedure to get a new driver source included into the kernel tree.
59SubmittingPatches
60 - procedure to get a source patch included into the kernel tree.
61VGA-softcursor.txt
62 - how to change your VGA cursor from a blinking underscore.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070063accounting/
64 - documentation on accounting and taskstats.
65aoe/
66 - description of AoE (ATA over Ethernet) along with config examples.
Jesper Juhl754c7972005-09-09 13:10:12 -070067applying-patches.txt
68 - description of various trees and how to apply their patches.
Linus Torvalds1da177e2005-04-16 15:20:36 -070069arm/
70 - directory with info about Linux on the ARM architecture.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070071atomic_ops.txt
72 - semantics and behavior of atomic and bitmask operations.
73auxdisplay/
74 - misc. LCD driver documentation (cfag12864b, ks0108).
Linus Torvalds1da177e2005-04-16 15:20:36 -070075basic_profiling.txt
76 - basic instructions for those who wants to profile Linux kernel.
77binfmt_misc.txt
78 - info on the kernel support for extra binary formats.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070079blackfin/
80 - directory with documentation for the Blackfin arch.
Linus Torvalds1da177e2005-04-16 15:20:36 -070081block/
82 - info on the Block I/O (BIO) layer.
83cachetlb.txt
84 - describes the cache/TLB flushing interfaces Linux uses.
85cciss.txt
86 - info, major/minor #'s for Compaq's SMART Array Controllers.
87cdrom/
88 - directory with information on the CD-ROM drivers that Linux has.
89cli-sti-removal.txt
90 - cli()/sti() removal guide.
91computone.txt
92 - info on Computone Intelliport II/Plus Multiport Serial Driver.
Jesper Juhlf6b07d32007-07-15 23:41:41 -070093connector/
94 - docs on the netlink based userspace<->kernel space communication mod.
95console/
96 - documentation on Linux console drivers.
Linus Torvalds1da177e2005-04-16 15:20:36 -070097cpqarray.txt
98 - info on using Compaq's SMART2 Intelligent Disk Array Controllers.
99cpu-freq/
100 - info on CPU frequency and voltage scaling.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700101cpu-hotplug.txt
102 - document describing CPU hotplug support in the Linux kernel.
103cpu-load.txt
104 - document describing how CPU load statistics are collected.
105cpusets.txt
106 - documents the cpusets feature; assign CPUs and Mem to a set of tasks.
107cputopology.txt
108 - documentation on how CPU topology info is exported via sysfs.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109cris/
110 - directory with info about Linux on CRIS architecture.
111crypto/
112 - directory with info on the Crypto API.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700113dcdbas.txt
114 - information on the Dell Systems Management Base Driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115debugging-modules.txt
116 - some notes on debugging modules after Linux 2.6.3.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700117dell_rbu.txt
118 - document demonstrating the use of the Dell Remote BIOS Update driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700119device-mapper/
120 - directory with info on Device Mapper.
121devices.txt
122 - plain ASCII listing of all the nodes in /dev/ with major minor #'s.
123digiepca.txt
124 - info on Digi Intl. {PC,PCI,EISA}Xx and Xem series cards.
125dnotify.txt
126 - info about directory notification in Linux.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700127dontdiff
128 - file containing a list of files that should never be diff'ed.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700129driver-model/
130 - directory with info about Linux driver model.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700131drivers/
132 - directory with driver documentation (currently only EDAC).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133dvb/
134 - info on Linux Digital Video Broadcast (DVB) subsystem.
135early-userspace/
136 - info about initramfs, klibc, and userspace early during boot.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700137ecryptfs.txt
138 - docs on eCryptfs: stacked cryptographic filesystem for Linux.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700139eisa.txt
140 - info on EISA bus support.
141exception.txt
142 - how Linux v2.2 handles exceptions without verify_area etc.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700143fault-injection/
144 - dir with docs about the fault injection capabilities infrastructure.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145fb/
146 - directory with info on the frame buffer graphics abstraction layer.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700147feature-removal-schedule.txt
148 - list of files and features that are going to be removed.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700149filesystems/
150 - directory with info on the various filesystems that Linux supports.
151firmware_class/
152 - request_firmware() hotplug interface info.
153floppy.txt
154 - notes and driver options for the floppy disk driver.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700155fujitsu/
156 - Fujitsu FR-V Linux documentation.
157gpio.txt
158 - overview of GPIO (General Purpose Input/Output) access conventions.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159hayes-esp.txt
160 - info on using the Hayes ESP serial driver.
161highuid.txt
162 - notes on the change from 16 bit to 32 bit user/group IDs.
163hpet.txt
164 - High Precision Event Timer Driver for Linux.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700165hrtimer/
166 - info on the timer_stats debugging facility for timer (ab)use.
167hrtimers/
168 - info on the hrtimers subsystem for high-resolution kernel timers.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700169hw_random.txt
170 - info on Linux support for random number generator in i8xx chipsets.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700171hwmon/
172 - directory with docs on various hardware monitoring drivers.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173i2c/
174 - directory with info about the I2C bus/protocol (2 wire, kHz speed).
175i2o/
176 - directory with info about the Linux I2O subsystem.
177i386/
178 - directory with info about Linux on Intel 32 bit architecture.
179ia64/
180 - directory with info about Linux on Intel 64 bit architecture.
181ide.txt
182 - important info for users of ATA devices (IDE/EIDE disks and CD-ROMS).
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700183infiniband/
184 - directory with documents concerning Linux InfiniBand support.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185initrd.txt
186 - how to use the RAM disk as an initial/temporary root filesystem.
187input/
188 - info on Linux input device support.
189io_ordering.txt
190 - info on ordering I/O writes to memory-mapped addresses.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700191ioctl/
192 - directory with documents describing various IOCTL calls.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700193ioctl-number.txt
194 - how to implement and register device/driver ioctl calls.
195iostats.txt
196 - info on I/O statistics Linux kernel provides.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700197irqflags-tracing.txt
198 - how to use the irq-flags tracing feature.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700199isapnp.txt
200 - info on Linux ISA Plug & Play support.
201isdn/
202 - directory with info on the Linux ISDN support, and supported cards.
203java.txt
204 - info on the in-kernel binary support for Java(tm).
205kbuild/
206 - directory with info about the kernel build process.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700207kdump/
208 - directory with mini HowTo on getting the crash dump code to work.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700209kernel-doc-nano-HOWTO.txt
210 - mini HowTo on generation and location of kernel documentation files.
211kernel-docs.txt
212 - listing of various WWW + books that document kernel internals.
213kernel-parameters.txt
214 - summary listing of command line / boot prompt args for the kernel.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700215keys-request-key.txt
216 - description of the kernel key request service.
217keys.txt
218 - description of the kernel key retention service.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700219kobject.txt
220 - info of the kobject infrastructure of the Linux kernel.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700221kprobes.txt
222 - documents the kernel probes debugging feature.
223kref.txt
224 - docs on adding reference counters (krefs) to kernel objects.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700225laptop-mode.txt
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700226 - how to conserve battery power using laptop-mode.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700227ldm.txt
228 - a brief description of LDM (Windows Dynamic Disks).
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700229leds-class.txt
230 - documents LED handling under Linux.
231local_ops.txt
232 - semantics and behavior of local atomic operations.
233lockdep-design.txt
234 - documentation on the runtime locking correctness validator.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700235locks.txt
236 - info on file locking implementations, flock() vs. fcntl(), etc.
237logo.gif
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700238 - full colour GIF image of Linux logo (penguin - Tux).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700239logo.txt
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700240 - info on creator of above logo & site to get additional images from.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700241m68k/
242 - directory with info about Linux on Motorola 68k architecture.
243magic-number.txt
244 - list of magic numbers used to mark/protect kernel data structures.
245mandatory.txt
246 - info on the Linux implementation of Sys V mandatory file locking.
247mca.txt
248 - info on supporting Micro Channel Architecture (e.g. PS/2) systems.
249md.txt
250 - info on boot arguments for the multiple devices driver.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700251memory-barriers.txt
252 - info on Linux kernel memory barriers.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700253memory.txt
254 - info on typical Linux memory problems.
255mips/
256 - directory with info about Linux on MIPS architecture.
257mono.txt
258 - how to execute Mono-based .NET binaries with the help of BINFMT_MISC.
259moxa-smartio
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700260 - file with info on installing/using Moxa multiport serial driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700261mtrr.txt
262 - how to use PPro Memory Type Range Registers to increase performance.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700263mutex-design.txt
264 - info on the generic mutex subsystem.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700265nbd.txt
266 - info on a TCP implementation of a network block device.
Paul Moore8802f612006-08-03 16:45:49 -0700267netlabel/
268 - directory with information on the NetLabel subsystem.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700269networking/
270 - directory with info on various aspects of networking with Linux.
271nfsroot.txt
272 - short guide on setting up a diskless box with NFS root filesystem.
273nmi_watchdog.txt
274 - info on NMI watchdog for SMP systems.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700275nommu-mmap.txt
276 - documentation about no-mmu memory mapping support.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700277numastat.txt
278 - info on how to read Numa policy hit/miss statistics in sysfs.
279oops-tracing.txt
280 - how to decode those nasty internal kernel error dump messages.
281paride.txt
282 - information about the parallel port IDE subsystem.
283parisc/
284 - directory with info on using Linux on PA-RISC architecture.
285parport.txt
286 - how to use the parallel-port driver.
287parport-lowlevel.txt
288 - description and usage of the low level parallel port functions.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700289pci-error-recovery.txt
290 - info on PCI error recovery.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700291pci.txt
292 - info on the PCI subsystem for device driver authors.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700293pcieaer-howto.txt
294 - the PCI Express Advanced Error Reporting Driver Guide HOWTO.
295pcmcia/
296 - info on the Linux PCMCIA driver.
297pi-futex.txt
298 - documentation on lightweight PI-futexes.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700299pm.txt
300 - info on Linux power management support.
301pnp.txt
302 - Linux Plug and Play documentation.
303power/
304 - directory with info on Linux PCI power management.
305powerpc/
306 - directory with info on using Linux with the PowerPC.
307preempt-locking.txt
308 - info on locking under a preemptive kernel.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700309prio_tree.txt
310 - info on radix-priority-search-tree use for indexing vmas.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700311ramdisk.txt
312 - short guide on how to set up and use the RAM disk.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700313rbtree.txt
314 - info on what red-black trees are and what they are for.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700315riscom8.txt
316 - notes on using the RISCom/8 multi-port serial driver.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700317robust-futex-ABI.txt
318 - documentation of the robust futex ABI.
319robust-futexes.txt
320 - a description of what robust futexes are.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700321rocket.txt
322 - info on the Comtrol RocketPort multiport serial driver.
323rpc-cache.txt
324 - introduction to the caching mechanisms in the sunrpc layer.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700325rt-mutex-design.txt
326 - description of the RealTime mutex implementation design.
327rt-mutex.txt
328 - desc. of RT-mutex subsystem with PI (Priority Inheritance) support.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700329rtc.txt
330 - notes on how to use the Real Time Clock (aka CMOS clock) driver.
331s390/
332 - directory with info on using Linux on the IBM S390.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700333sched-arch.txt
334 - CPU Scheduler implementation hints for architecture specific code.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700335sched-coding.txt
336 - reference for various scheduler-related methods in the O(1) scheduler.
337sched-design.txt
338 - goals, design and implementation of the Linux O(1) scheduler.
339sched-domains.txt
340 - information on scheduling domains.
341sched-stats.txt
342 - information on schedstats (Linux Scheduler Statistics).
343scsi/
344 - directory with info on Linux scsi support.
345serial/
346 - directory with info on the low level serial API.
347serial-console.txt
348 - how to set up Linux with a serial line console as the default.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700349sgi-ioc4.txt
350 - description of the SGI IOC4 PCI (multi function) device.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700351sgi-visws.txt
352 - short blurb on the SGI Visual Workstations.
353sh/
354 - directory with info on porting Linux to a new architecture.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700355sharedsubtree.txt
356 - a description of shared subtrees for namespaces.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700357smart-config.txt
358 - description of the Smart Config makefile feature.
359smp.txt
360 - a few notes on symmetric multi-processing.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700361sony-laptop.txt
362 - Sony Notebook Control Driver (SNC) Readme.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700363sonypi.txt
364 - info on Linux Sony Programmable I/O Device support.
365sound/
366 - directory with info on sound card support.
367sparc/
368 - directory with info on using Linux on Sparc architecture.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700369sparse.txt
370 - info on how to obtain and use the sparse tool for typechecking.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700371specialix.txt
372 - info on hardware/driver for specialix IO8+ multiport serial card.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700373spi/
374 - overview of Linux kernel Serial Peripheral Interface (SPI) support.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700375spinlocks.txt
376 - info on using spinlocks to provide exclusive access in kernel.
Greg Kroah-Hartman8907e942005-11-18 09:31:15 -0800377stable_api_nonsense.txt
378 - info on why the kernel does not have a stable in-kernel api or abi.
379stable_kernel_rules.txt
380 - rules and procedures for the -stable kernel releases.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700381stallion.txt
382 - info on using the Stallion multiport serial driver.
383svga.txt
384 - short guide on selecting video modes at boot via VGA BIOS.
385sx.txt
386 - info on the Specialix SX/SI multiport serial driver.
387sysctl/
388 - directory with info on the /proc/sys/* files.
389sysrq.txt
390 - info on the magic SysRq key.
391telephony/
392 - directory with info on telephony (e.g. voice over IP) support.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700393thinkpad-acpi.txt
394 - information on the (IBM and Lenovo) ThinkPad ACPI Extras driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700395time_interpolators.txt
396 - info on time interpolators.
397tipar.txt
398 - information about Parallel link cable for Texas Instruments handhelds.
399tty.txt
400 - guide to the locking policies of the tty layer.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700401uml/
Tobias Klauserd533f672005-09-10 00:26:46 -0700402 - directory with information about User Mode Linux.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700403unicode.txt
404 - info on the Unicode character/font mapping used in Linux.
405unshare.txt
406 - description of the Linux unshare system call.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700407usb/
408 - directory with info regarding the Universal Serial Bus.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700409video-output.txt
410 - sysfs class driver interface to enable/disable a video output device.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700411video4linux/
412 - directory with info regarding video/TV/radio cards and linux.
413vm/
414 - directory with info on the Linux vm code.
415voyager.txt
416 - guide to running Linux on the Voyager architecture.
Jesper Juhlf6b07d32007-07-15 23:41:41 -0700417w1/
418 - directory with documents regarding the 1-wire (w1) subsystem.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700419watchdog/
420 - how to auto-reboot Linux if it has "fallen and can't get up". ;-)
421x86_64/
422 - directory with info on Linux support for AMD x86-64 (Hammer) machines.
423xterm-linux.xpm
424 - XPM image of penguin logo (see logo.txt) sitting on an xterm.
425zorro.txt
426 - info on writing drivers for Zorro bus devices found on Amigas.