Architectures. Michael Doggett Department of Computer Science Lund University 2009 Tomas Akenine-Möller and Michael Doggett 1

Similar documents
Monday Morning. Graphics Hardware

Graphics Hardware. Ulf Assarsson. Graphics hardware why? Recall the following. Perspective-correct texturing

Graphics Architectures and OpenCL. Michael Doggett Department of Computer Science Lund university

PowerVR Hardware. Architecture Overview for Developers

GPU Architecture. Michael Doggett Department of Computer Science Lund university

Graphics Processing Unit Architecture (GPU Arch)

Performance Analysis and Culling Algorithms

Parallelizing Graphics Pipeline Execution (+ Basics of Characterizing a Rendering Workload)

Spring 2011 Prof. Hyesoon Kim

POWERVR MBX. Technology Overview

Challenges for GPU Architecture. Michael Doggett Graphics Architecture Group April 2, 2008

Parallelizing Graphics Pipeline Execution (+ Basics of Characterizing a Rendering Workload)

Spring 2009 Prof. Hyesoon Kim

Real-Time Buffer Compression. Michael Doggett Department of Computer Science Lund university

Power Efficiency for Software Algorithms running on Graphics Processors. Björn Johnsson Per Ganestam Michael Doggett Tomas Akenine-Möller

Course Recap + 3D Graphics on Mobile GPUs

Optimizing DirectX Graphics. Richard Huddy European Developer Relations Manager

Spring 2010 Prof. Hyesoon Kim. AMD presentations from Richard Huddy and Michael Doggett

CS427 Multicore Architecture and Parallel Computing

Optimizing for DirectX Graphics. Richard Huddy European Developer Relations Manager

Scheduling the Graphics Pipeline on a GPU

Introduction to Multicore architecture. Tao Zhang Oct. 21, 2010

Next-Generation Graphics on Larrabee. Tim Foley Intel Corp

Real - Time Rendering. Graphics pipeline. Michal Červeňanský Juraj Starinský

PowerVR Series5. Architecture Guide for Developers

Bringing AAA graphics to mobile platforms. Niklas Smedberg Senior Engine Programmer, Epic Games

X. GPU Programming. Jacobs University Visualization and Computer Graphics Lab : Advanced Graphics - Chapter X 1

GeForce4. John Montrym Henry Moreton

Multimedia in Mobile Phones. Architectures and Trends Lund

The Rasterization Pipeline

Lecture 25: Board Notes: Threads and GPUs

Optimisation. CS7GV3 Real-time Rendering

Squeezing Performance out of your Game with ATI Developer Performance Tools and Optimization Techniques

Graphics Hardware. Instructor Stephen J. Guy

GPU Architecture and Function. Michael Foster and Ian Frasch

Case 1:17-cv SLR Document 1-3 Filed 01/23/17 Page 1 of 33 PageID #: 60 EXHIBIT C

Graphics Hardware, Graphics APIs, and Computation on GPUs. Mark Segal

Programming Graphics Hardware

CSE 591: GPU Programming. Introduction. Entertainment Graphics: Virtual Realism for the Masses. Computer games need to have: Klaus Mueller

Graphics Hardware. Graphics Processing Unit (GPU) is a Subsidiary hardware. With massively multi-threaded many-core. Dedicated to 2D and 3D graphics

Lecture 9: Deferred Shading. Visual Computing Systems CMU , Fall 2013

Could you make the XNA functions yourself?

CS8803SC Software and Hardware Cooperative Computing GPGPU. Prof. Hyesoon Kim School of Computer Science Georgia Institute of Technology

GPU Computation Strategies & Tricks. Ian Buck NVIDIA

Hardware-driven visibility culling

Evolution of GPUs Chris Seitz

A SIMD-efficient 14 Instruction Shader Program for High-Throughput Microtriangle Rasterization

CONSOLE ARCHITECTURE

Optimizing Games for ATI s IMAGEON Aaftab Munshi. 3D Architect ATI Research

Introduction to Modern GPU Hardware

Windowing System on a 3D Pipeline. February 2005

CS451Real-time Rendering Pipeline

Real-Time Rendering (Echtzeitgraphik) Michael Wimmer

