March 4, 2008 DF5-1http://csg.csail.mit.edu/arvind/ The Monsoon Project Arvind Computer Science & Artificial Intelligence Lab Massachusetts Institute of.

Slides:



Advertisements
Similar presentations
Lecture 3: Instruction Set Principles Kai Bu
Advertisements

Dynamic ILP: Scoreboard Professor Alvin R. Lebeck Computer Science 220 / ECE 252 Fall 2008.
Instruction-Level Parallelism (ILP)
DATAFLOW ARHITEKTURE. Dataflow Processors - Motivation In basic processor pipelining hazards limit performance –Structural hazards –Data hazards due to.
February 28, 2012CS152, Spring 2012 CS 152 Computer Architecture and Engineering Lecture 11 - Out-of-Order Issue, Register Renaming, & Branch Prediction.
PART 4: (2/2) Central Processing Unit (CPU) Basics CHAPTER 13: REDUCED INSTRUCTION SET COMPUTERS (RISC) 1.
Computer Organization. This module surveys the physical resources of a computer system. –Basic components CPUMemoryBus I/O devices –CPU structure Registers.
Processor Technology and Architecture
CSCI 8150 Advanced Computer Architecture Hwang, Chapter 2 Program and Network Properties 2.3 Program Flow Mechanisms.
Computer Organization and Architecture The CPU Structure.
1  2004 Morgan Kaufmann Publishers Chapter Six. 2  2004 Morgan Kaufmann Publishers Pipelining The laundry analogy.
1 Lecture 5: Pipeline Wrap-up, Static ILP Basics Topics: loop unrolling, VLIW (Sections 2.1 – 2.2) Assignment 1 due at the start of class on Thursday.
Chapter 4 Processor Technology and Architecture. Chapter goals Describe CPU instruction and execution cycles Explain how primitive CPU instructions are.
(Page 554 – 564) Ping Perez CS 147 Summer 2001 Alternative Parallel Architectures  Dataflow  Systolic arrays  Neural networks.
Where do We Go from Here? Thoughts on Computer Architecture TIP For additional advice see Dale Canegie Training® Presentation Guidelines Jack Dennis MIT.
Processor Structure & Operations of an Accumulator Machine
High Performance Architectures Dataflow Part 3. 2 Dataflow Processors Recall from Basic Processor Pipelining: Hazards limit performance  Structural hazards.
Computer Architecture Dataflow Machines. Data Flow Conventional programming models are control driven Instruction sequence is precisely specified Sequence.
1 Arvind Computer Science and Artificial Intelligence Lab M.I.T. Dataflow: Passing the Token ISCA 2005, Madison, WI June 6, 2005.
March 4, 2008 DF4-1http://csg.csail.mit.edu/arvind/ From Id/pH to Dataflow Graphs Arvind Computer Science & Artificial Intelligence Lab Massachusetts Institute.
1 Multithreaded Architectures Lecture 3 of 4 Supercomputing ’93 Tutorial Friday, November 19, 1993 Portland, Oregon Rishiyur S. Nikhil Digital Equipment.
Computer Architecture And Organization UNIT-II General System Architecture.
Instruction Level Parallelism Pipeline with data forwarding and accelerated branch Loop Unrolling Multiple Issue -- Multiple functional Units Static vs.
1 Chapter 2 Dataflow Processors. 2 Dataflow processors Recall from basic processor pipelining: Hazards limit performance. – Structural hazards – Data.
Different parallel processing architectures Module 2.
Anshul Kumar, CSE IITD Other Architectures & Examples Multithreaded architectures Dataflow architectures Multiprocessor examples 1 st May, 2006.
Computer Organization CDA 3103 Dr. Hassan Foroosh Dept. of Computer Science UCF © Copyright Hassan Foroosh 2002.
Lecture on Central Process Unit (CPU)
Von Neumann Computers Article Authors: Rudolf Eigenman & David Lilja
EKT303/4 Superscalar vs Super-pipelined.
Question What technology differentiates the different stages a computer had gone through from generation 1 to present?
March 4, 2008http://csg.csail.mit.edu/arvindDF3-1 Dynamic Dataflow Arvind Computer Science & Artificial Intelligence Lab Massachusetts Institute of Technology.
December 5, 2006http://csg.csail.mit.edu/6.827/L22-1 Dynamic Dataflow Arvind Computer Science & Artificial Intelligence Lab Massachusetts Institute of.
Computer Organization Instructions Language of The Computer (MIPS) 2.
Computer Architecture Dataflow Machines Sunset over Lifou, New Caledonia.
Autumn 2006CSE P548 - Dataflow Machines1 Von Neumann Execution Model Fetch: send PC to memory transfer instruction from memory to CPU increment PC Decode.
Chapter 11 System Performance Enhancement. Basic Operation of a Computer l Program is loaded into memory l Instruction is fetched from memory l Operands.
Computer Architecture: Dataflow (Part I) Prof. Onur Mutlu Carnegie Mellon University.
Advanced Architectures
Processes and threads.
Dataflow Machines CMPE 511
Instruction Level Parallelism
Prof. Onur Mutlu Carnegie Mellon University
Fall 2012 Parallel Computer Architecture Lecture 22: Dataflow I
CS203 – Advanced Computer Architecture
Introduction to Computer Engineering
Pipelining: Advanced ILP
Superscalar Processors & VLIW Processors
Lecture 4: MIPS Instruction Set
Dataflow Models.
Dataflow: Passing the Token
Lecture 7: Dynamic Scheduling with Tomasulo Algorithm (Section 2.4)
Topic B (Cont’d) Dataflow Model of Computation
CS510 Operating System Foundations
Dataflow Model of Computation (From Dataflow to Multithreading)
How does the CPU work? CPU’s program counter (PC) register has address i of the first instruction Control circuits “fetch” the contents of the location.
Lecture 4: Instruction Set Design/Pipelining
Lecture 5: Pipeline Wrap-up, Static ILP
Information Representation: Machine Instructions
COMPUTER ORGANIZATION AND ARCHITECTURE
Samira Khan University of Virginia Jan 23, 2019
Advanced Computer Architecture Dataflow Processing
Introduction to Computer Engineering
Introduction to Computer Engineering
Introduction to Computer Engineering
Prof. Onur Mutlu Carnegie Mellon University
Prof. Onur Mutlu Carnegie Mellon University
Chapter 4 The Von Neumann Model
Presentation transcript:

March 4, 2008 DF5-1http://csg.csail.mit.edu/arvind/ The Monsoon Project Arvind Computer Science & Artificial Intelligence Lab Massachusetts Institute of Technology

March 4, 2008 DF5-2http://csg.csail.mit.edu/arvind/ Static - mostly for signal processing NEC - NEDIP and IPP Hughes, Hitachi, AT&T, Loral, TI, Sanyo M.I.T. Engineering model... Dynamic Manchester (‘81) M.I.T. - TTDA, Monsoon (‘88) M.I.T./Motorola - Monsoon (‘91) (8 PEs, 8 IS) ETL - SIGMA-1 (‘88) (128 PEs,128 IS) ETL - EM4 (‘90) (80 PEs), EM-X (‘96) (80 PEs) Sandia - EPS88, EPS-2 IBM - Empire... Dataflow Machines Related machines: Burton Smith’s Denelcor HEP, Horizon, Tera Shown at Supercomputing 96 Shown at Supercomputing 91 S. Sakai Y. Kodama EM4: single-chip dataflow micro, 80PE multiprocessor, ETL, Japan K. Hiraki T. Shimada Sigma-1: The largest dataflow machine, ETL, Japan John Gurd Greg Papadopoulos Monsoon Andy Boughton Chris Joerg Jack Costanza

March 4, 2008 DF5-3http://csg.csail.mit.edu/arvind/ Outline Static Dataflow Machines Not general-purpose enough Dynamic Dataflow Machines As easy to build as a simple pipelined processor The software view The memory model: I-structures Monsoon and its performance

March 4, 2008 DF5-4http://csg.csail.mit.edu/arvind/ Dataflow Graphs {x = a + b; y = b * 7 in (x-y) * (x+y)} a b +*7 -+ * y x Values in dataflow graphs are represented as tokens An operator executes when all its input tokens are present; copies of the result token are distributed to the destination operators token instruction ptr portdata ip = 3 p = L no separate control flow

March 4, 2008 DF5-5http://csg.csail.mit.edu/arvind/ Static Dataflow Machine: Instruction Templates Each arc in the graph has a operand slot in the program a b +*7 -+ * y x Destination 1 Destination 2 Presence bits L 4L * 3R 4R - 5L + 5R * out Opcode Operand 1Operand 2

March 4, 2008 DF5-6http://csg.csail.mit.edu/arvind/ Static Dataflow Machine Jack Dennis, 1973, Many such processors can be connected together Programs can be statically divided among the processor Receive Send FU Op dest1 dest2 p1 src1 p2 src2 Instruction Templates

