Assembly Language Programming: ARM Cortex-M3
Buy Rights Online Buy Rights

Rights Contact Login For More Details

More About This Title Assembly Language Programming: ARM Cortex-M3

English

ARM designs the cores of microcontrollers which equip most "embedded systems" based on 32-bit processors. Cortex M3 is one of these designs, recently developed by ARM with microcontroller applications in mind. To conceive a particularly optimized piece of software (as is often the case in the world of embedded systems) it is often necessary to know how to program in an assembly language.

This book explains the basics of programming in an assembly language, while being based on the architecture of Cortex M3 in detail and developing many examples.

It is written for people who have never programmed in an assembly language and is thus didactic and progresses step by step by defining the concepts necessary to acquiring a good understanding of these techniques.

English

Vincent Mahout is a teacher at INSA of Toulouse (Grande Ecole d'Ingénieurs) under the authority of the Ministry of Education and Research. He is also a researcher at CNRS/LAAS (www.laas.fr), Toulouse, France.

English

Preface ix

Chapter 1. Overview of Cortex-M3 Architecture 1

1.1. Assembly language versus the assembler 1

1.2. The world of ARM 2

Chapter 2. The Core of Cortex-M3 15

2.1. Modes, privileges and states 15

2.2. Registers 17

Chapter 3. The Proper Use of Assembly Directives 25

3.1. The concept of the directive 25

3.2. Structure of a program 27

3.3. A section of code 29

3.4. The data section 36

3.5. Is that all? 39

Chapter 4. Operands of Instructions 47

4.1. The constant and renaming 48

4.2. Operands for common instructions 49

4.3. Memory access operands: addressing modes 57

Chapter 5. Instruction Set 63

5.1. Reading guide 63

5.2. Arithmetic instructions 66

5.3. Logical and bit manipulation instructions 70

5.4. Internal transfer instructions 75

5.5. Test instructions 76

5.6. Branch instructions 77

5.7. Load/store instructions 80

5.8. “System” instructions and others 85

Chapter 6. Algorithmic and Data Structures 87

6.1. Flowchart versus algorithm 87

6.2. Alternative structures 89

6.3. Iterative structures 98

6.4. Compound conditions 106

6.5. Data structure 111

Chapter 7. Internal Modularity 119

7.1. Detailing the concept of procedure 119

7.2. Procedure arguments 123

7.3. Local data 136

Chapter 8. Managing Exceptions 147

8.1. What happens during Reset? 148

8.2. Possible exceptions 151

8.3. Priority management 161

8.4. Entry and return in exception processing 167

Chapter 9. From Listing to Executable: External Modularity 173

9.1. External modularity 175

9.2. The role of the assembler 182

9.3. The role of the linker 188

9.4. The loader and the debugging unit 196

Appendices 199

Appendix A. Instruction Set – Alphabetical List 201

Appendix B. The SysTick Timer 209

Appendix C. Example of a “Bootstrap” File 217

Appendix D. The GNU Assembler 227

Bibliography 239

Index 241

loading