Instruction Set Architecture



Similar documents
CS:APP Chapter 4 Computer Architecture Instruction Set Architecture. CS:APP2e

CS:APP Chapter 4 Computer Architecture Instruction Set Architecture

Chapter 4 Processor Architecture

Machine-Level Programming II: Arithmetic & Control

Assembly Language: Function Calls" Jennifer Rexford!

Lecture 7: Machine-Level Programming I: Basics Mohamed Zahran (aka Z)

CS61: Systems Programing and Machine Organization

l C-Programming l A real computer language l Data Representation l Everything goes down to bits and bytes l Machine representation Language

CS:APP Chapter 4 Computer Architecture. Wrap-Up. William J. Taffe Plymouth State University. using the slides of

Lecture 27 C and Assembly

Machine Programming II: Instruc8ons

Giving credit where credit is due

Intel 8086 architecture

CS412/CS413. Introduction to Compilers Tim Teitelbaum. Lecture 20: Stack Frames 7 March 08

Return-oriented programming without returns

Instruction Set Architecture

64-Bit NASM Notes. Invoking 64-Bit NASM

A Tiny Guide to Programming in 32-bit x86 Assembly Language

Computer Organization and Architecture

x64 Cheat Sheet Fall 2015

Instruction Set Architecture. or How to talk to computers if you aren t in Star Trek

MACHINE ARCHITECTURE & LANGUAGE

Hacking Techniques & Intrusion Detection. Ali Al-Shemery arabnix [at] gmail

Introduction. Application Security. Reasons For Reverse Engineering. This lecture. Java Byte Code

Advanced Computer Architecture-CS501. Computer Systems Design and Architecture 2.1, 2.2, 3.2

Computer Architectures

Instruction Set Architecture (ISA) Design. Classification Categories

612 CHAPTER 11 PROCESSOR FAMILIES (Corrisponde al cap Famiglie di processori) PROBLEMS

Instruction Set Architecture (ISA)

Instruction Set Design

In the Beginning The first ISA appears on the IBM System 360 In the good old days

LSN 2 Computer Processors

Stack Overflows. Mitchell Adair

X86-64 Architecture Guide

Systems Design & Programming Data Movement Instructions. Intel Assembly

Intel Assembler. Project administration. Non-standard project. Project administration: Repository

İSTANBUL AYDIN UNIVERSITY

Overview. CISC Developments. RISC Designs. CISC Designs. VAX: Addressing Modes. Digital VAX

Computer Organization and Components

An Overview of Stack Architecture and the PSC 1000 Microprocessor

PART B QUESTIONS AND ANSWERS UNIT I

CSC 2405: Computer Systems II

Stack machines The MIPS assembly language A simple source language Stack-machine implementation of the simple language Readings:

Chapter 7D The Java Virtual Machine

Abysssec Research. 1) Advisory information. 2) Vulnerable version

MICROPROCESSOR. Exclusive for IACE Students iacehyd.blogspot.in Ph: /422 Page 1

Off-by-One exploitation tutorial

8085 INSTRUCTION SET

PROBLEMS (Cap. 4 - Istruzioni macchina)

a storage location directly on the CPU, used for temporary storage of small amounts of data during processing.

TODAY, FEW PROGRAMMERS USE ASSEMBLY LANGUAGE. Higher-level languages such

CHAPTER 6 TASK MANAGEMENT

MICROPROCESSOR AND MICROCOMPUTER BASICS

Computer Architecture Lecture 2: Instruction Set Principles (Appendix A) Chih Wei Liu 劉 志 尉 National Chiao Tung University

Unpacked BCD Arithmetic. BCD (ASCII) Arithmetic. Where and Why is BCD used? From the SQL Server Manual. Packed BCD, ASCII, Unpacked BCD

Under The Hood: The System Call

M A S S A C H U S E T T S I N S T I T U T E O F T E C H N O L O G Y DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

More MIPS: Recursion. Computer Science 104 Lecture 9

CS 152 Computer Architecture and Engineering. Lecture 22: Virtual Machines

High-speed image processing algorithms using MMX hardware

The AVR Microcontroller and C Compiler Co-Design Dr. Gaute Myklebust ATMEL Corporation ATMEL Development Center, Trondheim, Norway

