Graphics Core Next

From HandWiki
Short description: Series of microarchitectures and instruction set architecture by AMD

Graphics Core Next (GCN)[1] is the codename for a series of microarchitectures and an instruction set architecture that were developed by AMD for its GPUs as the successor to its TeraScale microarchitecture. The first product featuring GCN was launched on January 9, 2012.[2]

GCN is a reduced instruction set SIMD microarchitecture contrasting the very long instruction word SIMD architecture of TeraScale.[3] GCN requires considerably more transistors than TeraScale, but offers advantages for general-purpose GPU (GPGPU) computation due to a simpler compiler.

GCN graphics chips were fabricated with CMOS at 28 nm, and with FinFET at 14 nm (by Samsung Electronics and GlobalFoundries) and 7 nm (by TSMC), available on selected models in AMD's Radeon HD 7000, HD 8000, 200, 300, 400, 500 and Vega series of graphics cards, including the separately released Radeon VII. GCN was also used in the graphics portion of Accelerated Processing Units (APUs), including those in the PlayStation 4 and Xbox One.

Instruction set

The GCN instruction set is owned by AMD and was developed specifically for GPUs. It has no micro-operation for division.

Documentation is available for:

An LLVM compiler back end is available for the GCN instruction set.[5] It is used by Mesa 3D.

GNU Compiler Collection 9 supports GCN 3 and GCN 5 since 2019[6] for single-threaded, stand-alone programs, with GCC 10 also offloading via OpenMP and OpenACC.[7]

MIAOW is an open-source RTL implementation of the AMD Southern Islands GPGPU microarchitecture.

In November 2015, AMD announced its Boltzmann Initiative, which aims to enable the porting of CUDA-based applications to a common C++ programming model.[8]

At the Super Computing 15 event, AMD displayed a Heterogeneous Compute Compiler (HCC), a headless Linux driver and HSA runtime infrastructure for cluster-class high-performance computing, and a Heterogeneous-compute Interface for Portability (HIP) tool for porting CUDA applications to the aforementioned common C++ model.

Microarchitectures

As of July 2017, the Graphics Core Next instruction set has seen five iterations. The differences between the first four generations are rather minimal, but the fifth-generation GCN architecture features heavily modified stream processors to improve performance and support the simultaneous processing of two lower-precision numbers in place of a single higher-precision number.[9]

Command processing

GCN command processing: Each Asynchronous Compute Engines (ACE) can parse incoming commands and dispatch work to the Compute Units (CUs). Each ACE can manage up to 8 independent queues. The ACEs can operate in parallel with the graphics command processor and two DMA engines. The graphics command processor handles graphics queues, the ACEs handle compute queues, and the DMA engines handle copy queues. Each queue can dispatch work items without waiting for other tasks to complete, allowing independent command streams to be interleaved on the GPU's Shader.

Graphics Command Processor

The Graphics Command Processor (GCP) is a functional unit of the GCN microarchitecture. Among other tasks, it is responsible for the handling of asynchronous shaders.[10]

Asynchronous Compute Engine

The Asynchronous Compute Engine (ACE) is a distinct functional block serving computing purposes, whose purpose is similar to that of the Graphics Command Processor.[ambiguous]

Schedulers

Since the third iteration of GCN, the hardware contains two schedulers: one to schedule "wavefronts" during shader execution (the CU Scheduler, or Compute Unit Scheduler) and the other to schedule execution of draw and compute queues. The latter helps performance by executing compute operations when the compute units (CUs) are underutilized due to graphics commands limited by fixed function pipeline speed or bandwidth. This functionality is known as Async Compute.

For a given shader, the GPU drivers may also schedule instructions on the CPU to minimize latency.

Geometric processor

Geometry processor

The geometry processor contains a Geometry Assembler, a Tesselator, and a Vertex Assembler.

The Tesselator is capable of doing tessellation in hardware as defined by Direct3D 11 and OpenGL 4.5 (see AMD January 21, 2017),[11] and succeeded ATI TruForm and hardware tessellation in TeraScale as AMD's then-latest semiconductor intellectual property core.

Compute units

One compute unit (CU) combines 64 shader processors with 4 texture mapping units (TMUs).[12][13] The compute units are separate from, but feed into, the render output units (ROPs).[13] Each compute unit consists of the following:

  • a CU scheduler
  • a Branch & Message Unit
  • 4 16-lane-wide SIMD Vector Units (SIMD-VUs)
  • 4 64 KiB vector general-purpose register (VGPR) files
  • 1 scalar unit (SU)
  • a 4 KiB GPR file
  • a local data share of 64 KiB
  • 4 Texture Filter Units
  • 16 Texture Fetch Load/Store Units
  • a 16 KiB level 1 (L1) cache

Four Compute units are wired to share a 16KiB L1 instruction cache and a 32KiB L1 data cache, both of which are read-only. A SIMD-VU operates on 16 elements at a time (per cycle), while a SU can operate on one a time (one/cycle). In addition, the SU handles some other operations, such as branching.[14]

