|  | .. _kernel_docs: | 
|  |  | 
|  | Index of Further Kernel Documentation | 
|  | ===================================== | 
|  |  | 
|  | The need for a document like this one became apparent in the linux-kernel | 
|  | mailing list as the same questions, asking for pointers to information, | 
|  | appeared again and again. | 
|  |  | 
|  | Fortunately, as more and more people get to GNU/Linux, more and more get | 
|  | interested in the Kernel. But reading the sources is not always enough. It | 
|  | is easy to understand the code, but miss the concepts, the philosophy and | 
|  | design decisions behind this code. | 
|  |  | 
|  | Unfortunately, not many documents are available for beginners to start. | 
|  | And, even if they exist, there was no "well-known" place which kept track | 
|  | of them. These lines try to cover this lack. | 
|  |  | 
|  | PLEASE, if you know any paper not listed here or write a new document, | 
|  | include a reference to it here, following the kernel's patch submission | 
|  | process. Any corrections, ideas or comments are also welcome. | 
|  |  | 
|  | All documents are cataloged with the following fields: the document's | 
|  | "Title", the "Author"/s, the "URL" where they can be found, some "Keywords" | 
|  | helpful when searching for specific topics, and a brief "Description" of | 
|  | the Document. | 
|  |  | 
|  | .. note:: | 
|  |  | 
|  | The documents on each section of this document are ordered by its | 
|  | published date, from the newest to the oldest. The maintainer(s) should | 
|  | periodically retire resources as they become obsolete or outdated; with | 
|  | the exception of foundational books. | 
|  |  | 
|  | Docs at the Linux Kernel tree | 
|  | ----------------------------- | 
|  |  | 
|  | The Sphinx books should be built with ``make {htmldocs | pdfdocs | epubdocs}``. | 
|  |  | 
|  | * Name: **linux/Documentation** | 
|  |  | 
|  | :Author: Many. | 
|  | :Location: Documentation/ | 
|  | :Keywords: text files, Sphinx. | 
|  | :Description: Documentation that comes with the kernel sources, | 
|  | inside the Documentation directory. Some pages from this document | 
|  | (including this document itself) have been moved there, and might | 
|  | be more up to date than the web version. | 
|  |  | 
|  | On-line docs | 
|  | ------------ | 
|  |  | 
|  | * Title: **Linux Kernel Mailing List Glossary** | 
|  |  | 
|  | :Author: various | 
|  | :URL: https://kernelnewbies.org/KernelGlossary | 
|  | :Date: rolling version | 
|  | :Keywords: glossary, terms, linux-kernel. | 
|  | :Description: From the introduction: "This glossary is intended as | 
|  | a brief description of some of the acronyms and terms you may hear | 
|  | during discussion of the Linux kernel". | 
|  |  | 
|  | * Title: **The Linux Kernel Module Programming Guide** | 
|  |  | 
|  | :Author: Peter Jay Salzman, Michael Burian, Ori Pomerantz, Bob Mottram, | 
|  | Jim Huang. | 
|  | :URL: https://sysprog21.github.io/lkmpg/ | 
|  | :Date: 2021 | 
|  | :Keywords: modules, GPL book, /proc, ioctls, system calls, | 
|  | interrupt handlers . | 
|  | :Description: A very nice GPL book on the topic of modules | 
|  | programming. Lots of examples. Currently the new version is being | 
|  | actively maintained at https://github.com/sysprog21/lkmpg. | 
|  |  | 
|  | * Title: **Rust for Linux** | 
|  |  | 
|  | :Author: various | 
|  | :URL: https://rust-for-linux.com/ | 
|  | :Date: rolling version | 
|  | :Keywords: glossary, terms, linux-kernel. | 
|  | :Description: From the website: "Rust for Linux is the project adding | 
|  | support for the Rust language to the Linux kernel. This website is | 
|  | intended as a hub of links, documentation and resources related to | 
|  | the project". | 
|  |  | 
|  | Published books | 
|  | --------------- | 
|  |  | 
|  | * Title: **Practical Linux System Administration: A Guide to Installation, Configuration, and Management, 1st Edition** | 
|  |  | 
|  | :Author: Kenneth Hess | 
|  | :Publisher: O'Reilly Media | 
|  | :Date: May, 2023 | 
|  | :Pages: 246 | 
|  | :ISBN: 978-1098109035 | 
|  | :Notes: System administration | 
|  |  | 
|  | * Title: **Linux Kernel Debugging: Leverage proven tools and advanced techniques to effectively debug Linux kernels and kernel modules** | 
|  |  | 
|  | :Author: Kaiwan N Billimoria | 
|  | :Publisher: Packt Publishing Ltd | 
|  | :Date: August, 2022 | 
|  | :Pages: 638 | 
|  | :ISBN: 978-1801075039 | 
|  | :Notes: Debugging book | 
|  |  | 
|  | * Title: **Linux Kernel Programming: A Comprehensive Guide to Kernel Internals, Writing Kernel Modules, and Kernel Synchronization** | 
|  |  | 
|  | :Author: Kaiwan N Billimoria | 
|  | :Publisher: Packt Publishing Ltd | 
|  | :Date: March, 2021 (Second Edition published in 2024) | 
|  | :Pages: 754 | 
|  | :ISBN: 978-1789953435 (Second Edition ISBN is 978-1803232225) | 
|  |  | 
|  | * Title: **Linux Kernel Programming Part 2 - Char Device Drivers and Kernel Synchronization: Create user-kernel interfaces, work with peripheral I/O, and handle hardware interrupts** | 
|  |  | 
|  | :Author: Kaiwan N Billimoria | 
|  | :Publisher: Packt Publishing Ltd | 
|  | :Date: March, 2021 | 
|  | :Pages: 452 | 
|  | :ISBN: 978-1801079518 | 
|  |  | 
|  | * Title: **Linux System Programming: Talking Directly to the Kernel and C Library** | 
|  |  | 
|  | :Author: Robert Love | 
|  | :Publisher: O'Reilly Media | 
|  | :Date: June, 2013 | 
|  | :Pages: 456 | 
|  | :ISBN: 978-1449339531 | 
|  | :Notes: Foundational book | 
|  |  | 
|  | * Title: **Linux Kernel Development, 3rd Edition** | 
|  |  | 
|  | :Author: Robert Love | 
|  | :Publisher: Addison-Wesley | 
|  | :Date: July, 2010 | 
|  | :Pages: 440 | 
|  | :ISBN: 978-0672329463 | 
|  | :Notes: Foundational book | 
|  |  | 
|  | .. _ldd3_published: | 
|  |  | 
|  | * Title: **Linux Device Drivers, 3rd Edition** | 
|  |  | 
|  | :Authors: Jonathan Corbet, Alessandro Rubini, and Greg Kroah-Hartman | 
|  | :Publisher: O'Reilly & Associates | 
|  | :Date: 2005 | 
|  | :Pages: 636 | 
|  | :ISBN: 0-596-00590-3 | 
|  | :Notes: Foundational book. Further information in | 
|  | http://www.oreilly.com/catalog/linuxdrive3/ | 
|  | PDF format, URL: https://lwn.net/Kernel/LDD3/ | 
|  |  | 
|  | * Title: **The Design of the UNIX Operating System** | 
|  |  | 
|  | :Author: Maurice J. Bach | 
|  | :Publisher: Prentice Hall | 
|  | :Date: 1986 | 
|  | :Pages: 471 | 
|  | :ISBN: 0-13-201757-1 | 
|  | :Notes: Foundational book | 
|  |  | 
|  | Miscellaneous | 
|  | ------------- | 
|  |  | 
|  | * Name: **Cross-Referencing Linux** | 
|  |  | 
|  | :URL: https://elixir.bootlin.com/ | 
|  | :Keywords: Browsing source code. | 
|  | :Description: Another web-based Linux kernel source code browser. | 
|  | Lots of cross references to variables and functions. You can see | 
|  | where they are defined and where they are used. | 
|  |  | 
|  | * Name: **Linux Weekly News** | 
|  |  | 
|  | :URL: https://lwn.net | 
|  | :Keywords: latest kernel news. | 
|  | :Description: The title says it all. There's a fixed kernel section | 
|  | summarizing developers' work, bug fixes, new features and versions | 
|  | produced during the week. | 
|  |  | 
|  | * Name: **The home page of Linux-MM** | 
|  |  | 
|  | :Author: The Linux-MM team. | 
|  | :URL: https://linux-mm.org/ | 
|  | :Keywords: memory management, Linux-MM, mm patches, TODO, docs, | 
|  | mailing list. | 
|  | :Description: Site devoted to Linux Memory Management development. | 
|  | Memory related patches, HOWTOs, links, mm developers... Don't miss | 
|  | it if you are interested in memory management development! | 
|  |  | 
|  | * Name: **Kernel Newbies IRC Channel and Website** | 
|  |  | 
|  | :URL: https://www.kernelnewbies.org | 
|  | :Keywords: IRC, newbies, channel, asking doubts. | 
|  | :Description: #kernelnewbies on irc.oftc.net. | 
|  | #kernelnewbies is an IRC network dedicated to the 'newbie' | 
|  | kernel hacker. The audience mostly consists of people who are | 
|  | learning about the kernel, working on kernel projects or | 
|  | professional kernel hackers that want to help less seasoned kernel | 
|  | people. | 
|  | #kernelnewbies is on the OFTC IRC Network. | 
|  | Try irc.oftc.net as your server and then /join #kernelnewbies. | 
|  | The kernelnewbies website also hosts articles, documents, FAQs... | 
|  |  | 
|  | * Name: **linux-kernel mailing list archives and search engines** | 
|  |  | 
|  | :URL: https://subspace.kernel.org | 
|  | :URL: https://lore.kernel.org | 
|  | :Keywords: linux-kernel, archives, search. | 
|  | :Description: Some of the linux-kernel mailing list archivers. If | 
|  | you have a better/another one, please let me know. | 
|  |  | 
|  | * Name: **The Linux Foundation YouTube channel** | 
|  |  | 
|  | :URL: https://www.youtube.com/user/thelinuxfoundation | 
|  | :Keywords: linux, videos, linux-foundation, youtube. | 
|  | :Description: The Linux Foundation uploads video recordings of their | 
|  | collaborative events, Linux conferences including LinuxCon, and | 
|  | other original research and content related to Linux and software | 
|  | development. | 
|  |  | 
|  | ------- | 
|  |  | 
|  | This document was originally based on: | 
|  |  | 
|  | https://www.dit.upm.es/~jmseyas/linux/kernel/hackers-docs.html | 
|  |  | 
|  | and written by Juan-Mariano de Goyeneche |