00-INDEX 17 KB

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