Mauro Carvalho Chehab | dc7a12b | 2019-04-14 15:51:10 -0300 | [diff] [blame] | 1 | |
Jani Nikula | 22cba31 | 2016-05-19 15:14:05 +0300 | [diff] [blame] | 2 | .. The Linux Kernel documentation master file, created by |
| 3 | sphinx-quickstart on Fri Feb 12 13:51:46 2016. |
| 4 | You can adapt this file completely to your liking, but it should at least |
| 5 | contain the root `toctree` directive. |
| 6 | |
Federico Vaga | aa586e2 | 2018-06-06 00:49:01 +0200 | [diff] [blame] | 7 | .. _linux_doc: |
| 8 | |
Konstantin Ryabitsev | 61ca5fd | 2017-06-06 16:50:04 -0400 | [diff] [blame] | 9 | The Linux Kernel documentation |
| 10 | ============================== |
Jani Nikula | 22cba31 | 2016-05-19 15:14:05 +0300 | [diff] [blame] | 11 | |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 12 | This is the top level of the kernel's documentation tree. Kernel |
| 13 | documentation, like the kernel itself, is very much a work in progress; |
| 14 | that is especially true as we work to integrate our many scattered |
| 15 | documents into a coherent whole. Please note that improvements to the |
| 16 | documentation are welcome; join the linux-doc list at vger.kernel.org if |
| 17 | you want to help out. |
| 18 | |
Thomas Gleixner | aa19a17 | 2017-12-28 23:17:17 +0100 | [diff] [blame] | 19 | Licensing documentation |
| 20 | ----------------------- |
| 21 | |
| 22 | The following describes the license of the Linux kernel source code |
| 23 | (GPLv2), how to properly mark the license of individual files in the source |
| 24 | tree, as well as links to the full license text. |
| 25 | |
Markus Heiser | 9799445 | 2018-08-14 13:43:12 +0200 | [diff] [blame] | 26 | * :ref:`kernel_licensing` |
Thomas Gleixner | aa19a17 | 2017-12-28 23:17:17 +0100 | [diff] [blame] | 27 | |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 28 | User-oriented documentation |
| 29 | --------------------------- |
| 30 | |
| 31 | The following manuals are written for *users* of the kernel — those who are |
| 32 | trying to get it to work optimally on a given system. |
Jani Nikula | 22cba31 | 2016-05-19 15:14:05 +0300 | [diff] [blame] | 33 | |
| 34 | .. toctree:: |
| 35 | :maxdepth: 2 |
| 36 | |
Mauro Carvalho Chehab | 9d85025 | 2016-09-21 09:51:11 -0300 | [diff] [blame] | 37 | admin-guide/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 38 | kbuild/index |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 39 | |
Changbin Du | 680e6ff | 2019-04-25 23:30:54 +0800 | [diff] [blame] | 40 | Firmware-related documentation |
| 41 | ------------------------------ |
| 42 | The following holds information on the kernel's expectations regarding the |
| 43 | platform firmwares. |
| 44 | |
| 45 | .. toctree:: |
| 46 | :maxdepth: 2 |
| 47 | |
| 48 | firmware-guide/index |
| 49 | |
Jonathan Corbet | 1d596de | 2017-04-02 14:58:01 -0600 | [diff] [blame] | 50 | Application-developer documentation |
| 51 | ----------------------------------- |
| 52 | |
| 53 | The user-space API manual gathers together documents describing aspects of |
| 54 | the kernel interface as seen by application developers. |
| 55 | |
| 56 | .. toctree:: |
| 57 | :maxdepth: 2 |
| 58 | |
Mike Rapoport | 8238191 | 2018-03-21 21:22:48 +0200 | [diff] [blame] | 59 | userspace-api/index |
Jonathan Corbet | 1d596de | 2017-04-02 14:58:01 -0600 | [diff] [blame] | 60 | |
| 61 | |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 62 | Introduction to kernel development |
| 63 | ---------------------------------- |
| 64 | |
| 65 | These manuals contain overall information about how to develop the kernel. |
| 66 | The kernel community is quite large, with thousands of developers |
| 67 | contributing over the course of a year. As with any large community, |
| 68 | knowing how things are done will make the process of getting your changes |
| 69 | merged much easier. |
| 70 | |
| 71 | .. toctree:: |
| 72 | :maxdepth: 2 |
| 73 | |
Mauro Carvalho Chehab | 0e4f07a | 2016-10-18 09:05:32 -0200 | [diff] [blame] | 74 | process/index |
Markus Heiser | c289312 | 2016-10-26 08:23:14 +0200 | [diff] [blame] | 75 | dev-tools/index |
Mauro Carvalho Chehab | 1dc4bbf | 2016-11-17 08:32:33 -0200 | [diff] [blame] | 76 | doc-guide/index |
Mauro Carvalho Chehab | c4fcd7c | 2017-05-11 08:03:27 -0300 | [diff] [blame] | 77 | kernel-hacking/index |
Changbin Du | 583bc6b | 2018-02-17 13:39:34 +0800 | [diff] [blame] | 78 | trace/index |
Tobin C. Harding | 9727a01 | 2017-12-04 10:27:29 +1100 | [diff] [blame] | 79 | maintainer/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 80 | fault-injection/index |
| 81 | livepatch/index |
| 82 | |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 83 | |
| 84 | Kernel API documentation |
| 85 | ------------------------ |
| 86 | |
| 87 | These books get into the details of how specific kernel subsystems work |
| 88 | from the point of view of a kernel developer. Much of the information here |
| 89 | is taken directly from the kernel source, with supplemental material added |
| 90 | as needed (or at least as we managed to add it — probably *not* all that is |
Andy Deng | 2069889 | 2017-01-25 12:14:33 +0800 | [diff] [blame] | 91 | needed). |
Jonathan Corbet | b51208d | 2016-10-26 15:43:00 -0600 | [diff] [blame] | 92 | |
| 93 | .. toctree:: |
| 94 | :maxdepth: 2 |
| 95 | |
Jonathan Corbet | dcec3c8 | 2016-08-20 13:17:32 -0600 | [diff] [blame] | 96 | driver-api/index |
Silvio Fricke | 24755a5 | 2016-10-28 10:14:10 +0200 | [diff] [blame] | 97 | core-api/index |
Mauro Carvalho Chehab | 4c68060 | 2019-06-28 07:29:15 -0300 | [diff] [blame] | 98 | locking/index |
Mauro Carvalho Chehab | df1b7ce | 2019-06-18 17:16:23 -0300 | [diff] [blame] | 99 | accounting/index |
| 100 | block/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 101 | cdrom/index |
Mauro Carvalho Chehab | 12bd112 | 2020-03-03 14:52:03 +0100 | [diff] [blame] | 102 | cpu-freq/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 103 | ide/index |
| 104 | fb/index |
| 105 | fpga/index |
Mauro Carvalho Chehab | df1b7ce | 2019-06-18 17:16:23 -0300 | [diff] [blame] | 106 | hid/index |
Mauro Carvalho Chehab | ccf988b | 2019-07-26 09:51:16 -0300 | [diff] [blame] | 107 | i2c/index |
Mauro Carvalho Chehab | df1b7ce | 2019-06-18 17:16:23 -0300 | [diff] [blame] | 108 | iio/index |
Mauro Carvalho Chehab | 5a5e045 | 2019-07-26 09:51:25 -0300 | [diff] [blame] | 109 | isdn/index |
Mauro Carvalho Chehab | a3a400d | 2019-06-28 09:30:28 -0300 | [diff] [blame] | 110 | infiniband/index |
Mauro Carvalho Chehab | 09fdc95 | 2019-06-18 16:51:34 -0300 | [diff] [blame] | 111 | leds/index |
Markus Heiser | b32feba | 2016-08-13 16:12:43 +0200 | [diff] [blame] | 112 | media/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 113 | netlabel/index |
Mauro Carvalho Chehab | 05e0f3b | 2017-05-12 09:14:02 -0300 | [diff] [blame] | 114 | networking/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 115 | pcmcia/index |
Mauro Carvalho Chehab | 08a6905 | 2019-07-15 09:39:57 -0300 | [diff] [blame] | 116 | power/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 117 | target/index |
| 118 | timers/index |
Mauro Carvalho Chehab | 9cdd273 | 2019-07-31 17:08:50 -0300 | [diff] [blame] | 119 | spi/index |
Mauro Carvalho Chehab | e9bb627 | 2019-07-31 17:08:53 -0300 | [diff] [blame] | 120 | w1/index |
Mauro Carvalho Chehab | 113094f | 2019-06-28 08:36:50 -0300 | [diff] [blame] | 121 | watchdog/index |
Sheriff Esseson | 03d3652 | 2019-08-09 14:23:49 +0100 | [diff] [blame] | 122 | virt/index |
Mauro Carvalho Chehab | aeb899a | 2017-04-11 07:01:19 -0300 | [diff] [blame] | 123 | input/index |
Mauro Carvalho Chehab | 7ebd8b66 | 2019-04-17 06:46:29 -0300 | [diff] [blame] | 124 | hwmon/index |
Jani Nikula | cb597fc | 2016-06-21 14:48:57 +0300 | [diff] [blame] | 125 | gpu/index |
Jarkko Sakkinen | 799a545 | 2016-11-03 17:57:52 -0600 | [diff] [blame] | 126 | security/index |
Takashi Iwai | 8551914 | 2016-11-02 21:30:39 +0100 | [diff] [blame] | 127 | sound/index |
Stephan Mueller | 3b72c81 | 2016-10-21 04:54:22 +0200 | [diff] [blame] | 128 | crypto/index |
Mauro Carvalho Chehab | 90f9f11 | 2017-05-12 06:50:22 -0300 | [diff] [blame] | 129 | filesystems/index |
Mike Rapoport | 8238191 | 2018-03-21 21:22:48 +0200 | [diff] [blame] | 130 | vm/index |
Tobin C. Harding | 3209570 | 2018-07-26 15:03:04 +1000 | [diff] [blame] | 131 | bpf/index |
Mauro Carvalho Chehab | ecefae6 | 2019-06-18 18:05:38 -0300 | [diff] [blame] | 132 | usb/index |
Changbin Du | c42eaff | 2019-05-14 22:47:23 +0800 | [diff] [blame] | 133 | PCI/index |
Mauro Carvalho Chehab | 31df2fd | 2020-03-02 09:15:34 +0100 | [diff] [blame] | 134 | scsi/index |
Randy Dunlap | 5591a30 | 2019-01-13 19:21:46 -0800 | [diff] [blame] | 135 | misc-devices/index |
Mauro Carvalho Chehab | c92992f | 2019-04-22 16:49:11 -0300 | [diff] [blame] | 136 | scheduler/index |
Manivannan Sadhasivam | 9435dc3 | 2020-02-20 15:28:39 +0530 | [diff] [blame] | 137 | mhi/index |
Jani Nikula | 22cba31 | 2016-05-19 15:14:05 +0300 | [diff] [blame] | 138 | |
Jiri Slaby | ffedeeb | 2019-10-11 13:50:41 +0200 | [diff] [blame] | 139 | Architecture-agnostic documentation |
| 140 | ----------------------------------- |
| 141 | |
| 142 | .. toctree:: |
| 143 | :maxdepth: 2 |
| 144 | |
| 145 | asm-annotations |
| 146 | |
Mauro Carvalho Chehab | bffac83 | 2017-05-13 07:50:43 -0300 | [diff] [blame] | 147 | Architecture-specific documentation |
| 148 | ----------------------------------- |
| 149 | |
| 150 | These books provide programming details about architecture-specific |
| 151 | implementation. |
| 152 | |
| 153 | .. toctree:: |
| 154 | :maxdepth: 2 |
| 155 | |
Mauro Carvalho Chehab | 159a5e7 | 2019-04-22 16:10:26 -0300 | [diff] [blame] | 156 | arm/index |
| 157 | arm64/index |
| 158 | ia64/index |
| 159 | m68k/index |
Mauro Carvalho Chehab | 80b1505 | 2019-07-26 09:51:31 -0300 | [diff] [blame] | 160 | mips/index |
Mauro Carvalho Chehab | 47359e5 | 2019-07-26 09:51:33 -0300 | [diff] [blame] | 161 | nios2/nios2 |
Mauro Carvalho Chehab | 32fc3cd | 2019-07-26 09:51:24 -0300 | [diff] [blame] | 162 | openrisc/index |
Mauro Carvalho Chehab | e77e918 | 2019-07-26 09:51:23 -0300 | [diff] [blame] | 163 | parisc/index |
Linus Torvalds | 5c6bd5d | 2019-09-22 09:30:30 -0700 | [diff] [blame] | 164 | powerpc/index |
Mauro Carvalho Chehab | 159a5e7 | 2019-04-22 16:10:26 -0300 | [diff] [blame] | 165 | riscv/index |
| 166 | s390/index |
| 167 | sh/index |
| 168 | sparc/index |
Thomas Gleixner | 6a9e529 | 2019-02-18 23:13:06 +0100 | [diff] [blame] | 169 | x86/index |
Mauro Carvalho Chehab | 159a5e7 | 2019-04-22 16:10:26 -0300 | [diff] [blame] | 170 | xtensa/index |
Mauro Carvalho Chehab | bffac83 | 2017-05-13 07:50:43 -0300 | [diff] [blame] | 171 | |
Darrick J. Wong | 6684874 | 2018-07-29 16:14:02 -0400 | [diff] [blame] | 172 | Filesystem Documentation |
| 173 | ------------------------ |
| 174 | |
| 175 | The documentation in this section are provided by specific filesystem |
| 176 | subprojects. |
| 177 | |
| 178 | .. toctree:: |
Theodore Ts'o | 0694f8c | 2018-07-29 16:35:23 -0400 | [diff] [blame] | 179 | :maxdepth: 2 |
Darrick J. Wong | 6684874 | 2018-07-29 16:14:02 -0400 | [diff] [blame] | 180 | |
| 181 | filesystems/ext4/index |
| 182 | |
Federico Vaga | 85c32d9 | 2018-06-06 00:49:00 +0200 | [diff] [blame] | 183 | Translations |
| 184 | ------------ |
SeongJae Park | ba42c57 | 2016-11-08 21:26:09 +0900 | [diff] [blame] | 185 | |
| 186 | .. toctree:: |
Federico Vaga | 85c32d9 | 2018-06-06 00:49:00 +0200 | [diff] [blame] | 187 | :maxdepth: 2 |
SeongJae Park | ba42c57 | 2016-11-08 21:26:09 +0900 | [diff] [blame] | 188 | |
Federico Vaga | 85c32d9 | 2018-06-06 00:49:00 +0200 | [diff] [blame] | 189 | translations/index |
Tsugikazu Shibata | f012733 | 2017-04-08 12:24:04 +0200 | [diff] [blame] | 190 | |
Jani Nikula | 22cba31 | 2016-05-19 15:14:05 +0300 | [diff] [blame] | 191 | Indices and tables |
| 192 | ================== |
| 193 | |
| 194 | * :ref:`genindex` |