Linux 3.19-rc2
[deliverable/linux.git] / Documentation / 00-INDEX
CommitLineData
1da177e4
LT
1
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.
449e3a72 5Please keep the descriptions small enough to fit on one line.
1da177e4
LT
6 Thanks -- Paul G.
7
8Following translations are available on the WWW:
9
010f4564
MI
10 - Japanese, maintained by the JF Project (jf@listserv.linux.or.jp), at
11 http://linuxjf.sourceforge.jp/
1da177e4
LT
12
1300-INDEX
14 - this file.
f6b07d39
JJ
15ABI/
16 - info on kernel <-> userspace ABI and relative interface stability.
b4d2730a 17
1da177e4
LT
18BUG-HUNTING
19 - brute force method of doing binary search of patches to find bug.
20Changes
21 - list of changes that break older software packages.
22CodingStyle
449e3a72 23 - how the maintainers expect the C code in the kernel to look.
1da177e4
LT
24DMA-API.txt
25 - DMA API, pci_ API & extensions for non-consistent memory machines.
449e3a72
PG
26DMA-API-HOWTO.txt
27 - Dynamic DMA mapping Guide
5ef43567
RL
28DMA-ISA-LPC.txt
29 - How to do DMA with ISA (and LPC) devices.
449e3a72
PG
30DMA-attributes.txt
31 - listing of the various possible attributes a DMA region can have
3cf8ca1c
HA
32dmatest.txt
33 - how to compile, configure and use the dmatest system.
1da177e4
LT
34DocBook/
35 - directory with DocBook templates etc. for kernel documentation.
449e3a72
PG
36EDID/
37 - directory with info on customizing EDID for broken gfx/displays.
d36cc9d0 38HOWTO
f6b07d39 39 - the process and procedures of how to do Linux kernel development.
1da177e4
LT
40IPMI.txt
41 - info on Linux Intelligent Platform Management Interface (IPMI) Driver.
42IRQ-affinity.txt
43 - how to select which CPU(s) handle which interrupt events on SMP.
449e3a72 44IRQ-domain.txt
453f42d3 45 - info on interrupt numbering and setting up IRQ domains.
f6b07d39
JJ
46IRQ.txt
47 - description of what an IRQ is.
449e3a72
PG
48Intel-IOMMU.txt
49 - basic info on the Intel IOMMU virtualization support.
50Makefile
51 - some files in Documentation dir are actually sample code to build
1da177e4
LT
52ManagementStyle
53 - how to (attempt to) manage kernel hackers.
1da177e4
LT
54RCU/
55 - directory with info on RCU (read-copy update).
1da177e4
LT
56SAK.txt
57 - info on Secure Attention Keys.
5ef43567
RL
58SM501.txt
59 - Silicon Motion SM501 multimedia companion chip
f6b07d39
JJ
60SecurityBugs
61 - procedure for reporting security bugs found in the kernel.
62SubmitChecklist
63 - Linux kernel patch submission checklist.
1da177e4
LT
64SubmittingDrivers
65 - procedure to get a new driver source included into the kernel tree.
66SubmittingPatches
67 - procedure to get a source patch included into the kernel tree.
68VGA-softcursor.txt
69 - how to change your VGA cursor from a blinking underscore.
f6b07d39
JJ
70accounting/
71 - documentation on accounting and taskstats.
b4d2730a
LB
72acpi/
73 - info on ACPI-specific hooks in the kernel.
f6b07d39
JJ
74aoe/
75 - description of AoE (ATA over Ethernet) along with config examples.
754c7976
JJ
76applying-patches.txt
77 - description of various trees and how to apply their patches.
1da177e4
LT
78arm/
79 - directory with info about Linux on the ARM architecture.
449e3a72
PG
80arm64/
81 - directory with info about Linux on the 64 bit ARM architecture.
3cf8ca1c
HA
82assoc_array.txt
83 - generic associative array intro.
f6b07d39
JJ
84atomic_ops.txt
85 - semantics and behavior of atomic and bitmask operations.
86auxdisplay/
87 - misc. LCD driver documentation (cfag12864b, ks0108).
449e3a72
PG
88backlight/
89 - directory with info on controlling backlights in flat panel displays
90bad_memory.txt
91 - how to use kernel parameters to exclude bad RAM regions.
1da177e4
LT
92basic_profiling.txt
93 - basic instructions for those who wants to profile Linux kernel.
3cf8ca1c
HA
94bcache.txt
95 - Block-layer cache on fast SSDs to improve slow (raid) I/O performance.
1da177e4
LT
96binfmt_misc.txt
97 - info on the kernel support for extra binary formats.
f6b07d39
JJ
98blackfin/
99 - directory with documentation for the Blackfin arch.
1da177e4
LT
100block/
101 - info on the Block I/O (BIO) layer.
31c00fc1
RD
102blockdev/
103 - info on block devices & drivers
449e3a72
PG
104braille-console.txt
105 - info on how to use serial devices for Braille support.
106bt8xxgpio.txt
107 - info on how to modify a bt8xx video card for GPIO usage.
196be0cd
BZ
108btmrvl.txt
109 - info on Marvell Bluetooth driver usage.
449e3a72
PG
110bus-devices/
111 - directory with info on TI GPMC (General Purpose Memory Controller)
9fe41e41
RD
112bus-virt-phys-mapping.txt
113 - how to access I/O mapped memory from within device drivers.
1da177e4
LT
114cachetlb.txt
115 - describes the cache/TLB flushing interfaces Linux uses.
1da177e4
LT
116cdrom/
117 - directory with information on the CD-ROM drivers that Linux has.
21acb9ca
TLSC
118cgroups/
119 - cgroups features, including cpusets and memory controller.
449e3a72
PG
120circular-buffers.txt
121 - how to make use of the existing circular buffer infrastructure
122clk.txt
123 - info on the common clock framework
124coccinelle.txt
125 - info on how to get and use the Coccinelle code checking tool.
f6b07d39
JJ
126connector/
127 - docs on the netlink based userspace<->kernel space communication mod.
128console/
129 - documentation on Linux console drivers.
1da177e4
LT
130cpu-freq/
131 - info on CPU frequency and voltage scaling.
f6b07d39
JJ
132cpu-hotplug.txt
133 - document describing CPU hotplug support in the Linux kernel.
134cpu-load.txt
135 - document describing how CPU load statistics are collected.
fe8e288a
VP
136cpuidle/
137 - info on CPU_IDLE, CPU idle state management subsystem.
f6b07d39
JJ
138cputopology.txt
139 - documentation on how CPU topology info is exported via sysfs.
fbedceb1
BP
140crc32.txt
141 - brief tutorial on CRC computation
1da177e4
LT
142cris/
143 - directory with info about Linux on CRIS architecture.
144crypto/
145 - directory with info on the Crypto API.
f6b07d39
JJ
146dcdbas.txt
147 - information on the Dell Systems Management Base Driver.
1da177e4
LT
148debugging-modules.txt
149 - some notes on debugging modules after Linux 2.6.3.
449e3a72
PG
150debugging-via-ohci1394.txt
151 - how to use firewire like a hardware debugger memory reader.
f6b07d39
JJ
152dell_rbu.txt
153 - document demonstrating the use of the Dell Remote BIOS Update driver.
449e3a72
PG
154development-process/
155 - how to work with the mainline kernel development process.
1da177e4
LT
156device-mapper/
157 - directory with info on Device Mapper.
158devices.txt
159 - plain ASCII listing of all the nodes in /dev/ with major minor #'s.
449e3a72
PG
160devicetree/
161 - directory with info on device tree files used by OF/PowerPC/ARM
162digsig.txt
163 -info on the Digital Signature Verification API
164dma-buf-sharing.txt
165 - the DMA Buffer Sharing API Guide
166dmaengine.txt
167 -the DMA Engine API Guide
f6b07d39
JJ
168dontdiff
169 - file containing a list of files that should never be diff'ed.
1da177e4
LT
170driver-model/
171 - directory with info about Linux driver model.
172dvb/
173 - info on Linux Digital Video Broadcast (DVB) subsystem.
449e3a72
PG
174dynamic-debug-howto.txt
175 - how to use the dynamic debug (dyndbg) feature.
1da177e4
LT
176early-userspace/
177 - info about initramfs, klibc, and userspace early during boot.
4a6b88ca
AB
178edac.txt
179 - information on EDAC - Error Detection And Correction
3cf8ca1c
HA
180efi-stub.txt
181 - How to use the EFI boot stub to bypass GRUB or elilo on EFI systems.
1da177e4
LT
182eisa.txt
183 - info on EISA bus support.
449e3a72
PG
184email-clients.txt
185 - info on how to use e-mail to send un-mangled (git) patches.
186extcon/
187 - directory with porting guide for Android kernel switch driver.
f6b07d39
JJ
188fault-injection/
189 - dir with docs about the fault injection capabilities infrastructure.
1da177e4
LT
190fb/
191 - directory with info on the frame buffer graphics abstraction layer.
192filesystems/
4f3b19ca 193 - info on the vfs and the various filesystems that Linux supports.
1da177e4
LT
194firmware_class/
195 - request_firmware() hotplug interface info.
449e3a72
PG
196flexible-arrays.txt
197 - how to make use of flexible sized arrays in linux
022c6747
AR
198fmc/
199 - information about the FMC bus abstraction
0868ff7a 200frv/
f6b07d39 201 - Fujitsu FR-V Linux documentation.
449e3a72
PG
202futex-requeue-pi.txt
203 - info on requeueing of tasks from a non-PI futex to a PI futex
204gcov.txt
205 - use of GCC's coverage testing tool "gcov" with the Linux kernel
3cf8ca1c
HA
206gpio/
207 - gpio related documentation
449e3a72
PG
208hid/
209 - directory with information on human interface devices
1da177e4
LT
210highuid.txt
211 - notes on the change from 16 bit to 32 bit user/group IDs.
449e3a72
PG
212hwspinlock.txt
213 - hardware spinlock provides hardware assistance for synchronization
3833eecc
TG
214timers/
215 - info on the timer related topics
1da177e4
LT
216hw_random.txt
217 - info on Linux support for random number generator in i8xx chipsets.
f6b07d39
JJ
218hwmon/
219 - directory with docs on various hardware monitoring drivers.
1da177e4
LT
220i2c/
221 - directory with info about the I2C bus/protocol (2 wire, kHz speed).
222i2o/
223 - directory with info about the Linux I2O subsystem.
71cced6e 224x86/i386/
1da177e4
LT
225 - directory with info about Linux on Intel 32 bit architecture.
226ia64/
227 - directory with info about Linux on Intel 64 bit architecture.
f6b07d39
JJ
228infiniband/
229 - directory with documents concerning Linux InfiniBand support.
449e3a72
PG
230init.txt
231 - what to do when the kernel can't find the 1st process to run.
1da177e4
LT
232initrd.txt
233 - how to use the RAM disk as an initial/temporary root filesystem.
234input/
235 - info on Linux input device support.
449e3a72
PG
236intel_txt.txt
237 - info on intel Trusted Execution Technology (intel TXT).
9fe41e41
RD
238io-mapping.txt
239 - description of io_mapping functions in linux/io-mapping.h
1da177e4
LT
240io_ordering.txt
241 - info on ordering I/O writes to memory-mapped addresses.
f6b07d39
JJ
242ioctl/
243 - directory with documents describing various IOCTL calls.
1da177e4
LT
244iostats.txt
245 - info on I/O statistics Linux kernel provides.
f6b07d39
JJ
246irqflags-tracing.txt
247 - how to use the irq-flags tracing feature.
1da177e4
LT
248isapnp.txt
249 - info on Linux ISA Plug & Play support.
250isdn/
251 - directory with info on the Linux ISDN support, and supported cards.
252java.txt
253 - info on the in-kernel binary support for Java(tm).
449e3a72
PG
254ja_JP/
255 - directory with Japanese translations of various documents
1da177e4
LT
256kbuild/
257 - directory with info about the kernel build process.
f6b07d39
JJ
258kdump/
259 - directory with mini HowTo on getting the crash dump code to work.
1da177e4
LT
260kernel-doc-nano-HOWTO.txt
261 - mini HowTo on generation and location of kernel documentation files.
262kernel-docs.txt
263 - listing of various WWW + books that document kernel internals.
264kernel-parameters.txt
265 - summary listing of command line / boot prompt args for the kernel.
3cf8ca1c
HA
266kernel-per-CPU-kthreads.txt
267 - List of all per-CPU kthreads and how they introduce jitter.
449e3a72
PG
268kmemcheck.txt
269 - info on dynamic checker that detects uses of uninitialized memory.
270kmemleak.txt
271 - info on how to make use of the kernel memory leak detection system
272ko_KR/
273 - directory with Korean translations of various documents
1da177e4
LT
274kobject.txt
275 - info of the kobject infrastructure of the Linux kernel.
f6b07d39
JJ
276kprobes.txt
277 - documents the kernel probes debugging feature.
278kref.txt
279 - docs on adding reference counters (krefs) to kernel objects.
d6ff3655
CC
280laptops/
281 - directory with laptop related info and laptop driver documentation.
1da177e4
LT
282ldm.txt
283 - a brief description of LDM (Windows Dynamic Disks).
9a684e19
AO
284leds/
285 - directory with info about LED handling under Linux.
f6b07d39
JJ
286local_ops.txt
287 - semantics and behavior of local atomic operations.
288lockdep-design.txt
289 - documentation on the runtime locking correctness validator.
214e0aed
DB
290locking/
291 - directory with info about kernel locking primitives
449e3a72
PG
292lockstat.txt
293 - info on collecting statistics on locks (and contention).
fd058733
JD
294lockup-watchdogs.txt
295 - info on soft and hard lockup detectors (aka nmi_watchdog).
1da177e4 296logo.gif
f6b07d39 297 - full colour GIF image of Linux logo (penguin - Tux).
1da177e4 298logo.txt
f6b07d39 299 - info on creator of above logo & site to get additional images from.
1da177e4
LT
300m68k/
301 - directory with info about Linux on Motorola 68k architecture.
302magic-number.txt
303 - list of magic numbers used to mark/protect kernel data structures.
1da177e4
LT
304md.txt
305 - info on boot arguments for the multiple devices driver.
449e3a72
PG
306media-framework.txt
307 - info on media framework, its data structures, functions and usage.
f6b07d39
JJ
308memory-barriers.txt
309 - info on Linux kernel memory barriers.
449e3a72
PG
310memory-devices/
311 - directory with info on parts like the Texas Instruments EMIF driver
5ef43567
RL
312memory-hotplug.txt
313 - Hotpluggable memory support, how to use and current status.
fdabf525
JH
314metag/
315 - directory with info about Linux on Meta architecture.
1da177e4
LT
316mips/
317 - directory with info about Linux on MIPS architecture.
449e3a72
PG
318misc-devices/
319 - directory with info about devices using the misc dev subsystem
dfe86cba
AH
320mmc/
321 - directory with info about the MMC subsystem
449e3a72
PG
322mn10300/
323 - directory with info about the mn10300 architecture port
3cf8ca1c
HA
324module-signing.txt
325 - Kernel module signing for increased security when loading modules.
449e3a72
PG
326mtd/
327 - directory with info about memory technology devices (flash)
1da177e4
LT
328mono.txt
329 - how to execute Mono-based .NET binaries with the help of BINFMT_MISC.
f6b07d39
JJ
330mutex-design.txt
331 - info on the generic mutex subsystem.
2868f89f
PE
332namespaces/
333 - directory with various information about namespaces
8802f616
PM
334netlabel/
335 - directory with information on the NetLabel subsystem.
1da177e4
LT
336networking/
337 - directory with info on various aspects of networking with Linux.
449e3a72
PG
338nfc/
339 - directory relating info about Near Field Communications support.
f6b07d39
JJ
340nommu-mmap.txt
341 - documentation about no-mmu memory mapping support.
1da177e4
LT
342numastat.txt
343 - info on how to read Numa policy hit/miss statistics in sysfs.
344oops-tracing.txt
345 - how to decode those nasty internal kernel error dump messages.
4047f8b1
JC
346padata.txt
347 - An introduction to the "padata" parallel execution API
1da177e4
LT
348parisc/
349 - directory with info on using Linux on PA-RISC architecture.
350parport.txt
351 - how to use the parallel-port driver.
352parport-lowlevel.txt
353 - description and usage of the low level parallel port functions.
f6b07d39
JJ
354pcmcia/
355 - info on the Linux PCMCIA driver.
449e3a72
PG
356percpu-rw-semaphore.txt
357 - RCU based read-write semaphore optimized for locking for reading
3cf8ca1c
HA
358phy.txt
359 - Description of the generic PHY framework.
f6b07d39 360pi-futex.txt
449e3a72
PG
361 - documentation on lightweight priority inheritance futexes.
362pinctrl.txt
363 - info on pinctrl subsystem and the PINMUX/PINCONF and drivers
1da177e4
LT
364pnp.txt
365 - Linux Plug and Play documentation.
366power/
367 - directory with info on Linux PCI power management.
368powerpc/
369 - directory with info on using Linux with the PowerPC.
449e3a72
PG
370prctl/
371 - directory with info on the priveledge control subsystem
1da177e4
LT
372preempt-locking.txt
373 - info on locking under a preemptive kernel.
b67ad18b
RD
374printk-formats.txt
375 - how to get printk format specifiers right
449e3a72
PG
376pps/
377 - directory with information on the pulse-per-second support
378ptp/
379 - directory with info on support for IEEE 1588 PTP clocks in Linux.
380pwm.txt
381 - info on the pulse width modulation driver subsystem
4126dacb
SI
382ramoops.txt
383 - documentation of the ramoops oops/panic logging module.
449e3a72
PG
384rapidio/
385 - directory with info on RapidIO packet-based fabric interconnect
f6b07d39
JJ
386rbtree.txt
387 - info on what red-black trees are and what they are for.
449e3a72
PG
388remoteproc.txt
389 - info on how to handle remote processor (e.g. AMP) offloads/usage.
390rfkill.txt
391 - info on the radio frequency kill switch subsystem/support.
f6b07d39
JJ
392robust-futex-ABI.txt
393 - documentation of the robust futex ABI.
394robust-futexes.txt
395 - a description of what robust futexes are.
449e3a72
PG
396rpmsg.txt
397 - info on the Remote Processor Messaging (rpmsg) Framework
f6b07d39
JJ
398rt-mutex-design.txt
399 - description of the RealTime mutex implementation design.
400rt-mutex.txt
401 - desc. of RT-mutex subsystem with PI (Priority Inheritance) support.
1da177e4
LT
402rtc.txt
403 - notes on how to use the Real Time Clock (aka CMOS clock) driver.
404s390/
405 - directory with info on using Linux on the IBM S390.
9b8eae72
BF
406scheduler/
407 - directory with info on the scheduler.
1da177e4
LT
408scsi/
409 - directory with info on Linux scsi support.
d410fa4e
RD
410security/
411 - directory that contains security-related info
1da177e4
LT
412serial/
413 - directory with info on the low level serial API.
414serial-console.txt
415 - how to set up Linux with a serial line console as the default.
f6b07d39
JJ
416sgi-ioc4.txt
417 - description of the SGI IOC4 PCI (multi function) device.
1da177e4
LT
418sh/
419 - directory with info on porting Linux to a new architecture.
449e3a72
PG
420smsc_ece1099.txt
421 -info on the smsc Keyboard Scan Expansion/GPIO Expansion device.
1da177e4
LT
422sound/
423 - directory with info on sound card support.
f6b07d39
JJ
424sparse.txt
425 - info on how to obtain and use the sparse tool for typechecking.
f6b07d39
JJ
426spi/
427 - overview of Linux kernel Serial Peripheral Interface (SPI) support.
1da177e4
LT
428spinlocks.txt
429 - info on using spinlocks to provide exclusive access in kernel.
8907e94b
GKH
430stable_api_nonsense.txt
431 - info on why the kernel does not have a stable in-kernel api or abi.
432stable_kernel_rules.txt
433 - rules and procedures for the -stable kernel releases.
449e3a72
PG
434static-keys.txt
435 - info on how static keys allow debug code in hotpaths via patching
1da177e4
LT
436svga.txt
437 - short guide on selecting video modes at boot via VGA BIOS.
5ef43567
RL
438sysfs-rules.txt
439 - How not to use sysfs.
1da177e4
LT
440sysctl/
441 - directory with info on the /proc/sys/* files.
442sysrq.txt
443 - info on the magic SysRq key.
449e3a72
PG
444target/
445 - directory with info on generating TCM v4 fabric .ko modules
3cf8ca1c
HA
446this_cpu_ops.txt
447 - List rationale behind and the way to use this_cpu operations.
449e3a72
PG
448thermal/
449 - directory with information on managing thermal issues (CPU/temp)
450trace/
451 - directory with info on tracing technologies within linux
452unaligned-memory-access.txt
453 - info on how to avoid arch breaking unaligned memory access in code.
f6b07d39
JJ
454unicode.txt
455 - info on the Unicode character/font mapping used in Linux.
456unshare.txt
457 - description of the Linux unshare system call.
1da177e4
LT
458usb/
459 - directory with info regarding the Universal Serial Bus.
449e3a72
PG
460vDSO/
461 - directory with info regarding virtual dynamic shared objects
462vfio.txt
463 - info on Virtual Function I/O used in guest/hypervisor instances.
464vgaarbiter.txt
465 - info on enable/disable the legacy decoding on different VGA devices
f6b07d39
JJ
466video-output.txt
467 - sysfs class driver interface to enable/disable a video output device.
1da177e4
LT
468video4linux/
469 - directory with info regarding video/TV/radio cards and linux.
449e3a72
PG
470virtual/
471 - directory with information on the various linux virtualizations.
1da177e4
LT
472vm/
473 - directory with info on the Linux vm code.
449e3a72
PG
474vme_api.txt
475 - file relating info on the VME bus API in linux
5ef43567
RL
476volatile-considered-harmful.txt
477 - Why the "volatile" type class should not be used
f6b07d39
JJ
478w1/
479 - directory with documents regarding the 1-wire (w1) subsystem.
1da177e4
LT
480watchdog/
481 - how to auto-reboot Linux if it has "fallen and can't get up". ;-)
449e3a72
PG
482wimax/
483 - directory with info about Intel Wireless Wimax Connections
484workqueue.txt
485 - information on the Concurrency Managed Workqueue implementation
3cf8ca1c
HA
486ww-mutex-design.txt
487 - Intro to Mutex wait/would deadlock handling.s
71cced6e 488x86/x86_64/
1da177e4 489 - directory with info on Linux support for AMD x86-64 (Hammer) machines.
449e3a72
PG
490xtensa/
491 - directory with documents relating to arch/xtensa port/implementation
492xz.txt
493 - how to make use of the XZ data compression within linux kernel
494zh_CN/
495 - directory with Chinese translations of various documents
1da177e4
LT
496zorro.txt
497 - info on writing drivers for Zorro bus devices found on Amigas.
This page took 0.8096 seconds and 5 git commands to generate.