00-INDEX 16.8 KB
Newer Older
Linus Torvalds's avatar
Linus Torvalds committed
1 2 3 4

This is a brief list of all the files in ./linux/Documentation and what
they contain. If you add a documentation file, please list it here in
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.
Linus Torvalds's avatar
Linus Torvalds committed
6 7 8 9
							 Thanks -- Paul G.

Following translations are available on the WWW:

10 11
   - Japanese, maintained by the JF Project (jf@listserv.linux.or.jp), at
     http://linuxjf.sourceforge.jp/
Linus Torvalds's avatar
Linus Torvalds committed
12 13 14

00-INDEX
	- this file.
15 16
ABI/
	- info on kernel <-> userspace ABI and relative interface stability.
17

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