A Trip Down The (2011) Rasterization Pipeline

CSE 591/392: GPU Programming. Introduction. Klaus Mueller. Computer Science Department Stony Brook University

This Unit: Putting It All Together. CIS 501 Computer Architecture. What is Computer Architecture? Sources

POWERVR MBX & SGX OpenVG Support and Resources

Hardware-driven Visibility Culling Jeong Hyun Kim

Unit 11: Putting it All Together: Anatomy of the XBox 360 Game Console

Real-World Applications of Computer Arithmetic

Mattan Erez. The University of Texas at Austin

Scanline Rendering 2 1/42

Real - Time Rendering. Pipeline optimization. Michal Červeňanský Juraj Starinský

GPU-Based Volume Rendering of. Unstructured Grids. João L. D. Comba. Fábio F. Bernardon UFRGS

A Reconfigurable Architecture for Load-Balanced Rendering

Cornell University CS 569: Interactive Computer Graphics. Introduction. Lecture 1. [John C. Stone, UIUC] NASA. University of Calgary

ECE 574 Cluster Computing Lecture 16

AMD Radeon HD 2900 Highlights

PowerVR Performance Recommendations. The Golden Rules

Threading Hardware in G80

Mali-400 MP: A Scalable GPU for Mobile Devices Tom Olson

This Unit: Putting It All Together. CIS 371 Computer Organization and Design. Sources. What is Computer Architecture?

Lecture 6: Texture. Kayvon Fatahalian CMU : Graphics and Imaging Architectures (Fall 2011)

CS GPU and GPGPU Programming Lecture 2: Introduction; GPU Architecture 1. Markus Hadwiger, KAUST

3D Computer Games Technology and History. Markus Hadwiger VRVis Research Center

Mobile HW and Bandwidth

This Unit: Putting It All Together. CIS 371 Computer Organization and Design. What is Computer Architecture? Sources

Optimizing and Profiling Unity Games for Mobile Platforms. Angelo Theodorou Senior Software Engineer, MPG Gamelab 2014, 25 th -27 th June

Antonio R. Miele Marco D. Santambrogio

Graphics Performance Optimisation. John Spitzer Director of European Developer Technology

Lecture 6: Texturing Part II: Texture Compression and GPU Latency Hiding Mechanisms. Visual Computing Systems CMU , Fall 2014

Lecture 7: The Programmable GPU Core. Kayvon Fatahalian CMU : Graphics and Imaging Architectures (Fall 2011)

ASYNCHRONOUS SHADERS WHITE PAPER 0

Tutorial on GPU Programming #2. Joong-Youn Lee Supercomputing Center, KISTI

A Bandwidth Effective Rendering Scheme for 3D Texture-based Volume Visualization on GPU

2.11 Particle Systems

Efficient and Scalable Shading for Many Lights

Beyond Programmable Shading Keeping Many Cores Busy: Scheduling the Graphics Pipeline

Case 1:17-cv SLR Document 1-4 Filed 01/23/17 Page 1 of 30 PageID #: 75 EXHIBIT D

The NVIDIA GeForce 8800 GPU

The Bifrost GPU architecture and the ARM Mali-G71 GPU

EECS 487: Interactive Computer Graphics

CENG 477 Introduction to Computer Graphics. Graphics Hardware and OpenGL

PowerVR Performance Recommendations The Golden Rules. October 2015

1.2.3 The Graphics Hardware Pipeline

Portland State University ECE 588/688. Graphics Processors

Pipeline Operations. CS 4620 Lecture 14

Anatomy of AMD s TeraScale Graphics Engine

What Next? Kevin Walsh CS 3410, Spring 2010 Computer Science Cornell University. * slides thanks to Kavita Bala & many others

CS4620/5620: Lecture 14 Pipeline

Transcription:

Architectures Michael Doggett Department of Computer Science Lund University 2009 Tomas Akenine-Möller and Michael Doggett 1

Overview of today s lecture The idea is to cover some of the existing graphics architectures (for mobile platforms) Extremely little is known to the public General info about graphics architectures XBOX Traditional straight pipeline But slowly disappearing non-unified architecture Tiling architectures [different from tiled rasterization!] Kyro (PC-architecture) Popular for mobile architectures where bandwidth and memory are limited ATI Bitboys architecture Unified shaders XBOX 360 High end PC graphics ATI Radeon 2900, 4870, 5870 2009 Tomas Akenine-Möller and Michael Doggett 2

