
- 708 pages
- English
- ePUB (mobile friendly)
- Available on iOS & Android
Linux Device Driver Development
About this book
Get up to speed with the most important concepts in driver development and focus on common embedded system requirements such as memory management, interrupt management, and locking mechanismsKey Featuresโข Write feature-rich and customized Linux device drivers for any character, SPI, and I2C deviceโข Develop a deep understanding of locking primitives, IRQ management, memory management, DMA, and so onโข Gain practical experience in the embedded side of Linux using GPIO, IIO, and input subsystemsBook DescriptionLinux is by far the most-used kernel on embedded systems. Thanks to its subsystems, the Linux kernel supports almost all of the application fields in the industrial world. This updated second edition of Linux Device Driver Development is a comprehensive introduction to the Linux kernel world and the different subsystems that it is made of, and will be useful for embedded developers from any discipline.You'll learn how to configure, tailor, and build the Linux kernel. Filled with real-world examples, the book covers each of the most-used subsystems in the embedded domains such as GPIO, direct memory access, interrupt management, and I2C/SPI device drivers. This book will show you how Linux abstracts each device from a hardware point of view and how a device is bound to its driver(s). You'll also see how interrupts are propagated in the system as the book covers the interrupt processing mechanisms in-depth and describes every kernel structure and API involved. This new edition also addresses how not to write device drivers using user space libraries for GPIO clients, I2C, and SPI drivers.By the end of this Linux book, you'll be able to write device drivers for most of the embedded devices out there. What you will learnโข Download, configure, build, and tailor the Linux kernelโข Describe the hardware using a device treeโข Write feature-rich platform drivers and leverage I2C and SPI busesโข Get the most out of the new concurrency managed workqueue infrastructureโข Understand the Linux kernel timekeeping mechanism and use time-related APIsโข Use the regmap framework to factor the code and make it genericโข Offload CPU for memory copies using DMAโข Interact with the real world using GPIO, IIO, and input subsystemsWho this book is forThis Linux OS book is for embedded system and embedded Linux enthusiasts/developers who want to get started with Linux kernel development and leverage its subsystems. Electronic hackers and hobbyists interested in Linux kernel development as well as anyone looking to interact with the platform using GPIO, IIO, and input subsystems will also find this book useful.
Frequently asked questions
- Essential is ideal for learners and professionals who enjoy exploring a wide range of subjects. Access the Essential Library with 800,000+ trusted titles and best-sellers across business, personal growth, and the humanities. Includes unlimited reading time and Standard Read Aloud voice.
- Complete: Perfect for advanced learners and researchers needing full, unrestricted access. Unlock 1.4M+ books across hundreds of subjects, including academic and specialized titles. The Complete Plan also includes advanced features like Premium Read Aloud and Research Assistant.
Please note we cannot support devices running on iOS 13 and Android 7 or earlier. Learn more about using the app.
Information
Section 1 -Linux Kernel Development Basics
- Chapter 1, Introduction to Kernel Development
- Chapter 2, Understanding Linux Kernel Module Basic Concepts
- Chapter 3, Dealing with Kernel Core Helpers
- Chapter 4, Writing Character Device Drivers
Chapter 1: Introduction to Kernel Development
- Setting up the development environment
- Understanding the kernel configuration process
- Building your kernel
Setting up the development environment
- Target: This is the machine that the binaries resulting from the build process are produced for. This is the machine that is going to run the binary.
- Host: This is the machine where the build process takes place.
- Compilation: This is also called native compilation or a native build. This happens when the target and the host are the same; that is, when you're building on machine A (the host) a binary that is going to be executed on the same machine (A, the target) or a machine of the same kind. Native compilation requires a native compiler. Therefore, a native compiler is one where the target and the host are the same.
- Cross-compilation: Here, the target and the host are different. It is where you build a binary from machine A (the host) that is going to be executed on machine B (the target). In this case, the host (machine A) must have installed the cross-compiler that supports the target architecture. Thus, a cross-compiler is a compiler where the target is different from the host.
Setting up the host machine
Understanding and installing toolchains
Table of contents
- Linux Device Driver Development Second Edition
- Contributors
- Preface
- Section 1 -Linux Kernel Development Basics
- Chapter 1: Introduction to Kernel Development
- Chapter 2: Understanding Linux Kernel Module Basic Concepts
- Chapter 3: Dealing with Kernel Core Helpers
- Chapter 4: Writing Character Device Drivers
- Section 2 - Linux Kernel Platform Abstraction and Device Drivers
- Chapter 5: Understanding and Leveraging the Device Tree
- Chapter 6: Introduction to Devices, Drivers, and Platform Abstraction
- Chapter 7: Understanding the Concept of Platform Devices and Drivers
- Chapter 8: Writing I2C Device Drivers
- Chapter 9: Writing SPI Device Drivers
- Section 3 - Making the Most out of Your Hardware
- Chapter 10: Understanding the Linux Kernel Memory Allocation
- Chapter 11: Implementing Direct Memory Access (DMA) Support
- Chapter 12: Abstracting Memory Access โ Introduction to the Regmap API: a Register Map Abstraction
- Chapter 13: Demystifying the Kernel IRQ Framework
- Chapter 14: Introduction to the Linux Device Model
- Section 4 - Misc Kernel Subsystems for the Embedded World
- Chapter 15: Digging into the IIO Framework
- Chapter 16: Getting the Most Out of the Pin Controller and GPIO Subsystems
- Chapter 17: Leveraging the Linux Kernel Input Subsystem
- Other Books You May Enjoy