Every SIMD-VU has some private memory where it stores its registers. There are two types of registers: scalar registers (S0, S1, etc.), which hold 4 bytes number each, and vector registers (V0, V1, etc.), which each represent a set of 64 4-byte numbers. On the vector registers, every operation is done in parallel on the 64 numbers. which correspond to 64 inputs. For example, it may work on 64 different pixels at a time (for each of them the inputs are slightly different, and thus you get slightly different color at the end).

Every SIMD-VU has room for 512 scalar registers and 256 vector registers.

AMD has claimed that each GCN compute unit (CU) has 64 KiB Local Data Share (LDS).[15]

CU scheduler

The CU scheduler is the hardware functional block, choosing which wavefronts the SIMD-VU executes. It picks one SIMD-VU per cycle for scheduling. This is not to be confused with other hardware or software schedulers.

Wavefront

A shader is a small program written in GLSL that performs graphics processing, and a kernel is a small program written in OpenCL that performs GPGPU processing. These processes don't need that many registers, but they do need to load data from system or graphics memory. This operation comes with significant latency. AMD and Nvidia chose similar approaches to hide this unavoidable latency: the grouping of multiple threads. AMD calls such a group a "wavefront", whereas Nvidia calls it a "warp". A group of threads is the most basic unit of scheduling of GPUs that implement this approach to hide latency. It is the minimum size of the data processed in SIMD fashion, the smallest executable unit of code, and the way to processes a single instruction over all of the threads in it at the same time.

In all GCN GPUs, a "wavefront" consists of 64 threads, and in all Nvidia GPUs, a "warp" consists of 32 threads.

AMD's solution is to attribute multiple wavefronts to each SIMD-VU. The hardware distributes the registers to the different wavefronts, and when one wavefront is waiting on some result, which lies in memory, the CU Scheduler assigns the SIMD-VU another wavefront. Wavefronts are attributed per SIMD-VU. SIMD-VUs do not exchange wavefronts. A maximum of 10 wavefronts can be attributed per SIMD-VU (thus 40 per CU).

AMD CodeXL shows tables with the relationship between number of SGPRs and VGPRs to the number of wavefronts, but essentially, for SGPRS it is between 104 and 512 per number of wavefronts, and for VGPRS it is 256 per number of wavefronts.

Note that in conjunction with the SSE instructions, this concept of the most basic level of parallelism is often called a "vector width". The vector width is characterized by the total number of bits in it.

SIMD Vector Unit

Each SIMD Vector Unit has:

  • a 16-lane integer and floating point vector Arithmetic Logic Unit (ALU)
  • 64 KiB Vector General Purpose Register (VGPR) file
  • 10× 48-bit Program Counters
  • Instruction buffer for 10 wavefronts (each wavefront is a group of 64 threads, or the size of one logical VGPR)
  • A 64-thread wavefront issues to a 16-lane SIMD Unit over four cycles

Each SIMD-VU has 10 wavefront instruction buffers, and it takes 4 cycles to execute one wavefront.

Audio and video acceleration blocks

Many implementations of GCN are typically accompanied by several of AMD's other ASIC blocks. Including but not limited to the Unified Video Decoder, Video Coding Engine, and AMD TrueAudio.

Video Coding Engine

The Video Coding Engine is a video encoding ASIC, first introduced with the Radeon HD 7000 Series.[16]

The initial version of the VCE added support for encoding I and P frames H.264 in the YUV420 pixel format, along with SVE temporal encode and Display Encode Mode, while the second version added B-frame support for YUV420 and YUV444 I-frames.

VCE 3.0 formed a part of the third generation of GCN, adding high-quality video scaling and the HEVC (H.265) codec.

VCE 4.0 was part of the Vega architecture, and was subsequently succeeded by Video Core Next.

TrueAudio

Unified virtual memory

In a preview in 2011, AnandTech wrote about the unified virtual memory, supported by Graphics Core Next.[17]

Heterogeneous System Architecture (HSA)

Main page: Engineering:Heterogeneous System Architecture
GCN includes special purpose function blocks to be used by HSA. Support for these function blocks is available through amdkfd since Linux kernel 3.19.[19]

Some of the specific HSA features implemented in the hardware need support from the operating system's kernel (its subsystems) and/or from specific device drivers. For example, in July 2014, AMD published a set of 83 patches to be merged into Linux kernel mainline 3.17 for supporting their Graphics Core Next-based Radeon graphics cards. The so-called HSA kernel driver resides in the directory /drivers/gpu/hsa, while the DRM graphics device drivers reside in /drivers/gpu/drm[20] and augment the already existing DRM drivers for Radeon cards.[21] This very first implementation focuses on a single "Kaveri" APU and works alongside the existing Radeon kernel graphics driver (kgd).

