2 This is a brief list of all the files in ./linux/Documentation and what
3 they contain. If you add a documentation file, please list it here in
4 alphabetical order as well, or risk being hunted down like a rabid dog.
5 Please keep the descriptions small enough to fit on one line.
8 Following translations are available on the WWW:
10 - Japanese, maintained by the JF Project (jf@listserv.linux.or.jp), at
11 http://linuxjf.sourceforge.jp/
16 - info on kernel <-> userspace ABI and relative interface stability.
19 - brute force method of doing binary search of patches to find bug.
21 - list of changes that break older software packages.
23 - how the maintainers expect the C code in the kernel to look.
25 - DMA API, pci_ API & extensions for non-consistent memory machines.
27 - Dynamic DMA mapping Guide
29 - How to do DMA with ISA (and LPC) devices.
31 - listing of the various possible attributes a DMA region can have
33 - directory with DocBook templates etc. for kernel documentation.
35 - directory with info on customizing EDID for broken gfx/displays.
37 - the process and procedures of how to do Linux kernel development.
39 - info on Linux Intelligent Platform Management Interface (IPMI) Driver.
41 - how to select which CPU(s) handle which interrupt events on SMP.
43 - info on interrupt numbering and setting up IRQ domains.
45 - description of what an IRQ is.
47 - basic info on the Intel IOMMU virtualization support.
49 - some files in Documentation dir are actually sample code to build
51 - how to (attempt to) manage kernel hackers.
53 - directory with info on RCU (read-copy update).
55 - info on Secure Attention Keys.
57 - Silicon Motion SM501 multimedia companion chip
59 - procedure for reporting security bugs found in the kernel.
61 - Linux kernel patch submission checklist.
63 - procedure to get a new driver source included into the kernel tree.
65 - procedure to get a source patch included into the kernel tree.
67 - how to change your VGA cursor from a blinking underscore.
69 - documentation on accounting and taskstats.
71 - info on ACPI-specific hooks in the kernel.
73 - description of AoE (ATA over Ethernet) along with config examples.
75 - description of various trees and how to apply their patches.
77 - directory with info about Linux on the ARM architecture.
79 - directory with info about Linux on the 64 bit ARM architecture.
81 - semantics and behavior of atomic and bitmask operations.
83 - misc. LCD driver documentation (cfag12864b, ks0108).
85 - directory with info on controlling backlights in flat panel displays
87 - how to use kernel parameters to exclude bad RAM regions.
89 - basic instructions for those who wants to profile Linux kernel.
91 - info on the kernel support for extra binary formats.
93 - directory with documentation for the Blackfin arch.
95 - info on the Block I/O (BIO) layer.
97 - info on block devices & drivers
99 - info on how to use serial devices for Braille support.
101 - info on how to modify a bt8xx video card for GPIO usage.
103 - info on Marvell Bluetooth driver usage.
105 - directory with info on TI GPMC (General Purpose Memory Controller)
106 bus-virt-phys-mapping.txt
107 - how to access I/O mapped memory from within device drivers.
109 - describes the cache/TLB flushing interfaces Linux uses.
111 - directory with information on the CD-ROM drivers that Linux has.
113 - cgroups features, including cpusets and memory controller.
115 - how to make use of the existing circular buffer infrastructure
117 - info on the common clock framework
119 - info on how to get and use the Coccinelle code checking tool.
121 - docs on the netlink based userspace<->kernel space communication mod.
123 - documentation on Linux console drivers.
125 - info on CPU frequency and voltage scaling.
127 - document describing CPU hotplug support in the Linux kernel.
129 - document describing how CPU load statistics are collected.
131 - info on CPU_IDLE, CPU idle state management subsystem.
133 - documentation on how CPU topology info is exported via sysfs.
135 - brief tutorial on CRC computation
137 - directory with info about Linux on CRIS architecture.
139 - directory with info on the Crypto API.
141 - information on the Dell Systems Management Base Driver.
142 debugging-modules.txt
143 - some notes on debugging modules after Linux 2.6.3.
144 debugging-via-ohci1394.txt
145 - how to use firewire like a hardware debugger memory reader.
147 - document demonstrating the use of the Dell Remote BIOS Update driver.
149 - how to work with the mainline kernel development process.
151 - directory with info on Device Mapper.
153 - plain ASCII listing of all the nodes in /dev/ with major minor #'s.
155 - directory with info on device tree files used by OF/PowerPC/ARM
157 -info on the Digital Signature Verification API
159 - the DMA Buffer Sharing API Guide
161 -the DMA Engine API Guide
163 - file containing a list of files that should never be diff'ed.
165 - directory with info about Linux driver model.
167 - info on Linux Digital Video Broadcast (DVB) subsystem.
168 dynamic-debug-howto.txt
169 - how to use the dynamic debug (dyndbg) feature.
171 - info about initramfs, klibc, and userspace early during boot.
173 - information on EDAC - Error Detection And Correction
175 - info on EISA bus support.
177 - info on how to use e-mail to send un-mangled (git) patches.
179 - directory with porting guide for Android kernel switch driver.
181 - dir with docs about the fault injection capabilities infrastructure.
183 - directory with info on the frame buffer graphics abstraction layer.
185 - info on the vfs and the various filesystems that Linux supports.
187 - request_firmware() hotplug interface info.
189 - how to make use of flexible sized arrays in linux
191 - information about the FMC bus abstraction
193 - Fujitsu FR-V Linux documentation.
195 - info on requeueing of tasks from a non-PI futex to a PI futex
197 - use of GCC's coverage testing tool "gcov" with the Linux kernel
199 - overview of GPIO (General Purpose Input/Output) access conventions.
201 - directory with information on human interface devices
203 - notes on the change from 16 bit to 32 bit user/group IDs.
205 - hardware spinlock provides hardware assistance for synchronization
207 - info on the timer related topics
209 - info on Linux support for random number generator in i8xx chipsets.
211 - directory with docs on various hardware monitoring drivers.
213 - directory with info about the I2C bus/protocol (2 wire, kHz speed).
215 - directory with info about the Linux I2O subsystem.
217 - directory with info about Linux on Intel 32 bit architecture.
219 - directory with info about Linux on Intel 64 bit architecture.
221 - directory with documents concerning Linux InfiniBand support.
223 - what to do when the kernel can't find the 1st process to run.
225 - how to use the RAM disk as an initial/temporary root filesystem.
227 - info on Linux input device support.
229 - info on intel Trusted Execution Technology (intel TXT).
231 - description of io_mapping functions in linux/io-mapping.h
233 - info on ordering I/O writes to memory-mapped addresses.
235 - directory with documents describing various IOCTL calls.
237 - info on I/O statistics Linux kernel provides.
239 - how to use the irq-flags tracing feature.
241 - info on Linux ISA Plug & Play support.
243 - directory with info on the Linux ISDN support, and supported cards.
245 - info on the in-kernel binary support for Java(tm).
247 - directory with Japanese translations of various documents
249 - directory with info about the kernel build process.
251 - directory with mini HowTo on getting the crash dump code to work.
252 kernel-doc-nano-HOWTO.txt
253 - mini HowTo on generation and location of kernel documentation files.
255 - listing of various WWW + books that document kernel internals.
256 kernel-parameters.txt
257 - summary listing of command line / boot prompt args for the kernel.
259 - info on dynamic checker that detects uses of uninitialized memory.
261 - info on how to make use of the kernel memory leak detection system
263 - directory with Korean translations of various documents
265 - info of the kobject infrastructure of the Linux kernel.
267 - documents the kernel probes debugging feature.
269 - docs on adding reference counters (krefs) to kernel objects.
271 - directory with laptop related info and laptop driver documentation.
273 - a brief description of LDM (Windows Dynamic Disks).
275 - directory with info about LED handling under Linux.
277 - semantics and behavior of local atomic operations.
279 - documentation on the runtime locking correctness validator.
281 - info on collecting statistics on locks (and contention).
283 - info on soft and hard lockup detectors (aka nmi_watchdog).
285 - full colour GIF image of Linux logo (penguin - Tux).
287 - info on creator of above logo & site to get additional images from.
289 - directory with info about Linux on Motorola 68k architecture.
291 - list of magic numbers used to mark/protect kernel data structures.
293 - info on boot arguments for the multiple devices driver.
295 - info on media framework, its data structures, functions and usage.
297 - info on Linux kernel memory barriers.
299 - directory with info on parts like the Texas Instruments EMIF driver
301 - Hotpluggable memory support, how to use and current status.
303 - info on typical Linux memory problems.
305 - directory with info about Linux on Meta architecture.
307 - directory with info about Linux on MIPS architecture.
309 - directory with info about devices using the misc dev subsystem
311 - directory with info about the MMC subsystem
313 - directory with info about the mn10300 architecture port
315 - directory with info about memory technology devices (flash)
317 - how to execute Mono-based .NET binaries with the help of BINFMT_MISC.
319 - info on the generic mutex subsystem.
321 - directory with various information about namespaces
323 - directory with information on the NetLabel subsystem.
325 - directory with info on various aspects of networking with Linux.
327 - directory relating info about Near Field Communications support.
329 - documentation about no-mmu memory mapping support.
331 - info on how to read Numa policy hit/miss statistics in sysfs.
333 - how to decode those nasty internal kernel error dump messages.
335 - An introduction to the "padata" parallel execution API
337 - directory with info on using Linux on PA-RISC architecture.
339 - how to use the parallel-port driver.
341 - description and usage of the low level parallel port functions.
343 - info on the Linux PCMCIA driver.
344 percpu-rw-semaphore.txt
345 - RCU based read-write semaphore optimized for locking for reading
347 - documentation on lightweight priority inheritance futexes.
349 - info on pinctrl subsystem and the PINMUX/PINCONF and drivers
351 - Linux Plug and Play documentation.
353 - directory with info on Linux PCI power management.
355 - directory with info on using Linux with the PowerPC.
357 - directory with info on the priveledge control subsystem
359 - info on locking under a preemptive kernel.
361 - how to get printk format specifiers right
363 - directory with information on the pulse-per-second support
365 - directory with info on support for IEEE 1588 PTP clocks in Linux.
367 - info on the pulse width modulation driver subsystem
369 - documentation of the ramoops oops/panic logging module.
371 - directory with info on RapidIO packet-based fabric interconnect
373 - info on what red-black trees are and what they are for.
375 - info on how to handle remote processor (e.g. AMP) offloads/usage.
377 - info on the radio frequency kill switch subsystem/support.
379 - documentation of the robust futex ABI.
381 - a description of what robust futexes are.
383 - info on the Remote Processor Messaging (rpmsg) Framework
385 - description of the RealTime mutex implementation design.
387 - desc. of RT-mutex subsystem with PI (Priority Inheritance) support.
389 - notes on how to use the Real Time Clock (aka CMOS clock) driver.
391 - directory with info on using Linux on the IBM S390.
393 - directory with info on the scheduler.
395 - directory with info on Linux scsi support.
397 - directory that contains security-related info
399 - directory with info on the low level serial API.
401 - how to set up Linux with a serial line console as the default.
403 - description of the SGI IOC4 PCI (multi function) device.
405 - short blurb on the SGI Visual Workstations.
407 - directory with info on porting Linux to a new architecture.
409 -info on the smsc Keyboard Scan Expansion/GPIO Expansion device.
411 - directory with info on sound card support.
413 - info on how to obtain and use the sparse tool for typechecking.
415 - overview of Linux kernel Serial Peripheral Interface (SPI) support.
417 - info on using spinlocks to provide exclusive access in kernel.
418 stable_api_nonsense.txt
419 - info on why the kernel does not have a stable in-kernel api or abi.
420 stable_kernel_rules.txt
421 - rules and procedures for the -stable kernel releases.
423 - info on how static keys allow debug code in hotpaths via patching
425 - short guide on selecting video modes at boot via VGA BIOS.
427 - How not to use sysfs.
429 - directory with info on the /proc/sys/* files.
431 - info on the magic SysRq key.
433 - directory with info on generating TCM v4 fabric .ko modules
435 - directory with information on managing thermal issues (CPU/temp)
437 - directory with info on tracing technologies within linux
438 unaligned-memory-access.txt
439 - info on how to avoid arch breaking unaligned memory access in code.
441 - info on the Unicode character/font mapping used in Linux.
443 - description of the Linux unshare system call.
445 - directory with info regarding the Universal Serial Bus.
447 - directory with info regarding virtual dynamic shared objects
449 - info on Virtual Function I/O used in guest/hypervisor instances.
451 - info on enable/disable the legacy decoding on different VGA devices
453 - sysfs class driver interface to enable/disable a video output device.
455 - directory with info regarding video/TV/radio cards and linux.
457 - directory with information on the various linux virtualizations.
459 - directory with info on the Linux vm code.
461 - file relating info on the VME bus API in linux
462 volatile-considered-harmful.txt
463 - Why the "volatile" type class should not be used
465 - directory with documents regarding the 1-wire (w1) subsystem.
467 - how to auto-reboot Linux if it has "fallen and can't get up". ;-)
469 - directory with info about Intel Wireless Wimax Connections
471 - information on the Concurrency Managed Workqueue implementation
473 - directory with info on Linux support for AMD x86-64 (Hammer) machines.
475 - directory with documents relating to arch/xtensa port/implementation
477 - how to make use of the XZ data compression within linux kernel
479 - directory with Chinese translations of various documents
481 - info on writing drivers for Zorro bus devices found on Amigas.