Graphics Processing Unit GPU How to turn millions of triangles into pixels in 1/60 of a second? Parallelism!! Pipelining Single Instruction Multiple Data (SIMD) Memory Bandwidth reductions (covered previously) Data 0 Data 1 Data 2 Data 3 1 Instruction PU PU PU PU 4-wide

GPU Pipeline New surface tessellation stages Surface Surface Programmable shaders SIMDs Vertices Shaders Vertex Transform shader Rasterization 2001 -- Radeon 8500 (R200) 2-wide Vertex shader 4-wide SIMD Pixel shader 2002 -- Radeon 9700 (R300) 4-wide Vertex shader 8-wide SIMD Pixel shader 4 Textures Shaders Image Pixel Texturing shader Z & Alpha FrameBuffer

Briefly about pipelining In GeForce3: 600-800 pipeline stages! 57 million transistors Pentium IV: 20 stages, 42 million transistors Some desktop graphics cards: GeForce FX 5800: 125 M transistors, 500 MHz 2005: GeForce FX 7800: 302 M transistors, 430 MHz 2007: ATI Radeon 2900, 700 M transistors, 740 MHz 2009: ATI Radeon 5870, 2154 M transistors, 850 MHz Ideally: n stages n times throughput But latency increases! However, not a problem here Chip runs at, say, 200 MHz (5ns per clock) 5ns*700stages=3.5 µs We got about 20 ms per frame (50 frames per second) Graphics hardware is simpler to pipeline because: Pixels are independent of each other Few branches and much fixed functionality Don t need that high clock freq: bandwidth to memory is often bottleneck This is changing with increased programmability though Simpler to predict memory access pattern (do prefecthing!) 2009 Tomas Akenine-Möller and Michael Doggett 5

Parallelism Simple idea: compute n results in parallel, then combine results GeForce FX 5800: 8 pixels/clock, 16 textures/clock With a pipeline of several 100 stages, there are many pixels being processed simultaneously This does not apply directly to mobiles, though Not always simple! Try to parallelize a sorting algorithm But pixels are independent of each other, so simpler for graphics hardware Can parallelize both geometry (vertex) and rasterizer (pixel): 2009 Tomas Akenine-Möller and Michael Doggett 6

Taxonomy of hardware Need to sort from model space to screen space Gives four major architectures: Sort-first Sort-middle Sort-Last Fragment Sort-Last Image Will describe these briefly, and then focus on sort-middle and sort-last fragment (used in commercial hardware) 2009 Tomas Akenine-Möller and Michael Doggett 7

Sort-First Sorts primitives before geometry stage Screen in divided into large regions A separate pipeline is responsible for each region (or many) G is geometry, FG & FM is part of rasterizer A fragment is all the generated information for a pixel on a triangle FG is Fragment Generation (finds which pixels are inside triangle) FM is Fragment Merge (merges the created fragments with various buffers (Z, color)) Not explored much at all kind of weird architecture - poor load balancing 2009 Tomas Akenine-Möller and Michael Doggett 8

Sort-Middle Sorts betwen G and R Pretty natural, since after G, we know the screen-space positions of the triangles Spread work arbitrarily among G s Then depending on screen-space position, sort to different R s Screen can be split into tiles. For example: Rectangular blocks (e.g., 4x4 pixels) Every n scanlines The R is responsible for rendering inside tile A triangle can be sent to many FG s depending on overlap (over tiles) 2009 Tomas Akenine-Möller and Michael Doggett 9

Sort-Last Fragment Sorts betwen FG and FM XBOX uses this! Again spread work among G s The generated work is sent to FG s Then sort fragments to FM s An FM is responsible for a tile of pixels A triangle is only sent to one FG, so this avoids doing the same work twice Sort-Middle: If a triangle overlaps several tiles, then the triangle is sent to all FG s responsible for these tiles Results in extra work 2009 Tomas Akenine-Möller and Michael Doggett 10