Lossless Delta Color Compression

Hardware schedulers

Hardware schedulers are used to perform scheduling[22] and offload the assignment of compute queues to the ACEs from the driver to hardware, by buffering these queues until there is at least one empty queue in at least one ACE. This causes the HWS to immediately assign buffered queues to the ACEs until all queues are full or there are no more queues to safely assign.[23]

Part of the scheduling work performed includes prioritized queues which allow critical tasks to run at a higher priority than other tasks without requiring the lower priority tasks to be preempted to run the high priority task, therefore allowing the tasks to run concurrently with the high priority tasks scheduled to hog the GPU as much as possible while letting other tasks use the resources that the high priority tasks are not using.[22] These are essentially Asynchronous Compute Engines that lack dispatch controllers.[22] They were first introduced in the fourth generation GCN microarchitecture,[22] but were present in the third generation GCN microarchitecture for internal testing purposes.[24] A driver update has enabled the hardware schedulers in third generation GCN parts for production use.[22]

Primitive Discard Accelerator

This unit discards degenerate triangles before they enter the vertex shader and triangles that do not cover any fragments before they enter the fragment shader.[25] This unit was introduced with the fourth generation GCN microarchitecture.[25]

Generations

Graphics Core Next 1

AMD Graphics Core Next 1
History
PredecessorTeraScale 3
SuccessorGraphics Core Next 2

The GCN 1 microarchitecture was used in several Radeon HD 7000 series graphics cards.

Die shot of the Tahiti GPU used in Radeon HD 7950 GHz Edition graphics cards

There are Asynchronous Compute Engines controlling computation and dispatching.[14][29]

ZeroCore Power

ZeroCore Power is a long idle power saving technology, shutting off functional units of the GPU when not in use.[30] AMD ZeroCore Power technology supplements AMD PowerTune.

Chips

Discrete GPUs (Southern Islands family):

  • Hainan
  • Oland
  • Cape Verde
  • Pitcairn
  • Tahiti

Graphics Core Next 2

AMD Graphics Core Next 2
History
PredecessorGraphics Core Next 1
SuccessorGraphics Core Next 3
AMD PowerTune "Bonaire"
Die shot of the Hawaii GPU used in Radeon R9 290 graphics cards

The 2nd generation of GCN was introduced with the Radeon HD 7790 and is also found in the Radeon HD 8770, R7 260/260X, R9 290/290X, R9 295X2, R7 360, and R9 390/390X, as well as Steamroller-based desktop "Kaveri" APUs and mobile "Kaveri" APUs and in the Puma-based "Beema" and "Mullins" APUs. It has multiple advantages over the original GCN, including FreeSync support, AMD TrueAudio and a revised version of AMD PowerTune technology.

GCN 2nd generation introduced an entity called "Shader Engine" (SE). A Shader Engine comprises one geometry processor, up to 44 CUs (Hawaii chip), rasterizers, ROPs, and L1 cache. Not part of a Shader Engine is the Graphics Command Processor, the 8 ACEs, the L2 cache and memory controllers as well as the audio and video accelerators, the display controllers, the 2 DMA controllers and the PCIe interface.

The A10-7850K "Kaveri" contains 8 CUs (compute units) and 8 Asynchronous Compute Engines for independent scheduling and work item dispatching.[31]

At AMD Developer Summit (APU) in November 2013 Michael Mantor presented the Radeon R9 290X.[32]

Chips

Discrete GPUs (Sea Islands family):

  • Bonaire
  • Hawaii

integrated into APUs:

  • Temash
  • Kabini
  • Liverpool (i.e. the APU found in the PlayStation 4)
  • Durango (i.e. the APU found in the Xbox One and Xbox One S)
  • Kaveri
  • Godavari
  • Mullins
  • Beema
  • Carrizo-L

Graphics Core Next 3

AMD Graphics Core Next 3
History
PredecessorGraphics Core Next 2
SuccessorGraphics Core Next 4
Die shot of the Fiji GPU used in Radeon R9 Nano graphics cards

GCN 3rd generation[33] was introduced in 2014 with the Radeon R9 285 and R9 M295X, which have the "Tonga" GPU. It features improved tessellation performance, lossless delta color compression to reduce memory bandwidth usage, an updated and more efficient instruction set, a new high quality scaler for video, HEVC encoding (VCE 3.0) and HEVC decoding (UVD 6.0), and a new multimedia engine (video encoder/decoder). Delta color compression is supported in Mesa.[34] However, its double precision performance is worse compared to previous generation.[35]

Chips

discrete GPUs:

  • Tonga (Volcanic Islands family), comes with UVD 5.0 (Unified Video Decoder)
  • Fiji (Pirate Islands family), comes with UVD 6.0 and High Bandwidth Memory (HBM 1)

integrated into APUs:

  • Carrizo, comes with UVD 6.0
  • Bristol Ridge[36]
  • Stoney Ridge[36]

