00-INDEX 17 KB

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