Sort-Last Image Sorts after entire pipeline So each FG & FM has a separate frame buffer for entire screen (Z and color) After all primitives have been sent to pipeline, the z-buffers and color buffers are merged into one color buffer Can be seen as a set of independent pipelines Huge memory requirements! Used in research, but probably not commercially 2009 Tomas Akenine-Möller and Michael Doggett 11

Taxonomy why? Good to know if you want to discuss what type of architecture a company want to sell to you Good to know if you want to build your own architecture What are the advantages/disadvantages of each... 2009 Tomas Akenine-Möller and Michael Doggett 12

The Xbox game console Built by Microsoft and NVIDIA Is almost a PC: Pentium III, 733 MHz An extended GeForce3 Why talk about it here? It resembles some mobile architectures a bit, and there is information available... 2009 Tomas Akenine-Möller and Michael Doggett 13

Xbox is a UMA machine UMA = unified memory architecture Every component in the system accesses the same memory We focus on the GPU Many mobile graphics architectures are UMA as well 2009 Tomas Akenine-Möller and Michael Doggett 14

Xbox Graphics Processing Unit Supports programmable vertex shaders No fixed-function geometry stage Is sort-last fragment architecture Rasterizer: handles four pixels per clock Runs at 250 MHz Imagine this is a programmable fragment shader unit, and we have a pretty modern architecture 2009 Tomas Akenine-Möller and Michael Doggett 15

Xbox geometry stage Dual vertex shaders Same vertex program is executed on two vertices in parallell Vertex shader unit is a SIMD machine that operates on 4 components at a time The point is that instead of a fixed function geometry stage, we have now full control over animation of vertices and lighting etc. Uses DMA (direct memory access), so that the GPU fetches vertices directly from memory by itself! Three different caches for better performance! 2009 Tomas Akenine-Möller and Michael Doggett 16

Xbox rasterizer First block: triangle setup (TS) and FG TS computes various deltas and other startup info This block also does Z-occlusion testing FG generates fragments inside triangles Tests 2x2 pixels at a time, and forwards these to the four pipelines that follow Note: near edges, not all pixels are inside triangles, and therefore 0-3 pipelines may be idle There are many strategies on how to find which fragments are inside triangle, but exactly how this is done on the XBOX is not known 2009 Tomas Akenine-Möller and Michael Doggett 17

Xbox rasterizer Sorting is done after FG Sort-last fragment arch. First: 2 texture units Can be run twice 4 texture lookups sort Assume TX+RC+Combiner is a Programmable Fragment Shader Unit The Xbox only had little flexibility there... Register Combiners (programmable) Finally, result from TXs, RCs, shading interpolation, fog interpolation is merged into a final color for that pixel 2009 Tomas Akenine-Möller and Michael Doggett 18

Xbox rasterizer: Fragment merge The combiner produced a final color for the pixel on a triangle FG merges this with: Color in color buffer (alpha blending) Respect to Z-buffer Stencil testing Alpha testing Z-compression and decompression is handled here as well Writes final color over the system memory bus 2009 Tomas Akenine-Möller and Michael Doggett 19

Questions on XBOX? 2009 Tomas Akenine-Möller and Michael Doggett 20

Tiling architectures There is an ongoing battle between traditional architectures (what we ve looked at so far) and tiling architectures Which is best? Depends... Sort-Middle architecture! 2009 Tomas Akenine-Möller and Michael Doggett 21

Examples of existing tiling architectures Imagination technologies Kyro II (PC graphics card) Sega Dreamcast PowerVR MBX (for mobiles) PowerVR SGX (for mobiles) Falanx (Norway) [now owned by ARM] Mali architectures For mobiles as well Intel Larrabee Software Tiled based rasterizer Coming soon... 2009 Tomas Akenine-Möller and Michael Doggett 22

Tiling: basic idea (1) Apply vertex shader (incl. projection) to B vertices A Create a triangle list for each tile Holds pointers to all triangles overlapping a tile A B C D E D E C F F 2009 Tomas Akenine-Möller and Michael Doggett 23