Graphics Core Next 4

AMD Graphics Core Next 4
History
PredecessorGraphics Core Next 3
SuccessorGraphics Core Next 5
Die shot of the Polaris 11 GPU used in Radeon RX 460 graphics cards
Die shot of the Polaris 10 GPU used in Radeon RX 470 graphics cards

GPUs of the Arctic Islands-family were introduced in Q2 of 2016 with the AMD Radeon 400 series. The 3D-engine (i.e. GCA (Graphics and Compute array) or GFX) is identical to that found in the Tonga-chips.[37] But Polaris feature a newer Display Controller engine, UVD version 6.3, etc.

All Polaris-based chips other than the Polaris 30 are produced on the 14 nm FinFET process, developed by Samsung Electronics and licensed to GlobalFoundries.[38] The slightly newer refreshed Polaris 30 is built on the 12 nm LP FinFET process node, developed by Samsung and GlobalFoundries. The fourth generation GCN instruction set architecture is compatible with the third generation. It is an optimization for 14 nm FinFET process enabling higher GPU clock speeds than with the 3rd GCN generation.[39] Architectural improvements include new hardware schedulers, a new primitive discard accelerator, a new display controller, and an updated UVD that can decode HEVC at 4K resolutions at 60 frames per second with 10 bits per color channel.

Chips

discrete GPUs:[40]

  • Polaris 10 (also codenamed Ellesmere) found on "Radeon RX 470" and "Radeon RX 480"-branded graphics cards
  • Polaris 11 (also codenamed Baffin) found on "Radeon RX 460"-branded graphics cards (also Radeon RX 560D)
  • Polaris 12 (also codenamed Lexa) found on "Radeon RX 550" and "Radeon RX 540"-branded graphics cards
  • Polaris 20, which is a refreshed (14 nm LPP Samsung/GloFo FinFET process) Polaris 10 with higher clocks, used for "Radeon RX 570" and "Radeon RX 580"-branded graphics cards[41]
  • Polaris 21, which is a refreshed (14 nm LPP Samsung/GloFo FinFET process) Polaris 11, used for "Radeon RX 560"-branded graphics cards
  • Polaris 22, found on "Radeon RX Vega M GH" and "Radeon RX Vega M GL"-branded graphics cards (as part of Kaby Lake-G)
  • Polaris 23, which is a refreshed (14 nm LPP Samsung/GloFo FinFET process) Polaris 12, used for "Radeon Pro WX 3200" and "Radeon RX 540X"-branded graphics cards (also Radeon RX 640)[42]
  • Polaris 30, which is a refreshed (12 nm LP GloFo FinFET process) Polaris 20 with higher clocks, used for "Radeon RX 590"-branded graphics cards[43]

In addition to dedicated GPUs, Polaris is utilized in the APUs of the PlayStation 4 Pro and Xbox One X, titled "Neo" and "Scorpio", respectively.

Precision Performance

FP64 performance of all GCN 4th generation GPUs is 1/16 of FP32 performance.

Graphics Core Next 5

AMD Graphics Core Next 5
History
PredecessorGraphics Core Next 4
SuccessorRDNA 1
Die shot of the Vega 10 GPU used in Radeon RX Vega 64 graphics cards

AMD began releasing details of their next generation of GCN Architecture, termed the 'Next-Generation Compute Unit', in January 2017.[39][44][45] The new design was expected to increase instructions per clock, higher clock speeds, support for HBM2, a larger memory address space. The discrete graphics chipsets also include "HBCC (High Bandwidth Cache Controller)", but not when integrated into APUs.[46] Additionally, the new chips were expected to include improvements in the Rasterisation and Render output units. The stream processors are heavily modified from the previous generations to support packed math Rapid Pack Math technology for 8-bit, 16-bit, and 32-bit numbers. With this there is a significant performance advantage when lower precision is acceptable (for example: processing two half-precision numbers at the same rate as a single single precision number).

Nvidia introduced tile-based rasterization and binning with Maxwell,[47] and this was a big reason for Maxwell's efficiency increase. In January, AnandTech assumed that Vega would finally catch up with Nvidia regarding energy efficiency optimizations due to the new "DSBR (Draw Stream Binning Rasterizer)" to be introduced with Vega.[48]

It also added support for a new shader stage – Primitive Shaders.[49][50] Primitive shaders provide more flexible geometry processing and replace the vertex and geometry shaders in a rendering pipeline. As of December 2018, the Primitive shaders can't be used because required API changes are yet to be done.[51]

Vega 10 and Vega 12 use the 14 nm FinFET process, developed by Samsung Electronics and licensed to GlobalFoundries. Vega 20 uses the 7 nm FinFET process developed by TSMC.

Chips