March 4, 2008 DF5-7http://csg.csail.mit.edu/arvind/ Static Dataflow: Problems/Limitations Mismatch between the model and the implementation The model requires unbounded FIFO token queues per arc but the architecture provides storage for one token per arc The architecture does not ensure FIFO order in the reuse of an operand slot The merge operator has a unique firing rule The static model does not support Function calls Data Structures - No easy solution in the static framework - Dynamic dataflow provided a framework for solutions

March 4, 2008 DF5-8http://csg.csail.mit.edu/arvind/ Outline Static Dataflow Machines  Not general-purpose enough Dynamic Dataflow Machines  As easy to build as a simple pipelined processor The software view The memory model: I-structures Monsoon and its performance

March 4, 2008 DF5-9http://csg.csail.mit.edu/arvind/ Dynamic Dataflow Architectures Allocate instruction templates, i.e., a frame, dynamically to support each loop iteration and procedure call termination detection needed to deallocate frames The code can be shared if we separate the code and the operand storage frame pointer instruction pointer a token

March 4, 2008 DF5-10http://csg.csail.mit.edu/arvind/ A Frame in Dynamic Dataflow Program * L, 4L 3R, 4R 5L 5R out * a b +*7 -+ * y x Need to provide storage for only one operand/operator Frame

March 4, 2008 DF5-11http://csg.csail.mit.edu/arvind/ Monsoon Processor Greg Papadopoulos Instruction Fetch Operand Fetch ip fp+r Network Frames op rd1,d2 Code Form Token ALU Token Queue

March 4, 2008 DF5-12http://csg.csail.mit.edu/arvind/ Temporary Registers & Threads Robert Iannucci Registers evaporate when an instruction thread is broken n sets of registers (n = pipeline depth) Instruction Fetch Operand Fetch Network Frames op rS1,S2 Code Form Token ALU Token Queue Registers Registers are also used for exceptions & interrupts Robert Iannucci

March 4, 2008 DF5-13http://csg.csail.mit.edu/arvind/ Actual Monsoon Pipeline: Eight Stages Instruction Fetch Form Token System Queue Registers Network Instruction Memory Effective Address Presence Bit Operation Frame Operation Presence bits Frame Memory User Queue R, 2W ALU

March 4, 2008 DF5-14http://csg.csail.mit.edu/arvind/ Instructions directly control the pipeline The opcode specifies an operation for each pipeline stage: opcode r dest1 [dest2] EA - effective address FP + r: frame relative r: absolute IP + r: code relative (not supported) WM - waiting matching Unary; Normal; Sticky; Exchange; Imperative PBs X port  PBs X Frame op X ALU inhibit Register ops: ALU: V L X V R  V’ L X V’ R, CC Form token: V L X V R X Tag 1 X Tag 2 X CC  Token 1 X Token 2 EA WM RegOp ALU FormToken Easy to implement; no hazard detection

March 4, 2008 DF5-15http://csg.csail.mit.edu/arvind/ Procedure Linkage Operators f get frame extract tag change Tag 0 Graph for f change Tag 1 a1 1: change Tag n an n:... change Tag 1 Fork token in frame 0 token in frame 1 Like standard call/return but caller & callee can be active simultaneously

March 4, 2008 DF5-16http://csg.csail.mit.edu/arvind/ Data Structures in Dataflow.. P P Memory Data structures reside in a structure store  tokens carry pointers I-structures: Write-once, Read multiple times or allocate, write, read,..., read, deallocate  No problem if a reader arrives before the writer at the memory location I-fetch a I-store a v

March 4, 2008 DF5-17http://csg.csail.mit.edu/arvind/ I-Structure Storage: Split-phase operations & Presence bits I-Fetch t s a a a a v2v2 fp.ip I-structure Memory Need to deal with multiple deferred reads other operations: fetch/store, take/put, clear  v1v1 address to be read t I-Fetch s split phase forwarding address

March 4, 2008 DF5-18http://csg.csail.mit.edu/arvind/ Outline Static Dataflow Machines  Not general-purpose enough Dynamic Dataflow Machines  As easy to build as a simple pipelined processor The software view  The memory model: I-structures Monsoon and its performance

March 4, 2008 DF5-19http://csg.csail.mit.edu/arvind/ Parallel Language Model Global Heap of Shared Objects Tree of Activation Frames h:g: f: loop active threads asynchronous and parallel at all levels