Tiling: basic idea (2) A B C D E F Process one tile at a time, and rasterize triangles in tile s triangle list On-chip buffers (color, depth, etc) Screen color buffer Start with tile A s triangles When all triangles in list have been processed, copy on-chip color buffer to screen color buffer Need to write out depth buffer as well! Because, the programmer may want to access it 2009 Tomas Akenine-Möller and Michael Doggett 24

Tiling: basic idea (3) A B C D E F B A C D F E Screen color buffer On-chip buffers (color, depth, etc) Then tile B s triangles When all triangles in list have been processed, copy on-chip color buffer to screen color buffer 2009 Tomas Akenine-Möller and Michael Doggett 25

Tiling: basic idea (4) A B C D E F B A C D F E Screen color buffer On-chip buffers (color, depth, etc) Then tile C s triangles When all triangles in list have been processed, copy on-chip color buffer to screen color buffer AND SO ON... 2009 Tomas Akenine-Möller and Michael Doggett 26

KYRO a PowerVR-based tiling architecture For KYRO II: tile=32x16 pixels Tiling advantage: can implement temporary color, stencil, and Z-buffer in fast on-chip memory for a single tile Saves memory and memory bandwidth! Claims to save 2/3 of bandwidth compared to traditional architecture (without Z- occlusion testing, no buffer compression...) 2009 Tomas Akenine-Möller and Michael Doggett 27

KYRO architecture overview CPU sends triangle data to KYRO II Tile Accelerator (TA) Needs an entire scene before ISP and TSP blocks can start So TA works on the next image, while ISP and TSP works on the current image (i.e., they work in a pipelined fashion) TA sorts triangles, and creates a list of triangle pointers for each tile (for tris inside tile) 2009 Tomas Akenine-Möller and Michael Doggett 28

KYRO Tile accelerator: When all triangles for entire scene are sorted into tiles, the TA can send tile data to next block: ISP And the TA then continues on the next frame s sorting in parallel Image synthesis processor (ISP): Implements Z-buffer, color buffer, stencil buffer for tile Depth testing: Test 32 pixels at a time against Z-buffer Records which pixels are visible Groups pixels with same texture and sends to TSP These are guaranteed to be visible, so we only texture each pixel once 2009 Tomas Akenine-Möller and Michael Doggett 29

KYRO: TSP Texture and Shading Processor (TSP): Handles texturing and shading interpolation Has two pipelines that run in parallel 2 pixels per clock Can use 8 textures at most Is implemented by looping in TSP Texture data is fetched from local memory Supersampling: 2x1, 1x2, and 2x2 Renders a larger image and filters and scales down For 2x2: Need only 4x the size of tile (or rather, render 4x as many tiles, i.e., need not 4x memory) 2009 Tomas Akenine-Möller and Michael Doggett 30

PowerVR MBX and SGX Kyro was for the PC market... MBX and SGX are designed for the mobile market Tiling: creates depth buffer first, then applies pixel shader Does not apply pixel-shader for hidden fragments: called deferred shading Uses PVR Texture Compression SGX (newest): uses unified shaders Programmable vertex and pixel shaders 2009 Tomas Akenine-Möller and Michael Doggett 31

Traditional vs Tiling 2009 Tomas Akenine-Möller and Michael Doggett 32

Falanx Mali Architecture Tiling architecture (tile size=16x16) Does not create Z-buffer first, and then apply pixel shader (as do PowerVR) Instead two other techniques to reduce BW: Efficient Zmax-culling Eliminates ~50% of occluded pixels [this varies, of course...] 2 bits-per-pixel texture compression (FLXTC) Plus fantastic antialiasing (more about that next lecture) 2009 Tomas Akenine-Möller and Michael Doggett 33

Questions on tiling architectures? 2009 Tomas Akenine-Möller and Michael Doggett 34

Bitboys G40 architecture Not a tiling architecture Bitboys, bought by ATI, ATI bought by AMD, AMD sold handheld graphics to Qualcomm 2009 Tomas Akenine-Möller and Michael Doggett 35

2009 Tomas Akenine-Möller and Michael Doggett 36

2009 Tomas Akenine-Möller and Michael Doggett 37

What can we expect? 2009 Tomas Akenine-Möller and Michael Doggett 38

