EE108B Lecture 2 MIPS Assembly Language I
Total Page:16
File Type:pdf, Size:1020Kb
Load more
Recommended publications
-
Mipspro C++ Programmer's Guide
MIPSproTM C++ Programmer’s Guide 007–0704–150 CONTRIBUTORS Rewritten in 2002 by Jean Wilson with engineering support from John Wilkinson and editing support from Susan Wilkening. COPYRIGHT Copyright © 1995, 1999, 2002 - 2003 Silicon Graphics, Inc. All rights reserved; provided portions may be copyright in third parties, as indicated elsewhere herein. No permission is granted to copy, distribute, or create derivative works from the contents of this electronic documentation in any manner, in whole or in part, without the prior written permission of Silicon Graphics, Inc. LIMITED RIGHTS LEGEND The electronic (software) version of this document was developed at private expense; if acquired under an agreement with the USA government or any contractor thereto, it is acquired as "commercial computer software" subject to the provisions of its applicable license agreement, as specified in (a) 48 CFR 12.212 of the FAR; or, if acquired for Department of Defense units, (b) 48 CFR 227-7202 of the DoD FAR Supplement; or sections succeeding thereto. Contractor/manufacturer is Silicon Graphics, Inc., 1600 Amphitheatre Pkwy 2E, Mountain View, CA 94043-1351. TRADEMARKS AND ATTRIBUTIONS Silicon Graphics, SGI, the SGI logo, IRIX, O2, Octane, and Origin are registered trademarks and OpenMP and ProDev are trademarks of Silicon Graphics, Inc. in the United States and/or other countries worldwide. MIPS, MIPS I, MIPS II, MIPS III, MIPS IV, R2000, R3000, R4000, R4400, R4600, R5000, and R8000 are registered or unregistered trademarks and MIPSpro, R10000, R12000, R1400 are trademarks of MIPS Technologies, Inc., used under license by Silicon Graphics, Inc. Portions of this publication may have been derived from the OpenMP Language Application Program Interface Specification. -
MIPS IV Instruction Set
MIPS IV Instruction Set Revision 3.2 September, 1995 Charles Price MIPS Technologies, Inc. All Right Reserved RESTRICTED RIGHTS LEGEND Use, duplication, or disclosure of the technical data contained in this document by the Government is subject to restrictions as set forth in subdivision (c) (1) (ii) of the Rights in Technical Data and Computer Software clause at DFARS 52.227-7013 and / or in similar or successor clauses in the FAR, or in the DOD or NASA FAR Supplement. Unpublished rights reserved under the Copyright Laws of the United States. Contractor / manufacturer is MIPS Technologies, Inc., 2011 N. Shoreline Blvd., Mountain View, CA 94039-7311. R2000, R3000, R6000, R4000, R4400, R4200, R8000, R4300 and R10000 are trademarks of MIPS Technologies, Inc. MIPS and R3000 are registered trademarks of MIPS Technologies, Inc. The information in this document is preliminary and subject to change without notice. MIPS Technologies, Inc. (MTI) reserves the right to change any portion of the product described herein to improve function or design. MTI does not assume liability arising out of the application or use of any product or circuit described herein. Information on MIPS products is available electronically: (a) Through the World Wide Web. Point your WWW client to: http://www.mips.com (b) Through ftp from the internet site “sgigate.sgi.com”. Login as “ftp” or “anonymous” and then cd to the directory “pub/doc”. (c) Through an automated FAX service: Inside the USA toll free: (800) 446-6477 (800-IGO-MIPS) Outside the USA: (415) 688-4321 (call from a FAX machine) MIPS Technologies, Inc. -
MIPS Architecture • MIPS (Microprocessor Without Interlocked Pipeline Stages) • MIPS Computer Systems Inc
Spring 2011 Prof. Hyesoon Kim MIPS Architecture • MIPS (Microprocessor without interlocked pipeline stages) • MIPS Computer Systems Inc. • Developed from Stanford • MIPS architecture usages • 1990’s – R2000, R3000, R4000, Motorola 68000 family • Playstation, Playstation 2, Sony PSP handheld, Nintendo 64 console • Android • Shift to SOC http://en.wikipedia.org/wiki/MIPS_architecture • MIPS R4000 CPU core • Floating point and vector floating point co-processors • 3D-CG extended instruction sets • Graphics – 3D curved surface and other 3D functionality – Hardware clipping, compressed texture handling • R4300 (embedded version) – Nintendo-64 http://www.digitaltrends.com/gaming/sony- announces-playstation-portable-specs/ Not Yet out • Google TV: an Android-based software service that lets users switch between their TV content and Web applications such as Netflix and Amazon Video on Demand • GoogleTV : search capabilities. • High stream data? • Internet accesses? • Multi-threading, SMP design • High graphics processors • Several CODEC – Hardware vs. Software • Displaying frame buffer e.g) 1080p resolution: 1920 (H) x 1080 (V) color depth: 4 bytes/pixel 4*1920*1080 ~= 8.3MB 8.3MB * 60Hz=498MB/sec • Started from 32-bit • Later 64-bit • microMIPS: 16-bit compression version (similar to ARM thumb) • SIMD additions-64 bit floating points • User Defined Instructions (UDIs) coprocessors • All self-modified code • Allow unaligned accesses http://www.spiritus-temporis.com/mips-architecture/ • 32 64-bit general purpose registers (GPRs) • A pair of special-purpose registers to hold the results of integer multiply, divide, and multiply-accumulate operations (HI and LO) – HI—Multiply and Divide register higher result – LO—Multiply and Divide register lower result • a special-purpose program counter (PC), • A MIPS64 processor always produces a 64-bit result • 32 floating point registers (FPRs). -
Instruction Set Architecture
The Instruction Set Architecture Application Instruction Set Architecture OiOperating Compiler System Instruction Set Architecture Instr. Set Proc. I/O system or Digital Design “How to talk to computers if Circuit Design you aren’t on Star Trek” CSE 240A Dean Tullsen CSE 240A Dean Tullsen How to Sppmpeak Computer Crafting an ISA High Level Language temp = v[k]; • Designing an ISA is both an art and a science Program v[k] = v[k+ 1]; v[k+1] = temp; • ISA design involves dealing in an extremely rare resource Compiler – instruction bits! lw $15, 0($2) AblLAssembly Language lw $16, 4($2) • Some things we want out of our ISA Program sw $16, 0($2) – completeness sw $15, 4($2) Assembler – orthogonality 1000110001100010000000000000000 – regularity and simplicity Machine Language 1000110011110010000000000000100 – compactness Program 1010110011110010000000000000000 – ease of ppgrogramming 1010110001100010000000000000100 Machine Interpretation – ease of implementation Control Signal Spec ALUOP[0:3] <= InstReg[9:11] & MASK CSE 240A Dean Tullsen CSE 240A Dean Tullsen Where are the instructions? KKyey ISA decisions • Harvard architecture • Von Neumann architecture destination operand operation • operations y = x + b – how many? inst & source operands inst cpu data – which ones storage storage operands cpu • data “stored-program” computer – how many? storage – location – types – how to specify? how does the computer know what L1 • instruction format 0001 0100 1101 1111 inst – size means? cache L2 cpu Mem cache – how many formats? L1 dtdata cache CSE -
Computer Architectures an Overview
Computer Architectures An Overview PDF generated using the open source mwlib toolkit. See http://code.pediapress.com/ for more information. PDF generated at: Sat, 25 Feb 2012 22:35:32 UTC Contents Articles Microarchitecture 1 x86 7 PowerPC 23 IBM POWER 33 MIPS architecture 39 SPARC 57 ARM architecture 65 DEC Alpha 80 AlphaStation 92 AlphaServer 95 Very long instruction word 103 Instruction-level parallelism 107 Explicitly parallel instruction computing 108 References Article Sources and Contributors 111 Image Sources, Licenses and Contributors 113 Article Licenses License 114 Microarchitecture 1 Microarchitecture In computer engineering, microarchitecture (sometimes abbreviated to µarch or uarch), also called computer organization, is the way a given instruction set architecture (ISA) is implemented on a processor. A given ISA may be implemented with different microarchitectures.[1] Implementations might vary due to different goals of a given design or due to shifts in technology.[2] Computer architecture is the combination of microarchitecture and instruction set design. Relation to instruction set architecture The ISA is roughly the same as the programming model of a processor as seen by an assembly language programmer or compiler writer. The ISA includes the execution model, processor registers, address and data formats among other things. The Intel Core microarchitecture microarchitecture includes the constituent parts of the processor and how these interconnect and interoperate to implement the ISA. The microarchitecture of a machine is usually represented as (more or less detailed) diagrams that describe the interconnections of the various microarchitectural elements of the machine, which may be everything from single gates and registers, to complete arithmetic logic units (ALU)s and even larger elements. -
Electronic Products and Relays Selection Table Interface Relays CR-Range and R600 / R500 Range Pluggable Interface Relays
Electronic Products and Relays Selection Table Interface Relays CR-Range and R600 / R500 Range Pluggable Interface Relays CR-M Range Order number number Order 1SVR 405 611 R4000 1SVR 405 611 R1000 1SVR 405 611 R6000 1SVR 405 611 R4200 1SVR 405 611 R8000 1SVR 405 611 R8200 1SVR 405 611 R9000 1SVR 405 611 R0000 1SVR 405 611 R5000 1SVR 405 611 R7000 1SVR 405 611 R2000 1SVR 405 611 R3000 1SVR 405 612 R4000 1SVR 405 612 R1000 1SVR 405 612 R6000 1SVR 405 612 R4200 1SVR 405 612 R8000 1SVR 405 612 R8200 1SVR 405 612 R9000 1SVR 405 612 R0000 1SVR 405 612 R5000 1SVR 405 612 R5200 1SVR 405 612 R7000 1SVR 405 612 R2000 1SVR 405 612 R3000 1SVR 405 613 R4000 1SVR 405 613 R1000 1SVR 405 613 R6000 1SVR 405 613 R4200 1SVR 405 613 R8000 1SVR 405 613 R8200 1SVR 405 613 R9000 1SVR 405 613 R0000 1SVR 405 613 R5000 1SVR 405 613 R7000 1SVR 405 613 R2000 1SVR 405 613 R3000 1SVR 405 611 R4100 1SVR 405 611 R1100 1SVR 405 611 R6100 1SVR 405 611 R4300 1SVR 405 611 R8100 1SVR 405 611 R8300 1SVR 405 611 R9100 1SVR 405 611 R0100 1SVR 405 611 R5100 1SVR 405 611 R7100 1SVR 405 611 R2100 1SVR 405 611 R3100 1SVR 405 612 R4100 1SVR 405 612 R1100 1SVR 405 612 R6100 1SVR 405 612 R4300 1SVR 405 612 R8100 1SVR 405 612 R8300 1SVR 405 612 R9100 1SVR 405 612 R0100 1SVR 405 612 R5100 1SVR 405 612 R7100 1SVR 405 612 R2100 1SVR 405 612 R3100 1SVR 405 613 R4100 1SVR 405 613 R1100 1SVR 405 613 R6100 1SVR 405 613 R4300 1SVR 405 613 R8100 1SVR 405 613 R8300 1SVR 405 613 R9100 1SVR 405 613 R0100 1SVR 405 613 R5100 1SVR 405 613 R7100 1SVR 405 613 R2100 1SVR 405 613 R3100 1SVR 405 614 R1100 -
MIPS, HPS, Two-Level Branch Prediction, and Compressed Code RISC Processor
Awards ................................................................................................................................................................ Common Bonds: MIPS, HPS, Two-Level Branch Prediction, and Compressed Code RISC Processor ONUR MUTLU ETH Zurich RICH BELGARD ......We are continuing our series of of performance optimization on the com- sions made in the MIPS project that retrospectives for the 10 papers that piler and keep the hardware design sim- passed the test of time. The retrospective received the first set of MICRO Test of ple. The compiler is responsible for touches on the design tradeoffs made to Time (“ToT”) Awards in December generating and scheduling simple instruc- couple the hardware and the software, 2014.1,2 This issue features four retro- tions, which require little translation in the MIPS project’s effect on the later spectives written for six of the award- hardware to generate control signals to development of “fabless” semiconductor winning papers. We briefly introduce control the datapath components, which companies, and the use of benchmarks these papers and retrospectives and in turn keeps the hardware design simple. as a method for evaluating end-to-end hope that you will enjoy reading them as Thus, the instructions and hardware both performance of a system as, among much as we have. If anything ties these remain simple, whereas the compiler others, contributions of the MIPS project works together, it is the innovation they becomes much more important (and that have stood the test of time. delivered by taking a strong position in likely complex) because it must schedule the RISC/CISC debates of their decade. instructions well to ensure correct and High-Performance Systems We hope the IEEE Micro audience, espe- high-performance use of a simple pipe- The second retrospective addresses three cially younger generations, will find the line. -
A 7 CPU Instruction Formats a CPU Instruction Is a Single 32-Bit Aligned Word
A 7 CPU Instruction Formats A CPU instruction is a single 32-bit aligned word. The major instruction formats are shown in Figure A-10. I-Type (Immediate). 31 26 25 21 20 16 15 0 opcode rs rt offset 6 5 5 16 J-Type (Jump). 31 26 25 0 opcode instr_index 6 26 R-Type (Register). 31 26 25 21 20 16 15 11 10 6 5 0 opcode rs rt rd sa function 6 5 5 5 5 6 opcode 6-bit primary operation code rd 5-bit destination register specifier rs 5-bit source register specifier 5-bit target (source/destination) register specifier or used to rt specify functions within the primary opcode value REGIMM immediate 16-bit signed immediate used for: logical operands, arithmetic signed operands, load/store address byte offsets, PC-relative branch signed instruction displacement instr_index 26-bit index shifted left two bits to supply the low-order 28 bits of the jump target address. sa 5-bit shift amount 6-bit function field used to specify functions within the primary function operation code value SPECIAL. Figure A-10 CPU Instruction Formats A-174 MIPS IV Instruction Set. Rev 3.2 CPU Instruction Set A 8 CPU Instruction Encoding This section describes the encoding of user-level, i.e. non-privileged, CPU instructions for the four levels of the MIPS architecture, MIPS I through MIPS IV. Each architecture level includes the instructions in the previous level;† MIPS IV includes all instructions in MIPS I, MIPS II, and MIPS III. This section presents eight different views of the instruction encoding. -
3 Financial Mathematics
23/09/2017 SIMPLE INTEREST FINANCE AND GROWTH Interest is based only on the original • Simple Interest sum of money • Hire Purchase Agreements Rand value of interest remains constant • Compound Interest Formula: A = P(1 + n.i) • Inflation A = Total Amount • Population Growth P = Principle int erest _ rate • i Exchange Rates i = Interest Rate (where 100 ) n = Number of Years 1 2 Example 1: R1500 is invested for 2 years at 18% per Example 2: R50 000 is invested for 18 years at 16% p.a. annum (p.a.) simple interest. simple interest. Determine: a) the value of the investment after 18 years Value of investment after 1 year: A = R1500 + 18% of R1500 b) the simple interest earned after 18 years = R1500 + R270 P = R50 000 ; I = 0.16 p.a ; n = 18 years = R1770 a) A = P(1 + i.n) Value of investment after 2 years: A = R50 000 (1 + 0,16.18) A = R1770 + 18% of R1500 A = R194 000 = R1770 + R270 = R2040 b) Interest received Therefore value of interest remains constant. = A - P = R194 000 – R50 000 Using the Simple Interest formula: = R144 000. A = P(1 + i.n) A = R1500(1 + 0,18 x 2) A = R2040 3 4 Example 3: How much was invested 4 years ago if the Example 4: R1 600 accumlates to R3 000 after 4 years. value of the investment is currently worth R7 000? The Find the interest rate if the investment earned simple interest rate was 7% p.a. simple interest. interest. A = R3000 ; P = R1600 ; n = 4 years A = R7000 ; n = 4 years ; i = 0.07 A = P(1 + i.n) A = P(1+i.n) R3000 = R1600(1 + i.4) R7000 = P(1 + 0,07 x 4) R3000 = R1600 + 4800i R7000 = P(l + 0,28) R3000 – R1600 = 4800i R7000 = P(1,28) R1500 = 4800i R1500 4800 = i R7000 i = 0,3125 P 1,28 r = i x 100 = 0,3125 x 100 P = R5468,75 = 31,25% Simple Interest Calculator 5 6 1 23/09/2017 3. -
R1000/R2000/R3000 R4000/R6000/R8000-W Series Compact, Pressure Gauge Embedded
Regulator standard white Series R1000/R2000/R3000 R4000/R6000/R8000-W Series Compact, pressure gauge embedded. Port size: 1/8 to 1 JIS symbol Specifications Descriptions R1000-W R2000-W R3000-W R4000-W R6000-W R8000-W Appearance Working fluid Compressed air Max. working pressure MPa 1 Withstanding pressure MPa 1.5 Ambient temperature range °C 5 to 60 Note 1 Set pressure range MPa 0.05 to 0.85 Relief With relief mechanism 1/8, 1/4 1/4, 3/8 1/4, 3/8 1/4, 3/8, 1/2 3/4, 1 3/4, 1 Port size Rc, NPT, G (3/8 uses an adaptor) (1/2 uses an adaptor) (1/2 uses an adaptor) (3/4 uses an adaptor) (1 1/4 uses an adaptor) (1 1/4 uses an adaptor) Product weight kg 0.16 0.31 0.45 0.7 1.0 1.6 Standard accessories Pressure gauge, nut for panel mount Pressure gauge Note 1: The working temperature range of the pressure switch with indicator PPD assembly "R1" is 5 to 50°C. Ozone specifications (Ending 12) R*000 - ··· - W ··· - P11 Clean room specifications (catalog No. CB-033S) MDust generation preventing structure for use in cleanrooms R*000 - ··········· - P7* Secondary battery compatible specifications (catalog No. CC-947) MStructured for use in secondary battery manufacturing processes R*000 - ··········· - P4* 378 Regulator Series How to order How to order * Refer to page 274 for the explanation of the option. A Model no. R R R R R R R1000 6 W L A6W 1 2 3 4 6 8 G Attachment (attached) 0 0 0 0 0 0 F Piping adaptor set (attached) 0 0 0 0 0 0 0 0 0 0 0 0 Symbol Descriptions A Model no. -
EC 413 Computer Organization
EC 413 Computer Organization Instruction Set Architecture (ISA) Prof. Michel A. Kinsy Department of Electrical & Computer Engineering Full Ecosystem View Applications & Algorithms Programming Language Compiler Operating System Firmware ISA Processor Memory organization I/O system Datapath & Control Digital Design Circuit Design Layout Department of Electrical & Computer Engineering Another System View Software Instruction Set Hardware Department of Electrical & Computer Engineering 1 Another System View We are building some AI will soon take very smart systems ! over the world! This is lot of fun, Albert!!! Software Instruction Set Hardware Sure! That’s easy for you to say!!! Department of Electrical & Computer Engineering Instruction Set Architecture (ISA) § Instructions are the language the computer understand § Instruction Set is the vocabulary of that language § It serves as the hardware/software interface § Defines data types § byte, int, float, double, string, vector… § Defines set of programmer visible state § Known as the programmer’s model of the machine § Defines instruction semantics (operations, sequencing) § operand location: register, immediate, indirect, . § add, sub, mul, move, compare, … Department of Electrical & Computer Engineering Instruction Set Architecture (ISA) § Instructions are the language the computer understand § Instruction Set is the vocabulary of that language § It serves as the hardware/software interface § Defines instruction format (bit encoding) § Number of explicit operands per instruction § Operand location § Number of bits per instruction § Instruction length: fixed, short, long, or variable., … § Examples: RISC-V, MIPS, Alpha, x86, IBM 360, VAX, ARM, JVM Department of Electrical & Computer Engineering 2 Instruction Set Architecture (ISA) § Many possible implementations of the same ISA § 360 implementations: model 30 (c. 1964), z900 (c. 2001) § x86 implementations: 8086 (c. -
R1000/R2000/R3000 R4000/R6000/R8000-W Series Compact, Pressure Gauge Embedded
Regulator standard white Series R1000/R2000/R3000 R4000/R6000/R8000-W Series Compact, pressure gauge embedded. Port size: 1/8 to 1 JIS symbol Specifications Descriptions R1000-W R2000-W R3000-W R4000-W R6000-W R8000-W Appearance Working fluid Compressed air Max. working pressure MPa 1 Withstanding pressure MPa 1.5 Ambient temperature range °C 5 to 60 Note 1 Set pressure range MPa 0.05 to 0.85 Relief With relief mechanism 1/8, 1/4 1/4, 3/8 1/4, 3/8 1/4, 3/8, 1/2 3/4, 1 3/4, 1 Port size Rc, NPT, G (3/8 uses an adaptor) (1/2 uses an adaptor) (1/2 uses an adaptor) (3/4 uses an adaptor) (1 1/4 uses an adaptor) (1 1/4 uses an adaptor) Product weight kg 0.16 0.31 0.45 0.7 1.0 1.6 Standard accessories Pressure gauge, nut for panel mount Pressure gauge Note 1: The working temperature range of the pressure switch with indicator PPD assembly "R1" is 5 to 50°C. Ozone specifications (Ending 12) R*000 - ··· - W ··· - P11 Clean room specifications (catalog No. CB-033S) ● Dust generation preventing structure for use in cleanrooms R*000 - ··········· - P7* Secondary battery compatible specifications (catalog No. CC-947) ● Structured for use in secondary battery manufacturing processes R*000 - ··········· - P4* 378 Regulator Series How to order How to order * Refer to page 274 for the explanation of the option. A Model no. R1000R2000R3000R4000R6000R8000 R1000 6 W L A6W G Attachment (attached) F Piping adaptor set (attached) Symbol Descriptions A Model no.