Compilers I - Chapter 4: Generating Better Code

W4118 Operating Systems. Instructor: Junfeng Yang

An Introduction to Assembly Programming with the ARM 32-bit Processor Family

Buffer Overflows. Security 2011

Pentium vs. Power PC Computer Architecture and PCI Bus Interface

Computer Architectures

Where we are CS 4120 Introduction to Compilers Abstract Assembly Instruction selection mov e1 , e2 jmp e cmp e1 , e2 [jne je jgt ] l push e1 call e

UNIVERSITY OF CALIFORNIA, DAVIS Department of Electrical and Computer Engineering. EEC180B Lab 7: MISP Processor Design Spring 1995

CHAPTER 7: The CPU and Memory

An Introduction to the ARM 7 Architecture

Programming from the Ground Up. Jonathan Bartlett

The Beast is Resting in Your Memory On Return-Oriented Programming Attacks and Mitigation Techniques To appear at USENIX Security & BlackHat USA, 2014

Andreas Herrmann. AMD Operating System Research Center

Computer Systems Architecture

Computer Organization and Assembly Language

CHAPTER 4 MARIE: An Introduction to a Simple Computer

HC12 Assembly Language Programming

CPU Organization and Assembly Language

Reduced Instruction Set Computer (RISC)

Stitching the Gadgets On the Ineffectiveness of Coarse-Grained Control-Flow Integrity Protection

1. General function and functionality of the malware

Central Processing Unit (CPU)

Translating C code to MIPS

How It All Works. Other M68000 Updates. Basic Control Signals. Basic Control Signals

Traditional IBM Mainframe Operating Principles

MACHINE INSTRUCTIONS AND PROGRAMS

Overview of IA-32 assembly programming. Lars Ailo Bongo University of Tromsø

Chapter 2 Topics. 2.1 Classification of Computers & Instructions 2.2 Classes of Instruction Sets 2.3 Informal Description of Simple RISC Computer, SRC

Software Vulnerabilities

Exceptions in MIPS. know the exception mechanism in MIPS be able to write a simple exception handler for a MIPS machine

VLIW Processors. VLIW Processors

The IA-32 processor architecture

A single register, called the accumulator, stores the. operand before the operation, and stores the result. Add y # add y from memory to the acc

TitanMist: Your First Step to Reversing Nirvana TitanMist. mist.reversinglabs.com

For a 64-bit system. I - Presentation Of The Shellcode

Assembly Language Programming

Return-oriented Programming: Exploitation without Code Injection

Introduction. Compiler Design CSE 504. Overview. Programming problems are easier to solve in high-level languages

Z80 Instruction Set. Z80 Assembly Language

Transcription:

CS:APP Chapter 4 Computer Architecture Instruction Set Architecture Randal E. Bryant adapted by Jason Fritts http://csapp.cs.cmu.edu CS:APP2e

Hardware Architecture - using Y86 ISA For learning aspects of hardware architecture design, we ll be using the Y86 ISA x86 is a CISC language too complex for educational purposes Y86 Instruction Set Architecture a pseudo-language based on x86 (IA-32) similar state, but simpler set of instructions simpler instruction formats and addressing modes more RISC-like ISA than IA-32 Format 1 6 bytes of information read from memory can determine instruction length from first byte 2 CS:APP2e

CISC Instruction Sets Complex Instruction Set Computer Dominant style through mid-80 s Stack-oriented instruction set Use stack to pass arguments, save program counter Explicit push and pop instructions Arithmetic instructions can access memory addl %eax, 12(%ebx,%ecx,4) requires memory read and write Complex address calculation Condition codes Set as side effect of arithmetic and logical instructions Philosophy Add instructions to perform typical programming tasks 3 CS:APP2e

RISC Instruction Sets Reduced Instruction Set Computer Internal project at IBM, later popularized by Hennessy (Stanford) and Patterson (Berkeley) Fewer, simpler instructions Might take more to get given task done Can execute them with small and fast hardware Register-oriented instruction set Many more (typically 32) registers Use for arguments, return pointer, temporaries Only load and store instructions can access memory Similar to Y86 mrmovl and rmmovl No Condition codes Test instructions return 0/1 in register 4 CS:APP2e