To tile or not to tile? (1) Tiling: Good: Uses a small amount of very fast memory 16x16x (4 (color) + 4 (depth) + 1 (stencil))=2304 bytes Bandwidth to z-buffer, color buffer, stencil for free Design is parallel (add more pipes) Bad: More local memory is needed (for tile sorting) Bandwidth increase since geometry needs sorting State changes: what happens when you need to switch from one long pixel-shader program to another? (several times per tile...) Harder to predict performance A triangle covering several tiles, is processed several times E.g., triangle setup... Ugly: Amount of local memory places a limit on how many triangles can be rendered Overflow? 3 MB can handle a little over 30,000 triangles (info from Kyro II) 2009 Tomas Akenine-Möller and Michael Doggett 39

Traditional: Good: To tile or not to tile? (2) More straightforward to implement Easier to predict performance Other bandwidth reduction techniques can be used (buffer compression, zmin/zmax-culling, e.g.) No (big) problems with state changes Bad: Cannot have the entire framebuffer in on-chip memory Buffer accesses costs! Have to execute pixel shader unnecessarily for some occluded fragments [but Zmax/Pre-Z pass can help] Ugly: Too traditional not that exotic... 2009 Tomas Akenine-Möller and Michael Doggett 40

To tile or not to tile? (3) Who knows? Definitely scene-dependent! 2009 Tomas Akenine-Möller and Michael Doggett 41

Unified shader architecture First on XBOX 360 (2005) DirectX10 uses unified shader model All PC graphics unified from Radeon 2xxx and GeForce 8xxx up iphone s PowerVR SGX Made possible since vertex shaders and fragment shader instruction set converged Basic idea: Have n unified shader units Can be used for either vertices or fragments Why? Load balancing! Increasing vertex processing 2009 Tomas Akenine-Möller and Michael Doggett 42

Unified Shader: XBOX 360 48 unified shader units e.g 16 used for vertices, and 32 for fragments Scheduling is dynamic Split depends on what is being rendered Consequence: can run at ~100% efficiency all the time, rather than having some pipeline instructions waiting for others Non-unified shader pipeline based high-end PC chips can run at 50-60% efficiency. 2009 Tomas Akenine-Möller and Michael Doggett 43

Unified shaders Sequencer s goal: Keep all 48 unified shader units busy ~100% of the time in the most efficient way possible. Threads are grouped in sets of 64 and run together If a thread needs to wait for data, another thread can be processed and sent to the unified shader units. XBOX 360 2009 Tomas Akenine-Möller and Michael Doggett 44

ATI Radeon 2900 (R600) Merge the XBOX360 unified shader with X1800 (R520) series Support Microsoft s DirectX Direct3D 10 Unified shader language New Geometry Shader pipeline stage Supported on mobiles chips Launched 2007

R600 Top Level Red Compute Rasterizer Yellow Cache Unified shader Thread Scheduler Shader R/W Instr./Const. cache Unified texture cache Compression 4 SIMDs 16 Vector Units per SIMD 5 ALUs per Vector Unit Unified Texture Cache L2 256KB L1 32KB Z + Blend 46 August 2007 Radeon HD 2900

ATI Radeon 4800 Series Architecture 10 SIMDs 1.2 teraflops = 10 SIMDs x 16 ALUs x 5 (32bit FP) x 2ops (muladd) x 750MHz 47 Radeon 4800

Radeon 4800 Series (R770) Launched 2008 260mm 2 956 MTransistors 48 Radeon 4800

Radeon 4800 Series Launched 2008 260mm 2 956 MTransistors 64 z/stencil 40 texture 10 SIMDs Increasingly larger percentage of chip 49 Radeon 4800

ATI Radeon 5870 (R800) Released 23 September 2009 First Direct3D 11 GPU 2 x 10 SIMDs

ATI Radeon Rasterizer 5870 Rasterizer L2 Cache 128KB L2 Cache 128KB L2 Cache 128KB L2 Cache 128KB from http:// www.anandtech.com/ video/showdoc.aspx? i=3643&p=5

Intel s Larrabee n (16-32) Pentiums with 16 wide 32bit SIMD 1024 bit ring bus

The end 2009 Tomas Akenine-Möller and Michael Doggett 53