00-INDEX 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481
  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. fmc/
  186. - information about the FMC bus abstraction
  187. frv/
  188. - Fujitsu FR-V Linux documentation.
  189. futex-requeue-pi.txt
  190. - info on requeueing of tasks from a non-PI futex to a PI futex
  191. gcov.txt
  192. - use of GCC's coverage testing tool "gcov" with the Linux kernel
  193. gpio.txt
  194. - overview of GPIO (General Purpose Input/Output) access conventions.
  195. hid/
  196. - directory with information on human interface devices
  197. highuid.txt
  198. - notes on the change from 16 bit to 32 bit user/group IDs.
  199. hwspinlock.txt
  200. - hardware spinlock provides hardware assistance for synchronization
  201. timers/
  202. - info on the timer related topics
  203. hw_random.txt
  204. - info on Linux support for random number generator in i8xx chipsets.
  205. hwmon/
  206. - directory with docs on various hardware monitoring drivers.
  207. i2c/
  208. - directory with info about the I2C bus/protocol (2 wire, kHz speed).
  209. i2o/
  210. - directory with info about the Linux I2O subsystem.
  211. x86/i386/
  212. - directory with info about Linux on Intel 32 bit architecture.
  213. ia64/
  214. - directory with info about Linux on Intel 64 bit architecture.
  215. infiniband/
  216. - directory with documents concerning Linux InfiniBand support.
  217. init.txt
  218. - what to do when the kernel can't find the 1st process to run.
  219. initrd.txt
  220. - how to use the RAM disk as an initial/temporary root filesystem.
  221. input/
  222. - info on Linux input device support.
  223. intel_txt.txt
  224. - info on intel Trusted Execution Technology (intel TXT).
  225. io-mapping.txt
  226. - description of io_mapping functions in linux/io-mapping.h
  227. io_ordering.txt
  228. - info on ordering I/O writes to memory-mapped addresses.
  229. ioctl/
  230. - directory with documents describing various IOCTL calls.
  231. iostats.txt
  232. - info on I/O statistics Linux kernel provides.
  233. irqflags-tracing.txt
  234. - how to use the irq-flags tracing feature.
  235. isapnp.txt
  236. - info on Linux ISA Plug & Play support.
  237. isdn/
  238. - directory with info on the Linux ISDN support, and supported cards.
  239. java.txt
  240. - info on the in-kernel binary support for Java(tm).
  241. ja_JP/
  242. - directory with Japanese translations of various documents
  243. kbuild/
  244. - directory with info about the kernel build process.
  245. kdump/
  246. - directory with mini HowTo on getting the crash dump code to work.
  247. kernel-doc-nano-HOWTO.txt
  248. - mini HowTo on generation and location of kernel documentation files.
  249. kernel-docs.txt
  250. - listing of various WWW + books that document kernel internals.
  251. kernel-parameters.txt
  252. - summary listing of command line / boot prompt args for the kernel.
  253. kmemcheck.txt
  254. - info on dynamic checker that detects uses of uninitialized memory.
  255. kmemleak.txt
  256. - info on how to make use of the kernel memory leak detection system
  257. ko_KR/
  258. - directory with Korean translations of various documents
  259. kobject.txt
  260. - info of the kobject infrastructure of the Linux kernel.
  261. kprobes.txt
  262. - documents the kernel probes debugging feature.
  263. kref.txt
  264. - docs on adding reference counters (krefs) to kernel objects.
  265. laptops/
  266. - directory with laptop related info and laptop driver documentation.
  267. ldm.txt
  268. - a brief description of LDM (Windows Dynamic Disks).
  269. leds/
  270. - directory with info about LED handling under Linux.
  271. local_ops.txt
  272. - semantics and behavior of local atomic operations.
  273. lockdep-design.txt
  274. - documentation on the runtime locking correctness validator.
  275. lockstat.txt
  276. - info on collecting statistics on locks (and contention).
  277. lockup-watchdogs.txt
  278. - info on soft and hard lockup detectors (aka nmi_watchdog).
  279. logo.gif
  280. - full colour GIF image of Linux logo (penguin - Tux).
  281. logo.txt
  282. - info on creator of above logo & site to get additional images from.
  283. m68k/
  284. - directory with info about Linux on Motorola 68k architecture.
  285. magic-number.txt
  286. - list of magic numbers used to mark/protect kernel data structures.
  287. md.txt
  288. - info on boot arguments for the multiple devices driver.
  289. media-framework.txt
  290. - info on media framework, its data structures, functions and usage.
  291. memory-barriers.txt
  292. - info on Linux kernel memory barriers.
  293. memory-devices/
  294. - directory with info on parts like the Texas Instruments EMIF driver
  295. memory-hotplug.txt
  296. - Hotpluggable memory support, how to use and current status.
  297. memory.txt
  298. - info on typical Linux memory problems.
  299. metag/
  300. - directory with info about Linux on Meta architecture.
  301. mips/
  302. - directory with info about Linux on MIPS architecture.
  303. misc-devices/
  304. - directory with info about devices using the misc dev subsystem
  305. mmc/
  306. - directory with info about the MMC subsystem
  307. mn10300/
  308. - directory with info about the mn10300 architecture port
  309. mtd/
  310. - directory with info about memory technology devices (flash)
  311. mono.txt
  312. - how to execute Mono-based .NET binaries with the help of BINFMT_MISC.
  313. mutex-design.txt
  314. - info on the generic mutex subsystem.
  315. namespaces/
  316. - directory with various information about namespaces
  317. netlabel/
  318. - directory with information on the NetLabel subsystem.
  319. networking/
  320. - directory with info on various aspects of networking with Linux.
  321. nfc/
  322. - directory relating info about Near Field Communications support.
  323. nommu-mmap.txt
  324. - documentation about no-mmu memory mapping support.
  325. numastat.txt
  326. - info on how to read Numa policy hit/miss statistics in sysfs.
  327. oops-tracing.txt
  328. - how to decode those nasty internal kernel error dump messages.
  329. padata.txt
  330. - An introduction to the "padata" parallel execution API
  331. parisc/
  332. - directory with info on using Linux on PA-RISC architecture.
  333. parport.txt
  334. - how to use the parallel-port driver.
  335. parport-lowlevel.txt
  336. - description and usage of the low level parallel port functions.
  337. pcmcia/
  338. - info on the Linux PCMCIA driver.
  339. percpu-rw-semaphore.txt
  340. - RCU based read-write semaphore optimized for locking for reading
  341. pi-futex.txt
  342. - documentation on lightweight priority inheritance futexes.
  343. pinctrl.txt
  344. - info on pinctrl subsystem and the PINMUX/PINCONF and drivers
  345. pnp.txt
  346. - Linux Plug and Play documentation.
  347. power/
  348. - directory with info on Linux PCI power management.
  349. powerpc/
  350. - directory with info on using Linux with the PowerPC.
  351. prctl/
  352. - directory with info on the priveledge control subsystem
  353. preempt-locking.txt
  354. - info on locking under a preemptive kernel.
  355. printk-formats.txt
  356. - how to get printk format specifiers right
  357. pps/
  358. - directory with information on the pulse-per-second support
  359. ptp/
  360. - directory with info on support for IEEE 1588 PTP clocks in Linux.
  361. pwm.txt
  362. - info on the pulse width modulation driver subsystem
  363. ramoops.txt
  364. - documentation of the ramoops oops/panic logging module.
  365. rapidio/
  366. - directory with info on RapidIO packet-based fabric interconnect
  367. rbtree.txt
  368. - info on what red-black trees are and what they are for.
  369. remoteproc.txt
  370. - info on how to handle remote processor (e.g. AMP) offloads/usage.
  371. rfkill.txt
  372. - info on the radio frequency kill switch subsystem/support.
  373. robust-futex-ABI.txt
  374. - documentation of the robust futex ABI.
  375. robust-futexes.txt
  376. - a description of what robust futexes are.
  377. rpmsg.txt
  378. - info on the Remote Processor Messaging (rpmsg) Framework
  379. rt-mutex-design.txt
  380. - description of the RealTime mutex implementation design.
  381. rt-mutex.txt
  382. - desc. of RT-mutex subsystem with PI (Priority Inheritance) support.
  383. rtc.txt
  384. - notes on how to use the Real Time Clock (aka CMOS clock) driver.
  385. s390/
  386. - directory with info on using Linux on the IBM S390.
  387. scheduler/
  388. - directory with info on the scheduler.
  389. scsi/
  390. - directory with info on Linux scsi support.
  391. security/
  392. - directory that contains security-related info
  393. serial/
  394. - directory with info on the low level serial API.
  395. serial-console.txt
  396. - how to set up Linux with a serial line console as the default.
  397. sgi-ioc4.txt
  398. - description of the SGI IOC4 PCI (multi function) device.
  399. sgi-visws.txt
  400. - short blurb on the SGI Visual Workstations.
  401. sh/
  402. - directory with info on porting Linux to a new architecture.
  403. smsc_ece1099.txt
  404. -info on the smsc Keyboard Scan Expansion/GPIO Expansion device.
  405. sound/
  406. - directory with info on sound card support.
  407. sparse.txt
  408. - info on how to obtain and use the sparse tool for typechecking.
  409. spi/
  410. - overview of Linux kernel Serial Peripheral Interface (SPI) support.
  411. spinlocks.txt
  412. - info on using spinlocks to provide exclusive access in kernel.
  413. stable_api_nonsense.txt
  414. - info on why the kernel does not have a stable in-kernel api or abi.
  415. stable_kernel_rules.txt
  416. - rules and procedures for the -stable kernel releases.
  417. static-keys.txt
  418. - info on how static keys allow debug code in hotpaths via patching
  419. svga.txt
  420. - short guide on selecting video modes at boot via VGA BIOS.
  421. sysfs-rules.txt
  422. - How not to use sysfs.
  423. sysctl/
  424. - directory with info on the /proc/sys/* files.
  425. sysrq.txt
  426. - info on the magic SysRq key.
  427. target/
  428. - directory with info on generating TCM v4 fabric .ko modules
  429. thermal/
  430. - directory with information on managing thermal issues (CPU/temp)
  431. trace/
  432. - directory with info on tracing technologies within linux
  433. unaligned-memory-access.txt
  434. - info on how to avoid arch breaking unaligned memory access in code.
  435. unicode.txt
  436. - info on the Unicode character/font mapping used in Linux.
  437. unshare.txt
  438. - description of the Linux unshare system call.
  439. usb/
  440. - directory with info regarding the Universal Serial Bus.
  441. vDSO/
  442. - directory with info regarding virtual dynamic shared objects
  443. vfio.txt
  444. - info on Virtual Function I/O used in guest/hypervisor instances.
  445. vgaarbiter.txt
  446. - info on enable/disable the legacy decoding on different VGA devices
  447. video-output.txt
  448. - sysfs class driver interface to enable/disable a video output device.
  449. video4linux/
  450. - directory with info regarding video/TV/radio cards and linux.
  451. virtual/
  452. - directory with information on the various linux virtualizations.
  453. vm/
  454. - directory with info on the Linux vm code.
  455. vme_api.txt
  456. - file relating info on the VME bus API in linux
  457. volatile-considered-harmful.txt
  458. - Why the "volatile" type class should not be used
  459. w1/
  460. - directory with documents regarding the 1-wire (w1) subsystem.
  461. watchdog/
  462. - how to auto-reboot Linux if it has "fallen and can't get up". ;-)
  463. wimax/
  464. - directory with info about Intel Wireless Wimax Connections
  465. workqueue.txt
  466. - information on the Concurrency Managed Workqueue implementation
  467. x86/x86_64/
  468. - directory with info on Linux support for AMD x86-64 (Hammer) machines.
  469. xtensa/
  470. - directory with documents relating to arch/xtensa port/implementation
  471. xz.txt
  472. - how to make use of the XZ data compression within linux kernel
  473. zh_CN/
  474. - directory with Chinese translations of various documents
  475. zorro.txt
  476. - info on writing drivers for Zorro bus devices found on Amigas.