Y86 Instruction Set and Formatting Byte 0 1 2 3 4 5 halt 0 0 nop 1 0 cmovxx ra, rb 2 fn ra rb irmovl V, rb 3 0 8 rb V rmmovl ra, D(rB) 4 0 ra rb D mrmovl D(rB), ra 5 0 ra rb D OPl ra, rb 6 fn ra rb jxx Dest 7 fn Dest call Dest 8 0 Dest ret 9 0 pushl ra A 0 ra 8 popl ra B 0 ra 8 5 CS:APP2e

Y86 Processor State RF: Program registers %eax %ecx %edx %ebx %esi %edi %esp %ebp CC: Condition codes ZF SF OF PC Stat: Program status DMEM: Memory Program Registers Same 8 as with IA32. Each 32 bits Condition Codes Single-bit flags set by arithmetic or logical instructions» ZF: Zero SF:Negative OF: Overflow Program Counter Indicates address of next instruction Program Status Indicates either normal operation or some error condition Memory Byte-addressable storage array Words stored in little-endian byte order 6 CS:APP2e

Y86 Instruction Set #2 Byte 0 1 2 3 4 5 halt 0 0 nop 1 0 cmovxx ra, rb 2 fn ra rb irmovl V, rb 3 0 8 rb V addl 6 0 subl 6 1 andl 6 2 xorl 6 3 rmmovl ra, D(rB) 4 0 ra rb D mrmovl D(rB), ra 5 0 ra rb D OPl ra, rb 6 fn ra rb jxx Dest 7 fn Dest call Dest 8 0 Dest ret 9 0 pushl ra A 0 ra 8 popl ra 7 B 0 ra 8 CS:APP2e

Y86 Instruction Set #3 Byte 0 1 2 3 4 5 halt 0 0 nop 1 0 rrmovl ra, rb 2 fn ra rb irmovl V, rb 3 0 8 rb V rmmovl ra, D(rB) 4 0 ra rb D jmp 7 0 mrmovl D(rB), ra 5 0 ra rb D jle 7 1 OPl ra, rb 6 fn ra rb jl 7 2 jxx Dest 7 fn Dest je 7 3 call Dest 8 0 Dest jne 7 4 ret 9 0 jge 7 5 pushl ra A 0 ra 8 jg 7 6 popl ra B 0 ra 8 8 CS:APP2e

Encoding Registers Each register has 4-bit ID %eax %ecx %edx %ebx 0 1 2 3 %esi %edi %esp %ebp 6 7 4 5 Same encoding as in IA32 Register ID 15 (0xF) indicates no register Will use this in our hardware design in multiple places 10 CS:APP2e

Instruction Example Addition Instruction Generic Form addl ra, rb 6 0 ra rb Encoded Representation Add value in register ra to that in register rb Store result in register rb Note that Y86 only allows addition to be applied to register data Set condition codes based on result e.g., addl %eax,%esi Encoding: 60 06 Two-byte encoding First indicates instruction type Second gives source and destination registers 11 CS:APP2e

Arithmetic and Logical Operations Instruction Code Function Code Add addl ra, rb 6 0 ra rb Subtract (ra from rb) And subl ra, rb 6 1 ra rb Refer to generically as OPl Encodings differ only by function code Low-order 4 bytes in first instruction word Set condition codes as side effect andl ra, rb 6 2 ra rb Exclusive-Or xorl ra, rb 6 3 ra rb 12 CS:APP2e

Move Operations rrmovl ra, rb 2 0 ra rb Register --> Register irmovl V, rb 3 0 8 rb V Immediate --> Register rmmovl ra, D(rB) 4 0 ra rb D Register --> Memory mrmovl D(rB), ra 5 0 ra rb D Memory --> Register Like the IA32 movl instruction Simpler format for memory addresses Give different names to keep them distinct 13 CS:APP2e

Move Instruction Examples IA32 Y86 Encoding movl $0xabcd, %edx irmovl $0xabcd, %edx 30 82 cd ab 00 00 movl %esp, %ebx rrmovl %esp, %ebx 20 43 movl -12(%ebp),%ecx movl %esi,0x41c(%esp) mrmovl -12(%ebp),%ecx rmmovl %esi,0x41c(%esp) 50 15 f4 ff ff ff 40 64 1c 04 00 00 movl $0xabcd, (%eax) movl %eax, 12(%eax,%edx) movl (%ebp,%eax,4),%ecx 14 CS:APP2e

