Introduction
General preface information in most computer books.
Provide a bit of background and history of the ARM Processor leading up to the modern 64-bit processors that this book is about. Covers what you need to write programs like those in this book. GNU GCC compiler, GDB, a text editor, etc. Covers hardware you require to run the programs in this book including how to run a Raspberry Pi in 64-bit mode or using another SBC like the NVidia Jetson Nano.
Talk about how programs are represented in memory and then how you use an Assembler to generate them. Cover the linking process and give a very small example. The chapter concludes with a simple "Hello World" program written in ARM 64-bit Assembler.
The goal is to always have working sample programs, this is the first, to just ensure the reader can enter, assemble and link.
Now that we can start to write some longer code, we need to get into debugging. We also introduce makefiles. Cover the basics and typical workflows for writing/debugging programs.
Introduce how to do if/else statements and loops. Introduce design patterns. Talk more about making your programs readable and maintainable.
Covers loading from and storing to the Pi's memory. Indexed memory operation, etc.
Cover how Linux system calls work from Assembler. Cover how to do basic file I/O and other useful tasks like timing code.
Create a simple Assembler program to flash some LEDs attached via a breadboard to the GPIO pins.
Usually people use minimal Assembly code to supplement their programming in other languages. Cover the most common use cases and provide examples of each.
Show how to write Assembler to perform floating point calculations. Show how to do division. Cover the data formats supported here.
Explain Single Instruction Multiple Data (SIMD) programming. Examples from AI and graphics. Give examples and demonstrate how this can speed up your program.
How to use GCC to generate an Assembler listing from higher level language source code, how to use GDB to view Assembly code in memory and how to use Ghidra to reverse engineer a compiled program. Then look at an example of injecting executable code using a buffer overrun.
Introduction
General preface information in most computer books.
Provide a bit of background and history of the ARM Processor leading up to the modern 64-bit processors that this book is about. Covers what you need to write programs like those in this book. GNU GCC compiler, GDB, a text editor, etc. Covers hardware you require to run the programs in this book including how to run a Raspberry Pi in 64-bit mode or using another SBC like the NVidia Jetson Nano.
Talk about how programs are represented in memory and then how you use an Assembler to generate them. Cover the linking process and give a very small example. The chapter concludes with a simple "Hello World" program written in ARM 64-bit Assembler.
The goal is to always have working sample programs, this is the first, to just ensure the reader can enter, assemble and link.
Now that we can start to write some longer code, we need to get into debugging. We also introduce makefiles. Cover the basics and typical workflows for writing/debugging programs.
Introduce how to do if/else statements and loops. Introduce design patterns. Talk more about making your programs readable and maintainable.
Covers loading from and storing to the Pi's memory. Indexed memory operation, etc.
Cover how Linux system calls work from Assembler. Cover how to do basic file I/O and other useful tasks like timing code.
Create a simple Assembler program to flash some LEDs attached via a breadboard to the GPIO pins.
Usually people use minimal Assembly code to supplement their programming in other languages. Cover the most common use cases and provide examples of each.
Show how to write Assembler to perform floating point calculations. Show how to do division. Cover the data formats supported here.
Explain Single Instruction Multiple Data (SIMD) programming. Examples from AI and graphics. Give examples and demonstrate how this can speed up your program.
How to use GCC to generate an Assembler listing from higher level language source code, how to use GDB to view Assembly code in memory and how to use Ghidra to reverse engineer a compiled program. Then look at an example of injecting executable code using a buffer overrun.
Chapter 1: Getting Started.- Chapter 2: Loading & Adding.- Chapter 3: Tooling Up.- Chapter 4: Controlling Program Flow.- Chapter 5: Thanks for the Memories.- Chapter 6: Functions & the Stack.- Chapter 7: Linux Operating System Services.- Chapter 8: Programming GPIO Pins.- Chapter 9: Interacting with C & Python.- Chapter 10: Interfacing with Kotlin & Swift.- Chapter 11: Multiply, Divide & Accumulate .- Chapter 12: Floating-Point Operations.- Chapter 13: Neon Coprocessor.- Chapter 14: Optimizing Code.- Chapter 15 Reading & Understanding Code.- Chapter 16: Hacking Code.- Appendix A: The ARM Instruction Set.- Appendix B: Binary Formats.- Appendix C: Assembler Directives.- Appendix D: ASCII Character Set.
Stephen Smith is a retired Software Architect, located in Gibsons, BC, Canada. He's been developing software since high-school, or way too many years to record. Since retiring he has pursued Artificial Intelligence programming, earned his Advanced HAM Radio License and enjoys mountain biking, hiking, and nature photography. He continues to write his popular technology blog at smist08.wordpress.com.
![]() |
Ask a Question About this Product More... |
![]() |