229 lines
8.2 KiB
ReStructuredText
229 lines
8.2 KiB
ReStructuredText
.. _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
|