Jump Instructions Jump Unconditionally jmp Dest 7 0 Jump When Less or Equal jle Dest 7 1 Jump When Less jl Dest 7 2 Jump When Equal je Dest 7 3 Jump When Not Equal jne Dest 7 4 Jump When Greater or Equal Dest Dest Dest Dest Dest Refer to generically as jxx Encodings differ only by function code Based on values of condition codes Same as IA32 counterparts Encode full destination address Unlike PC-relative addressing seen in IA32 jge Dest 7 5 Dest Jump When Greater jg Dest 7 6 Dest 16 CS:APP2e

Stack Operations pushl ra A 0 ra F Decrement %esp by 4 Store word from ra to memory at %esp Like IA32 popl ra B 0 ra F Read word from memory at %esp Save in ra Increment %esp by 4 Like IA32 18 CS:APP2e

Subroutine Call and Return call Dest 8 0 Dest Push address of next instruction onto stack Start executing instructions at Dest Like IA32 ret 9 0 Pop value from stack Use as address for next instruction Like IA32 19 CS:APP2e

Miscellaneous Instructions nop 1 0 Don t do anything halt 0 0 Stop executing instructions IA32 has comparable instruction, but can t execute it in user mode We will use it to stop the simulator Encoding ensures that program hitting memory initialized to zero will halt 20 CS:APP2e

Status Conditions Mnemonic Code AOK 1 Mnemonic Code HLT 2 Mnemonic Code ADR 3 Mnemonic Code INS 4 Normal operation Halt instruction encountered Bad address (either instruction or data) encountered Invalid instruction encountered Desired Behavior If AOK, keep going Otherwise, stop program execution 21 CS:APP2e

Y86 Code Generation Example #2 Second Try Write with pointer code Result Don t need to do indexed addressing /* Find number of elements in null-terminated list */ int len2(int a[]) { int len = 0; while (*a++) len++; return len; }.L11: incl movl addl testl jne.l11 %ecx (%edx), %eax $4, %edx %eax, %eax Compile with gcc34 O1 -S 24 CS:APP2e

Y86 Code Generation Example #3 IA32 Code Setup len2: pushl %ebp movl %esp, %ebp movl 8(%ebp), %edx movl $0, %ecx movl (%edx), %eax addl $4, %edx testl %eax, %eax je.l13 Y86 Code Setup len2: pushl %ebp # Save %ebp rrmovl %esp, %ebp # New FP pushl %esi # Save irmovl $4, %esi # Constant 4 pushl %edi # Save irmovl $1, %edi # Constant 1 mrmovl 8(%ebp), %edx # Get a irmovl $0, %ecx # len = 0 mrmovl (%edx), %eax # Get *a addl %esi, %edx # a++ andl %eax, %eax # Test *a je Done # If zero, goto Done Need constants 1 & 4 Use andl to test register Store in callee-save registers 25 CS:APP2e

Y86 Code Generation Example #4 IA32 Code Loop & Exit.L11: incl %ecx movl (%edx), %eax addl $4, %edx testl %eax, %eax jne.l11.l13: movl %ecx, %eax leave ret Y86 Code Loop & Exit Loop: addl %edi, %ecx # len++ mrmovl (%edx), %eax # Get *a addl %esi, %edx # a++ andl %eax, %eax # Test *a jne Loop # If!0, goto Loop Done: rrmovl %ecx, %eax # return len popl %edi # Restore %edi popl %esi # Restore %esi rrmovl %ebp, %esp # Restore SP popl %ebp # Restore FP ret 26 CS:APP2e

Summary Y86 Instruction Set Architecture Similar state and instructions as IA32 Simpler encodings Somewhere between CISC and RISC How Important is ISA Design? Less now than before With enough hardware, can make almost anything go fast Intel has evolved from IA32 to x86-64 Uses 64-bit words (including addresses) Adopted some features found in RISC» More registers (16)» Less reliance on stack 36 CS:APP2e