discrete GPUs:

  • Vega 10 (14 nm Samsung/GloFo FinFET process) (also codenamed Greenland[52]) found on "Radeon RX Vega 64", "Radeon RX Vega 56", "Radeon Vega Frontier Edition", "Radeon Pro V340", Radeon Pro WX 9100, and Radeon Pro WX 8200 graphics cards[53]
  • Vega 12 (14 nm Samsung/GloFo FinFET process) found on "Radeon Pro Vega 20" and "Radeon Pro Vega 16"-branded mobile graphics cards[54]
  • Vega 20 (7 nm TSMC FinFET process) found on "Radeon Instinct MI50" and "Radeon Instinct MI60"-branded accelerator cards,[55] "Radeon Pro Vega II", and "Radeon VII"-branded graphics cards.[56]

integrated into APUs:

  • Raven Ridge[57] came with VCN 1 which supersedes VCE and UVD and allows full fixed-function VP9 decode.

Precision performance

Double-precision floating-point (FP64) performance of all GCN 5th generation GPUs, except for Vega 20, is one-sixteenth of FP32 performance. For Vega 20 with Radeon Instinct this is half of FP32 performance. For Vega 20 with Radeon VII this is a quarter of FP32 performance.[58] All GCN 5th generation GPUs support half-precision floating-point (FP16) calculations which is twice of FP32 performance.

Comparison of GCN chips

  • Table contains only discrete GPU chips (including mobile). APU(IGP) and console chips are not listed.
Microarchitecture[59] GCN 1 GCN 2 GCN 3 GCN 4 GCN 5
Chip Tahiti[60] Pitcairn[61] Cape Verde[62] Oland[63] Hainan[64] Bonaire[65] Hawaii[66] Topaz[67] Tonga[68] Fiji[69] Ellesmere[70] Baffin[71] Lexa[72] Vega 10[73] Vega 12[74] Vega 20[75]
Code name1 ? ? ? Tiran ? ? Ibiza Iceland ? ? Polaris 10 Polaris 11 Polaris 12 Greenland Treasure Refresh Moonshot
Chip variant(s) New Zealand
Malta
Wimbledon
Curaçao
Neptune
Trinidad
Chelsea
Heathrow
Venus
Tropo
Mars
Opal
Litho
Sun
Jet
Exo
Banks
Saturn
Tobago
Strato
Emerald
Vesuvius
Grenada
Meso
Weston
Polaris 24
Amethyst
Antigua
Capsaicin Polaris 20
Polaris 30
Polaris 21 Polaris 23 N/A N/A N/A
Fab TSMC 28 nm GlobalFoundries 14 nm / 12 nm (Polaris 30) TSMC 7 nm
Die size (mm2) 352 / 365 (Malta) 212 123 77 56 160 438 125 366 596 232 123 103 495 Unknown 331
Transistors (million) 4,313 2,800 1,500 950 690 2,080 6,200 1,550 5,000 8,900 5,700 3,000 2,200 12,500 Unknown 13,230
Transistor density (MTr/mm2) 12.3 / 12.8 (Malta) 13.2 12.2 12.3 13.0 14.2 12.4 13.7 14.9 24.6 24.4 21.4 25.3 Unknown 40.0
Asynchronous compute engines 2 8 ? 8 4 ? 4
Geometry engines 2 1 2 N/A ? N/A 4 ? 4
Shader engines N/A 4 ? 4 2 N/A
Hardware schedulers N/A 2 ? 2
Compute units 32 20 10 / 8 (Chelsea) 6 5 / 6 (Jet) 14 44 6 32 64 36 16 10 64 20 64
Stream processors 2048 1280 640 / 512 (Chelsea) 384 320 / 384 (Jet) 896 2816 384 2048 4096 2304 1024 640 4096 1280 4096
Texture mapping units 128 80 40 / 32 (Chelsea) 24 20 / 24 (Jet) 56 176 24 128 256 144 64 40 256 80 256
Render output units 32 16 8 16 64 8 32 64 32 16 64 32 64
Z/Stencil OPS 128 64 16 64 256 16 128 256 N/A
L1 cache (KB) 16 per Compute unit (CU)
L2 cache (KB) 768 512 256 128 / 256 (Jet) 256 1024 256 768 2048 1024 512 4096 1024 4096
Display Core Engine 6.0 6.4 N/A 8.2 8.5 N/A 10.0 11.2 12.0 12.1
Unified Video Decoder 3.2 4.0 N/A 4.2 N/A 5.0 6.0 6.3 7.0 7.2
Video Coding Engine 1.0 N/A 2.0 N/A 3.0 3.4 4.0 4.1
Launch2 2011 2012 2012 2013 2015 2013 2013 2014 2014 2015 2016 2016 2017 2017 2018 2018
Series (Family) Southern Islands Sea Islands Volcanic Islands Pirate Islands Arctic Islands Vega Vega II
Notes mobile/OEM mobile/OEM mobile

1 Old code names such as Treasure (Lexa) or Hawaii Refresh (Ellesmere) are not listed.
2 Initial launch date. Launch dates of variant chips such as Polaris 20 (April 2017) are not listed.

