Book Image

Computer Architecture with Python and ARM

By : Alan Clements
Book Image

Computer Architecture with Python and ARM

By: Alan Clements

Overview of this book

This comprehensive guide offers a unique and immersive learning experience by combining Python programming with ARM architecture. Starting with an introduction to computer architecture and the flow of data within a computer system, you’ll progress to building your own interpreter using Python. You’ll see how this foundation enables the simulation of computer operations and learn ways to enhance a simulator by adding new instructions and displaying improved results. As you advance, you’ll explore the TC1 Assembler and Simulator Program to gain insights into instruction analysis and explore practical examples of simulators. This will help you build essential skills in understanding complex computer instructions, strengthening your grasp of computer architecture. Moreover, you’ll be introduced to the Raspberry Pi operating system, preparing you to delve into the detailed language of the ARM computer. This includes exploring the ARM instruction set architecture, data-processing instructions, subroutines, and the stack. With clear explanations, practical examples, and coding exercises, this resource will enable you to design and construct your own computer simulator, simulate assembly language programs, and leverage the Raspberry Pi for ARM programming.
Table of Contents (18 chapters)
1
Part 1: Using Python to Simulate a Computer
Free Chapter
2
Chapter 1: From Finite State Machines to Computers
10
Part 2: Using Raspberry Pi to Study a Real Computer Architecture

Intermission: The Pre-TC1

In order to provide a more complete overview of the operation of a CPU simulator, we are going to introduce a highly simplified, but complete, version to give you an idea of how things fit together, before we create a more complex system.

In this section, you will learn how to design a simulator without some of the complications associated with a fully fledged design.

This version of TC1, called TC1mini, can execute assembly language. However, we use a fixed format for assembly-level instructions (input is case-sensitive) and a fixed literal format (no hexadecimal or binary numbers), and we don’t support labels and symbolic names. This approach helps stop the details from getting in the way of the bigger picture.

The Simulator

The simulator supports register-to-register operations, such as ADD r1,r2,r3. Its only memory access is pointer-based, that is, LDRI r1,[r2] and STRI r1,[r2]. It provides increment and decrement instructions, INC r1...