March 4, 2008 DF5-20http://csg.csail.mit.edu/arvind/ Dataflow Graphs + I-Structures +... TTDA Monsoon *T *T-Voyager Id World implicit parallelism Id

March 4, 2008 DF5-21http://csg.csail.mit.edu/arvind/ Id World people Rishiyur Nikhil, Keshav Pingali, Vinod Kathail, David Culler Ken Traub Steve Heller, Richard Soley, Dinart Mores Jamey Hicks, Alex Caro, Andy Shaw, Boon Ang Shail Anditya R Paul Johnson Paul Barth Jan Maessen Christine Flood Jonathan Young Derek Chiou Arun Iyangar Zena Ariola Mike Bekerle K. Eknadham (IBM), Wim Bohm (Colorado), Joe Stoy (Oxford),... Steve Heller Ken TraubR.S. Nikhil Keshav Pingali David Culler Boon S. AngDerek ChiouJamey Hicks

March 4, 2008 DF5-22http://csg.csail.mit.edu/arvind/ Id Applications on MIT Numerical Hydrodynamics - SIMPLE Global Circulation Model - GCM Photon-Neutron Transport code -GAMTEB N-body problem Symbolic Combinatorics - free tree matching,Paraffins Id-in-Id compiler System I/O Library Heap Storage Allocator on Monsoon Fun and Games Breakout Life Spreadsheet

March 4, 2008 DF5-23http://csg.csail.mit.edu/arvind/ Id Run Time System (RTS) on Monsoon Frame Manager: Allocates frame memory on processors for procedure and loop activations Derek Chiou Heap Manager: Allocates storage in I-Structure memory or in Processor memory for heap objects. Arun Iyengar

March 4, 2008 DF5-24http://csg.csail.mit.edu/arvind/ Unix Box The Monsoon Project Motorola Cambridge Research Center + MIT MIT-Motorola collaboration Research Prototypes 16 2-node systems (MIT, LANL, Motorola, Colorado, Oregon, McGill, USC,...) 2 16-node systems (MIT, LANL) Id World Software I-structure Monsoon Processor 64-bit 10M tokens/sec 4M 64-bit words 100 MB/sec 16-node Fat Tree Tony Dahbura

March 4, 2008 DF5-25http://csg.csail.mit.edu/arvind/ Single Processor Monsoon Performance Evolution One 64-bit processor (10 MHz) + 4M 64-bit I-structure Feb. 91Aug. 91 Mar. 92Sep. 92 Matrix Multiply 4:04 3:58 3:55 1:46 500x500 Wavefront 5:00 5:00 3:48 500x500, 144 iters. Paraffins n = 19 :50 :31 :02.4 n = 22 :32 GAMTEB-9C 40K particles 17:20 10:42 5:36 5:36 1M particles 7:13:20 4:17:142:36:00 2:22:00 SIMPLE iterations :19 :15 :10 :06 1K iterations 4:48:00 1:19:49 hours:minutes:seconds Need a real machine to do this

March 4, 2008 DF5-26http://csg.csail.mit.edu/arvind/ Monsoon Speed Up Results Boon Ang, Derek Chiou, Jamey Hicks Matrix Multiply 500 x 500 Paraffins n=22 GAMTEB-2C 40 K particles SIMPLE iters 1pe pe pe pe pe pe pe pe speed up critical path (millions of cycles) September, 1992 Could not have asked for more

March 4, 2008 DF5-27http://csg.csail.mit.edu/arvind/ Base Performance? Id on Monsoon vs. C / F77 on R3000 Monsoon (1pe) (x 10e6 cycles) MIPS (R3000) (x 10e6 cycles) * 1787 * Matrix Multiply 500 x 500 Paraffins n=22 GAMTEB-9C 40 K particles SIMPLE iters R3000 cycles collected via Pixie * Fortran 77, fully optimized + MIPS C, O = 3 64-bit floating point used in Matrix-Multiply, GAMTEB and SIMPLE MIPS codes won’t run on a parallel machine without recompilation/recoding 8-way superscalar? Unlikely to give 7 fold speedup

March 4, 2008 DF5-28http://csg.csail.mit.edu/arvind/ The Monsoon Experience Performance of implicitly parallel Id programs scaled effortlessly. Id programs on a single-processor Monsoon took 2 to 3 times as many cycles as Fortran/C on a modern workstation. Can certainly be improved Effort to develop the invisible software (loaders, simulators, I/O libraries,....) dominated the effort to develop the visible software (compilers...)