This text book provides a fairly thorough examination of the ARM V8 ISA (Instruction Set Architecture). It begins from the perspective of a person knowledgeable in the C or C++ programming languages (or similar languages, of which there are many). Early chapters bridge your knowledge of C or C++ backwards into assembly language driving home a very sharp point: C is a high level assembly language. Further, assembly language is nothing to be scared about.
As mentioned, if you are already familiar with C or any language descended from C, this book begins with what you know. Later chapters dive deeply into the corners and recesses of the ARM V8 ISA and are suitable for those wishing to master the rich instruction set of the 64 bit ARM processors.
Yes, absolutely.
In fact, we would argue that the study of assembly language is extremely important to the building of competent software engineers. Further, we would argue that teaching the x86 instruction set is sadistic and cruel as that ISA was born in the 1970s and has simply gotten more muddled with age.
The MIPS instruction set is another ISA that is often covered in College level courses. While far kinder and gentler than the x86 ISA, the MIPS processor isn't nearly as relevant as the ARM family. Phones, tablets, laptops and even desktops contain ARM V8 processors making the study of the ARM ISA far more topical.
Assembly language programming is quite closely intertwined with both the underlying hardware architecture and the host operating system. A "calling convention" refers to how functions are called and how parameters are passed. In this book we will use the ARM LINUX conventions. This means:
- You will need to run a ARM Linux VM on the Macintosh - even on ARM-based Macs. Why? Apple. That's why.
- You will need to run WSL (Windows Subsystem for Linux) on ARM-based Windows machines.
- You will need to run an ARM Linux VM on x86-based Windows machines.
As commendable as the ARM designs are, ARM's naming conventions for their Intellectual Properties are horrid. In this book, AARCH64 and ARM V8 are taken to be synonyms for the 64 bit ARM Instruction Set Architecture (ISA).
Chapter | Content |
---|---|
1 | Hello World |
2 | If Statements |
3 | Loops |
.... a | .... While Loops |
.... b | .... For Loops |
.... c | .... Implementing Continue |
.... d | .... Implementing Break |
4 | Interludes |
.... a | .... Registers |
.... b | .... Load and Store |
.... c | .... More About ldr |
.... d | .... Register Sizes |
5 | Functions |
.... a | .... Calling and Returning |
.... b | .... Passing Parameters |
6 | FizzBuzz - a Complete Program |
7 | Structs |
.... a | .... Alignment |
.... b | .... Defining |
.... c | .... Using |
8 | const |
9 | Casting |
10 | Floating Point |
.... a | .... What Are Floating Point Numbers? |
.... b | .... Working with Floats |
Chapter | Content |
---|---|
11 | Bit Fields |
.... a | .... Without Bit Fields |
.... b | .... With Bit Fields |
.... c | .... Review of Newly Described Instructions |
Here are some project specifications to offer a challenge to your growing mastery.
Perry Kivolowitz's career in the Computer Sciences spans just under five decades. He launched more than 5 companies, mostly relating to hardware, image processing and visual effects (for motion pictures and television). Perry received Emmy recognition for his work on the The Gathering, the pilot episode of Babylon 5. Later he received the Emmy Award for Engineering along with his colleagues at SilhouetteFX, LLC. Also, Perry received and Academy Award for Scientific and Technical Achievement for his invention of Shape Driven Warping and Morphing.