# CSE 378 Machine Organization and Assembly Language Programming

# Spring 2009

John Zahorjan Ivayla Dermendjieva David St. Hilaire

# Part 1: Course MechanicsPart 2: Course Overview



### This Version of 378

- Software simulators, rather than hardware
- Pros:
  - Greater breadth (by which I mean depth)
    - Compiler, OS, shell, and applications
  - "Easier debugging"
  - Fewer hidden gotchas
  - · "Work where you want, when you want"
- Cons
  - New set of tools (Cebollita / SMOK)
  - Not as useful a pre-req for CSE 466 / 471
    - But a better pre-req for a lot of other courses, and non-courses







"Sequential code"

• c=0;

if ( a<0 ) c=1;

- Parallel Execution Approaches
  - Pipelining
  - Multiple issue
  - Multi-threading
  - Multi-core
- All these approaches have something to teach us about turning sequential code into "explicitly parallel code"

### Multicores (Explicitly Parallel Code)

Parallelism has always been critical to performance in computing, but it was often hidden. Chapter 4 will explain pipelining, an elegant technique that runs programs faster by overlapping the execution of instructions. This is one example of *instruction-level parallelism*, where the parallel nature of the hardware is abstracted away so the programmer and compiler can think of the hardware as executing instructions sequentially.

Forcing programmers to be aware of the parallel hardware and to explicitly rewrite their programs to be parallel had been the "third rail" of computer architecture, for companies in the past that depended on such a change in behavior failed (see Section 7.14 on the CD). From this historical perspective, it's startling that the whole IT industry has bet its future that programmers will finally successfully switch to explicitly parallel programming.



- CSE 370
  - · Binary / hex integers
  - Basic machine organization: memory, registers, ALU, control, clock-cycle (?)
  - (378 is logical organization, not logic)
- CSE 303 / 143
  - Java not so much Java programming, as running Java programs
    - javac, java, classpath, jar, an editor
  - C we'll be using C--, a C subset, but we won't be doing much programming in it.
  - Unix we'll be using a Unix shell (cygwin, at least) in very modest ways. (We'll also be using Windows.)
  - Shell and make

### Mechanics: Homework

- Some problems from the book
- The majority of the work will be building a working machine
  - Three incremental projects
  - · Working in pairs if you like
    - Dividing the workload isn't easy
  - The final result will be a working processor that runs an operating system and a simple shell (plus applications)
- The challenge is mastering breadth



### An example: Java

- You probably think of computers as "Java" (and vice versa)
- A problem people often have in this course is forgetting about that
  - The processor isn't trying to execute Java
  - It's very primitive:
    add 0100010000111101 and 010111101000111
  - Java is a whole lot of adding (plus some other things, like conditionals)

# Mechanics: Exams

Two midterms

- Monday, April 20 (subject to change)
- Monday, May 18 (subject to change)
- One final
  - Monday, June 8 (8:30-10:20)

# Mechanics: Grading

- 40% homeworks
- 10% first midterm
- 15% second midterm
- 30% final (covers entire quarter)
- 5% other



- Assignments:
  - Mostly electronic turn-in
  - We could be very rigid about the exact turn-in time...
- 20% / day late penalty
- 2 free extension days (at your discretion)
  - Make sure to clearly notify the TA

## Mechanics: Academic Misconduct

- "In general, any activity you engage in for the purpose of earning credit while avoiding learning, or to help others do so, is likely to be an act of Academic Misconduct."
- Different people learn best in different ways.
- It's never cheating to interact with course staff.





· Mostly one-way communication





















# MIPS R2000 ISA

- 32 registers (in register file)
- Each register is 32 bits wide
- "load-store" architecture
  - Source operands must be in registers
  - Result goes into a register
- MIPS is a "reduced instruction set" (RISC) architecture
  - Designed for parallelism (pipelining)
- mips.com sells architectures (not hardware)