See also

External links

References

  1. AMD Developer Central (January 31, 2014). "GS-4106 The AMD GCN Architecture – A Crash Course, by Layla Mah". https://www.slideshare.net/DevCentralAMD/gs4106-the-amd-gcn-architecture-a-crash-course-by-layla-mah. 
  2. "AMD Launches World's Fastest Single-GPU Graphics Card – the AMD Radeon HD 7970" (Press release). AMD. December 22, 2011. Archived from the original on January 20, 2015. Retrieved January 20, 2015.
  3. Gulati, Abheek (2019-11-11). "An Architectural Deep-Dive into AMD's TeraScale, GCN & RDNA GPU Architectures" (in en). https://medium.com/high-tech-accessible/an-architectural-deep-dive-into-amds-terascale-gcn-rdna-gpu-architectures-c4a212d0eb9. 
  4. "AMD community forums". https://community.amd.com/thread/203070. 
  5. "LLVM back-end amdgpu". http://llvm.org/docs/AMDGPUUsage.html. 
  6. "GCC 9 Release Series Changes, New Features, and Fixes". https://gcc.gnu.org/gcc-9/changes.html#amdgcn. 
  7. "AMD GCN Offloading Support". https://gcc.gnu.org/ml/gcc-patches/2019-11/msg00905.html. 
  8. "AMD Boltzmann Initiative – Heterogeneous-compute Interface for Portability (HIP)". November 16, 2015. https://www.amd.com/en/press-releases/boltzmann-initiative-2015nov16. 
  9. Smith, Ryan (January 5, 2017). "The AMD Vega GPU Architecture Preview". http://www.anandtech.com/show/11002/the-amd-vega-gpu-architecture-teaser. 
  10. Smith, Ryan. "AMD Dives Deep On Asynchronous Shading". http://www.anandtech.com/show/9124/amd-dives-deep-on-asynchronous-shading. 
  11. "Conformant Products". October 26, 2017. https://www.khronos.org/conformance/adopters/conformant-products#opengl. 
  12. Compute Cores Whitepaper. AMD. 2014. p. 5. https://www.amd.com/Documents/Compute_Cores_Whitepaper.pdf. 
  13. 13.0 13.1 Smith, Ryan (December 21, 2011). "AMD's Graphics Core Next Preview". http://www.anandtech.com/show/4455/amds-graphics-core-next-preview-amd-architects-for-compute/5. 
  14. 14.0 14.1 Mantor, Michael; Houston, Mike (June 15, 2011). "AMD Graphics Core Next". AMD. p. 40. http://developer.amd.com/wordpress/media/2013/06/2620_final.pdf. "Asynchronous Compute Engine (ACE)" 
  15. "Optimizing GPU occupancy and resource usage with large thread groups" (in en-GB). https://gpuopen.com/learn/optimizing-gpu-occupancy-resource-usage-large-thread-groups/. 
  16. "White Paper AMD UnifiedVideoDecoder (UVD)". 2012-06-15. https://www.amd.com/Documents/UVD3_whitepaper.pdf. 
  17. 17.0 17.1 "Not Just A New Architecture, But New Features Too". AnandTech. December 21, 2011. http://www.anandtech.com/show/4455/amds-graphics-core-next-preview-amd-architects-for-compute/6. 
  18. "Kaveri microarchitecture". SemiAccurate. January 15, 2014. http://semiaccurate.com/2014/01/15/technical-look-amds-kaveri-architecture/. 
  19. Airlie, Dave (November 26, 2014). "Merge AMDKFD". freedesktop.org. http://cgit.freedesktop.org/~airlied/linux/commit/?h=drm-next&id=33f86ff62c4368c8d6bf3c76dc2fa416e3f90213. 
  20. "/drivers/gpu/drm". Kernel.org. https://git.kernel.org/cgit/linux/kernel/git/stable/linux-stable.git/tree/drivers/gpu/drm. 
  21. "[PATCH 00/83 AMD HSA kernel driver"]. LKML. July 10, 2014. http://lkml.iu.edu/hypermail/linux/kernel/1407.1/02923.html. 
  22. 22.0 22.1 22.2 22.3 22.4 Angelini, Chris (June 29, 2016). "AMD Radeon RX 480 8GB Review". Tom's Hardware: p. 1. http://www.tomshardware.com/reviews/amd-radeon-rx-480-polaris-10,4616.html. 
  23. "Dissecting the Polaris Architecture". 2016. http://radeon.wpengine.netdna-cdn.com/wp-content/uploads/2016/08/Polaris-Architecture-Whitepaper-Final-08042016.pdf. 
  24. Shrout, Ryan (June 29, 2016). "The AMD Radeon RX 480 Review – The Polaris Promise". PC Perspective: p. 2. http://www.pcper.com/reviews/Graphics-Cards/AMD-Radeon-RX-480-Review-Polaris-Promise/Polaris-Architecture-4th-Generation-. 
  25. 25.0 25.1 Smith, Ryan (June 29, 2016). "The AMD Radeon RX 480 Preview: Polaris Makes Its Mainstream Mark". AnandTech: p. 3. http://www.anandtech.com/show/10446/the-amd-radeon-rx-480-preview/3. 
  26. "AMD Radeon HD 7000 Series to be PCI-Express 3.0 Compliant". TechPowerUp. http://www.techpowerup.com/149225/AMD-Radeon-HD-7000-Series-to-be-PCI-Express-3.0-Compliant.html. 
  27. "AMD Details Next Gen. GPU Architecture". http://pixelsmashers.com/?p=10341. 
  28. Tony Chen; Jason Greaves, "AMD's Graphics Core Next (GCN) Architecture", AMD, http://meseec.ce.rit.edu/551-projects/fall2014/3-4.pdf, retrieved August 13, 2016 
  29. "AMD's Graphics Core Next Preview: AMD's New GPU, Architected For Compute". AnandTech. December 21, 2011. http://www.anandtech.com/show/4455/amds-graphics-core-next-preview-amd-architects-for-compute/5. "AMD's new Asynchronous Compute Engines serve as the command processors for compute operations on GCN. The principal purpose of ACEs will be to accept work and to dispatch it off to the CUs for processing." 
  30. "Managing Idle Power: Introducing ZeroCore Power". December 22, 2011. http://www.anandtech.com/show/5261/amd-radeon-hd-7970-review/11. 
  31. "AMD's Kaveri A10-7850K tested". January 14, 2014. http://www.anandtech.com/show/7677/amd-kaveri-review-a8-7600-a10-7850k/7. 
  32. "AMD Radeon R9-290X". November 21, 2013. http://www.slideshare.net/DevCentralAMD/gs4152-michael-mantor. 
  33. "Carrizo Overview" (PNG). http://images.anandtech.com/doci/9319/Slide%2019%20-%20GCN%20Overview.png. 
  34. "Add DCC Support". Freedesktop.org. October 11, 2015. http://lists.freedesktop.org/archives/mesa-dev/2015-October/096919.html. 
  35. Smith, Ryan (September 10, 2014). "AMD Radeon R9 285 Review". http://www.anandtech.com/show/8460/amd-radeon-r9-285-review. 
  36. 36.0 36.1 Cutress, Ian (June 1, 2016). "AMD Announces 7th Generation APU". http://www.anandtech.com/show/10362/amd-7th-generation-apu-bristol-ridge-stoney-ridge-for-notebooks. 
  37. "RadeonFeature". https://www.x.org/wiki/RadeonFeature/#index6h2. 
  38. "Radeon Technologies Group – January 2016 – AMD Polaris Architecture". http://www.guru3d.com/articles-pages/radeon-technologies-group-january-2016-amd-polaris-architecture,1.html. 
  39. 39.0 39.1 Smith, Ryan (January 5, 2017). "The AMD Vega Architecture Teaser: Higher IPC, Tiling, & More, coming in H1'2017". http://www.anandtech.com/show/11002/the-amd-vega-gpu-architecture-teaser. 
  40. WhyCry (March 24, 2016). "AMD confirms Polaris 10 is Ellesmere and Polaris 11 is Baffin". http://videocardz.com/58634/amd-confirms-polaris-10-is-ellesmere-and-polaris-11-is-baffin. 
  41. "Fast vollständige Hardware-Daten zu AMDs Radeon RX 500 Serie geleakt". https://www.3dcenter.org/news/fast-vollstaendige-hardware-daten-zu-amds-radeon-rx-500-serie-geleakt. 
  42. "AMD Polaris 23". https://www.techpowerup.com/gpu-specs/amd-polaris-23.g920. 
  43. Oh, Nate (November 15, 2018). "The AMD Radeon RX 590 Review, feat. XFX & PowerColor: Polaris Returns (Again)". https://www.anandtech.com/show/13570/the-amd-radeon-rx-590-review. 
  44. Kampman, Jeff (January 5, 2017). "The curtain comes up on AMD's Vega architecture". http://techreport.com/review/31224/the-curtain-comes-up-on-amd-vega-architecture. 
  45. Shrout, Ryan (January 5, 2017). "AMD Vega GPU Architecture Preview: Redesigned Memory Architecture". PC Perspective. https://www.pcper.com/reviews/Graphics-Cards/AMD-Vega-GPU-Architecture-Preview-Redesigned-Memory-Architecture. 
  46. Kampman, Jeff (October 26, 2017). "AMD's Ryzen 7 2700U and Ryzen 5 2500U APUs revealed". https://techreport.com/review/32743/amd-ryzen-7-2700u-and-ryzen-5-2500u-apus-revealed. 
  47. Raevenlord (March 1, 2017). "On NVIDIA's Tile-Based Rendering". https://www.techpowerup.com/231129/on-nvidias-tile-based-rendering. 
  48. "Vega Teaser: Draw Stream Binning Rasterizer". http://www.anandtech.com/show/11002/the-amd-vega-gpu-architecture-teaser/3. 
  49. "Radeon RX Vega Revealed: AMD promises 4K gaming performance for $499 – Trusted Reviews". July 31, 2017. http://www.trustedreviews.com/news/amd-vega-specs-performance-release-date-technology-explained. 
  50. "The curtain comes up on AMD's Vega architecture". http://techreport.com/review/31224/the-curtain-comes-up-on-amd-vega-architecture/2. 
  51. Kampman, Jeff (January 23, 2018). "Radeon RX Vega primitive shaders will need API support". https://techreport.com/news/33153/radeon-rx-vega-primitive-shaders-will-need-api-support. 
  52. "ROCm-OpenCL-Runtime/libUtils.cpp at master · RadeonOpenCompute/ROCm-OpenCL-Runtime". May 3, 2017. https://github.com/RadeonOpenCompute/ROCm-OpenCL-Runtime/blob/master/compiler/lib/utils/v0_8/libUtils.cpp. 
  53. "The AMD Radeon RX Vega 64 & RX Vega 56 Review: Vega Burning Bright". August 14, 2017. https://www.anandtech.com/show/11717/the-amd-radeon-rx-vega-64-and-56-review. 
  54. "AMD's Vega Mobile Lives: Vega Pro 20 & 16 in Updated MacBook Pros In November". October 30, 2018. https://www.anandtech.com/show/13532/amds-vega-mobile-lives-vega-pro-20-16-in-november. 
  55. "AMD Announces Radeon Instinct MI60 & MI50 Accelerators: Powered By 7nm Vega". November 6, 2018. https://www.anandtech.com/show/13562/amd-announces-radeon-instinct-mi60-mi50-accelerators-powered-by-7nm-vega. 
  56. "AMD Unveils World's First 7nm Gaming GPU – Delivering Exceptional Performance and Incredible Experiences for Gamers, Creators and Enthusiasts" (Press release). Las Vegas, Nevada: AMD. January 9, 2019. Retrieved January 12, 2019.
  57. Ferreira, Bruno (May 16, 2017). "Ryzen Mobile APUs are coming to a laptop near you". Tech Report. https://techreport.com/news/31918/ryzen-mobile-apus-are-coming-to-a-laptop-near-you. 
  58. "AMD Unveils World's First 7nm Datacenter GPUs – Powering the Next Era of Artificial Intelligence, Cloud Computing and High Performance Computing (HPC) | AMD". AMD.com (Press release). November 6, 2018. Retrieved November 10, 2018.
  59. "RadeonFeature". https://www.x.org/wiki/RadeonFeature/. 
  60. "AMD Tahiti GPU Specs". https://www.techpowerup.com/gpu-specs/amd-tahiti.g120. 
  61. "AMD Pitcairn GPU Specs". https://www.techpowerup.com/gpu-specs/amd-pitcairn.g420. 
  62. "AMD Cape Verde GPU Specs". https://www.techpowerup.com/gpu-specs/amd-cape-verde.g100. 
  63. "AMD Oland GPU Specs". https://www.techpowerup.com/gpu-specs/amd-oland.g389. 
  64. "AMD Hainan GPU Specs". https://www.techpowerup.com/gpu-specs/amd-hainan.g817. 
  65. "AMD Bonaire GPU Specs". https://www.techpowerup.com/gpu-specs/amd-bonaire.g568. 
  66. "AMD Hawaii GPU Specs". https://www.techpowerup.com/gpu-specs/amd-hawaii.g738. 
  67. "AMD Topaz GPU Specs". https://www.techpowerup.com/gpu-specs/amd-topaz.g766. 
  68. "AMD Tonga GPU Specs". https://www.techpowerup.com/gpu-specs/amd-tonga.g768. 
  69. "AMD Fiji GPU Specs". https://www.techpowerup.com/gpu-specs/amd-fiji.g774. 
  70. "AMD Ellesmere GPU Specs". https://www.techpowerup.com/gpu-specs/amd-ellesmere.g795. 
  71. "AMD Baffin GPU Specs". https://www.techpowerup.com/gpu-specs/amd-baffin.g796. 
  72. "AMD Lexa GPU Specs". https://www.techpowerup.com/gpu-specs/amd-lexa.g806. 
  73. "AMD Vega 10 GPU Specs". https://www.techpowerup.com/gpu-specs/amd-vega-10.g800. 
  74. "AMD Vega 12 GPU Specs". https://www.techpowerup.com/gpu-specs/amd-vega-12.g859. 
  75. "AMD Vega 20 GPU Specs". https://www.techpowerup.com/gpu-specs/amd-vega-20.g848.