Jump to content

Qualcomm Hexagon: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Tags: Mobile edit Mobile web edit
 
(34 intermediate revisions by 22 users not shown)
Line 1: Line 1:
{{short description|Family of digital signal processor microprocessors}}
{{short description|Family of digital signal processor microprocessors}}
{{Technical|date=March 2016}}
{{Infobox CPU architecture
{{Infobox CPU architecture
| name = Hexagon
| name = Hexagon
| designer = [[Qualcomm]]
| designer = [[Qualcomm]]
| bits = 32-bit
| bits = 32-bit, 64-bit
| introduced = 2006 (QDSP6)
| introduced = 2006 (QDSP6)
| version =
| version =
| design = 4-way multithreaded [[VLIW]]
| design = 4-way multithreaded [[VLIW]]
| type = Register-Register
| type = [[Load–store]]
| encoding = Fixed 4 byte per instruction, up to 4 instructions in VLIW multiinstruction
| encoding = Fixed 4 byte per instruction, up to 4 instructions in VLIW multiinstruction
| branching = <!-- Branching evaluation, e.g. Condition register, Condition code, Compare and branch -->
| branching = <!-- Branching evaluation, e.g. Condition register, Condition code, Compare and branch -->
Line 20: Line 19:
}}
}}


'''Hexagon''' is the brand name for a family of digital signal processor (DSP) products by [[Qualcomm]]. Hexagon is also known as QDSP6, standing for “sixth generation digital signal processor.” According to Qualcomm, the Hexagon architecture is designed to deliver performance with low power over a variety of applications.<ref>{{Cite web|title=Hexagon DSP SDK|url=https://developer.qualcomm.com/software/hexagon-dsp-sdk|access-date=2021-01-14|website=Qualcomm Developer Network|language=en}}</ref><ref>{{Cite web|title=Hexagon DSP SDK Processor|url=https://developer.qualcomm.com/software/hexagon-dsp-sdk/dsp-processor|access-date=2021-01-14|website=Qualcomm Developer Network|language=en}}</ref>
'''Hexagon''' is the brand name for a family of [[digital signal processor]] (DSP) and later [[neural processing unit]] (NPU) products by [[Qualcomm]].<ref>{{Cite web |title=CSDL {{!}} IEEE Computer Society |url=https://www.computer.org/csdl/proceedings-article/hcs/2023/10254715/1QKTntH0oyk |access-date=2024-06-08 |website=www.computer.org}}</ref> Hexagon is also known as QDSP6, standing for “sixth generation digital signal processor.” According to Qualcomm, the Hexagon architecture is designed to deliver performance with low power over a variety of applications.<ref>{{Cite web|title=Hexagon DSP SDK|url=https://developer.qualcomm.com/software/hexagon-dsp-sdk|access-date=2021-01-14|website=Qualcomm Developer Network|language=en}}</ref><ref name="Hexagon DSP SDK Processor">{{Cite web|title=Hexagon DSP SDK Processor|url=https://developer.qualcomm.com/software/hexagon-dsp-sdk/dsp-processor|access-date=2021-01-14|website=Qualcomm Developer Network|language=en}}</ref>


Each version of Hexagon has an instruction set and a micro-architecture. These two features are intimately related.
Each version of Hexagon has an instruction set and a micro-architecture. These two features are intimately related.


Hexagon is used in Qualcomm Snapdragon chips, for example in smartphones, cars, wearable devices and other mobile devices and is also used in components of cellular phone networks.
Hexagon is used in [[Qualcomm Snapdragon]] chips, for example in smartphones, cars, wearable devices and other mobile devices and is also used in components of cellular phone networks.


== Instruction set architecture ==
== Instruction set architecture ==
Line 31: Line 30:
Assemblers and compilers that translate computer programs into streams of instructions – bit streams - that the device can understand and carry out (execute). As an instruction stream executes, the integrity of system function is supported by the use of instruction privilege levels. Privileged instructions have access to more resources in the device, including memory. Hexagon supports privilege levels.
Assemblers and compilers that translate computer programs into streams of instructions – bit streams - that the device can understand and carry out (execute). As an instruction stream executes, the integrity of system function is supported by the use of instruction privilege levels. Privileged instructions have access to more resources in the device, including memory. Hexagon supports privilege levels.


Originally, Hexagon instructions operated on integer numbers but not floating point numbers,<ref>{{Cite web|last=Humrick|first=Matt|title=Qualcomm Details Snapdragon 835: Kryo 280 CPU, Adreno 540 GPU, X16 LTE|url=https://www.anandtech.com/show/10948/qualcomm-snapdragon-835-kryo-280-adreno-540|access-date=2021-01-14|website=www.anandtech.com}}</ref> but in v5 floating point support was added.<ref>{{Cite web|last=Group|first=Lindley|date=|title=Microprocessor Report|url=http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_microreport2013_v5.pdf|url-status=live|archive-url=|archive-date=|access-date=|website=}}</ref>
Originally, Hexagon instructions operated on integer numbers but not floating point numbers,<ref>{{Cite web|last=Humrick|first=Matt|title=Qualcomm Details Snapdragon 835: Kryo 280 CPU, Adreno 540 GPU, X16 LTE|url=https://www.anandtech.com/show/10948/qualcomm-snapdragon-835-kryo-280-adreno-540|access-date=2021-01-14|website=www.anandtech.com}}</ref> but in v5 floating point support was added.<ref>{{Cite web|last=Group|first=Lindley|date=|title=Microprocessor Report|url=http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_microreport2013_v5.pdf|access-date=|website=}}</ref>


The processing unit which handles execution of instructions is capable of in-order dispatching up to 4 instructions (the packet) to 4 [[Execution unit|Execution Units]] every clock.<ref>{{cite web|url=http://landley.net/notes.html |title=Rob Landley's Blog Thing for 2012 |publisher=Landley.net |access-date=2012-10-19}}</ref><ref name="ll-simp0">[http://llvm.org/devmtg/2011-11/Simpson_PortingLLVMToADSP.pdf Porting LLVM to a Next Generation DSP], L. Taylor Simpson (Qualcomm) // LLVM Developers’ Meeting: 11/18/2011</ref>
The processing unit which handles execution of instructions is capable of in-order dispatching up to 4 instructions (the packet) to 4 [[Execution unit|Execution Units]] every clock.<ref>{{cite web|url=http://landley.net/notes.html |title=Rob Landley's Blog Thing for 2012 |publisher=Landley.net |access-date=2012-10-19}}</ref><ref name="ll-simp0">[http://llvm.org/devmtg/2011-11/Simpson_PortingLLVMToADSP.pdf Porting LLVM to a Next Generation DSP], L. Taylor Simpson (Qualcomm) // LLVM Developers’ Meeting: 11/18/2011</ref>


== Micro-architecture ==
== Micro-architecture ==
Micro-architecture is the physical structure of a chip or chip component that makes it possible for a device to carry out the instructions. A given instruction set can be implemented by a variety of micro-architectures. The buses – data transfer channels – for Hexagon devices are 32 bits wide. That is, 32 bits of data can be moved from one part of the chip to another in a single step. The Hexagon micro-architecture is multi-threaded,<ref>{{Cite web|title=Hexagon DSP SDK Processor|url=https://developer.qualcomm.com/software/hexagon-dsp-sdk/dsp-processor|access-date=2021-01-14|website=Qualcomm Developer Network|language=en}}</ref> which means that it can simultaneously process more than one stream of instructions, enhancing data processing speed. Hexagon supports very long instruction words,<ref>{{Cite web|title=Hexagon - Microarchitectures - Qualcomm - WikiChip|url=https://en.wikichip.org/wiki/qualcomm/microarchitectures/hexagon|access-date=2021-01-14|website=en.wikichip.org|language=en}}</ref><ref>{{Cite document|last=Iqbal|first=Faisal|date=|title=Qualcomm Hexagon DSP|url=https://www.academia.edu/39512926|url-status=live|archive-url=|archive-date=|access-date=|website=}}</ref> which are groupings of four instructions that can be executed “in parallel.” Parallel execution means that multiple instructions can run simultaneously without one instruction having to complete before the next one starts. The Hexagon micro-architecture supports single instruction, multiple data operations,<ref>{{Cite web|last=Technologies|first=Qualcomm|date=2018|title=Qualcomm Hexagon V66 HVX Programmer's Reference Manual|url=https://developer.qualcomm.com/qfile/67416/80-n2040-44_b_qualcomm_hexagon_v66_hvx_reference_manual_programmers.pdf|url-status=live|archive-url=|archive-date=|access-date=|website=}}</ref> which means that a when a Hexagon device receives an instruction it can carry out the operation on more than one piece of data at the same time
Micro-architecture is the physical structure of a chip or chip component that makes it possible for a device to carry out the instructions. A given instruction set can be implemented by a variety of micro-architectures. The buses – data transfer channels – for Hexagon devices are 32 bits wide. That is, 32 bits of data can be moved from one part of the chip to another in a single step. The Hexagon micro-architecture is multi-threaded,<ref name="Hexagon DSP SDK Processor"/> which means that it can simultaneously process more than one stream of instructions, enhancing data processing speed. Hexagon supports very long instruction words,<ref>{{Cite web|title=Hexagon - Microarchitectures - Qualcomm - WikiChip|url=https://en.wikichip.org/wiki/qualcomm/microarchitectures/hexagon|access-date=2021-01-14|website=en.wikichip.org|language=en}}</ref><ref>{{Cite web|last=Iqbal|first=Faisal|date=|title=Qualcomm Hexagon DSP|url=https://www.academia.edu/39512926|access-date=|website=}}</ref> which are groupings of four instructions that can be executed “in parallel.” Parallel execution means that multiple instructions can run simultaneously without one instruction having to complete before the next one starts. The Hexagon micro-architecture supports single instruction, multiple data operations,<ref>{{Cite web|last=Technologies|first=Qualcomm|date=2018|title=Qualcomm Hexagon V66 HVX Programmer's Reference Manual|url=https://developer.qualcomm.com/qfile/67416/80-n2040-44_b_qualcomm_hexagon_v66_hvx_reference_manual_programmers.pdf|access-date=|website=}}</ref> which means that when a Hexagon device receives an instruction, it can carry out the operation on more than one piece of data at the same time.
According to 2012 estimation, Qualcomm shipped 1.2 billion DSP [[Semiconductor intellectual property core|cores]] inside its [[System on a chip|system on a chip (SoCs)]] (average 2.3 DSP core per SoC) in 2011, and 1.5 billion cores were planned for 2012, making the QDSP6 the most shipped architecture of DSP<ref>Will Strauss, [http://www.fwdconcepts.com/dsp111212.htm Forward Concepts. Wireless/DSP Market Bulletin: Qualcomm Leads in Global DSP Silicon Shipments] {{webarchive |url=https://web.archive.org/web/20130528013532/http://www.fwdconcepts.com/dsp111212.htm |date=May 28, 2013 }} // Forward Concepts: "In calendar year 2011, Qualcomm shipped a reported 521 million MSM chip shipments and we estimate that an average of 2.3 of its DSP cores in each unit resulted in 1.2 billion DSPs shipped in silicon. This (calendar) year, we estimate that the company will ship an average of 2.4 DSP cores with each (more complex) MSM chip."</ref> ([[CEVA, Inc.|CEVA]] had around 1 billion of DSP cores shipped in 2011 with 90% of IP-licenseable DSP market<ref>[http://www.prnewswire.com/news-releases/ceva-continues-to-dominate-dsp-ip-market-with-90-market-share-151346395.html]; [http://www.semiwiki.com/forum/content/1287-dsp-ip-core-ceva-undisputed-worldwide-leader-70-market-share.html]; [https://archive.today/20130722043806/http://www.eetasia.com/articleLogin.do?artId=8800667242 Ceva grabs 90% of DSP IP market], 2012</ref>).
According to 2012 estimation, Qualcomm shipped 1.2 billion DSP [[Semiconductor intellectual property core|cores]] inside its [[System on a chip|system on a chip (SoCs)]] (average 2.3 DSP core per SoC) in 2011, and 1.5 billion cores were planned for 2012, making the QDSP6 the most shipped architecture of DSP<ref>Will Strauss, [http://www.fwdconcepts.com/dsp111212.htm Forward Concepts. Wireless/DSP Market Bulletin: Qualcomm Leads in Global DSP Silicon Shipments] {{webarchive |url=https://web.archive.org/web/20130528013532/http://www.fwdconcepts.com/dsp111212.htm |date=May 28, 2013 }} // Forward Concepts: "In calendar year 2011, Qualcomm shipped a reported 521 million MSM chip shipments and we estimate that an average of 2.3 of its DSP cores in each unit resulted in 1.2 billion DSPs shipped in silicon. This (calendar) year, we estimate that the company will ship an average of 2.4 DSP cores with each (more complex) MSM chip."</ref> ([[CEVA, Inc.|CEVA]] had around 1 billion of DSP cores shipped in 2011 with 90% of IP-licensable DSP market<ref>[http://www.prnewswire.com/news-releases/ceva-continues-to-dominate-dsp-ip-market-with-90-market-share-151346395.html]; [http://www.semiwiki.com/forum/content/1287-dsp-ip-core-ceva-undisputed-worldwide-leader-70-market-share.html]; [https://archive.today/20130722043806/http://www.eetasia.com/articleLogin.do?artId=8800667242 Ceva grabs 90% of DSP IP market], 2012</ref>).


The Hexagon architecture is designed to deliver performance with low power over a variety of applications. It has features such as hardware assisted [[multithreading (computer architecture)|multithreading]], privilege levels, [[VLIW|Very Long Instruction Word (VLIW)]], [[SIMD|Single Instruction Multiple Data (SIMD)]],<ref>Hexagon v2 Programmers Reference</ref><ref name=hotchip14>{{cite web|url=http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_micro2014_v6.pdf|title=HEXAGON DSP: AN ARCHITECTURE OPTIMIZED FOR MOBILE MULTIMEDIA AND COMMUNICATIONS|date=March–April 2014|author=Lucian Codrescu (Qualcomm)|publisher= IEEE Micro 34.2|pages=34–43}}</ref> and instructions geared toward efficient signal processing. Hardware multithreading is implemented as [[Barrel processor|barrel]] [[temporal multithreading]] - threads are switched in round-robin fashion each cycle, so the 600&nbsp;MHz physical core is presented as three logical 200&nbsp;MHz cores before V5.<ref>[http://eprint.iacr.org/2013/428.pdf Faster 128-EEA3 and 128-EIA3 Software], Roberto Avanzi and Billy Bob Brumley (Qualcomm Research), Cryptology ePrint Archive: Report 2013/428, 2 Jul 2013. Page 9.</ref><ref name=hotchip13/> Hexagon V5 switched to dynamic multithreading (DMT) with [[Context switch#LATENCY|thread switch]] on L2 misses, interrupt waiting or on special instructions.<ref name=hotchip13/><ref name=mprv5-2013>[http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_microreport2013_v5.pdf Qualcomm Extends Hexagon DSP: Hexagon v5 Adds Floating-Point Math, Dynamic Multithreading] // Linley Gwennap, Microprocessor Report, August 2013</ref>
The Hexagon architecture is designed to deliver performance with low power over a variety of applications. It has features such as hardware assisted [[multithreading (computer architecture)|multithreading]], privilege levels, [[VLIW|Very Long Instruction Word (VLIW)]], [[SIMD|Single Instruction Multiple Data (SIMD)]],<ref>Hexagon v2 Programmers Reference</ref><ref name=hotchip14>{{cite web|url=http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_micro2014_v6.pdf|title=Hexagon DSP: An Architecture Optimized for Mobile Multimedia and Communications|date=March–April 2014|author=Lucian Codrescu (Qualcomm)|publisher= IEEE Micro 34.2|pages=34–43}}</ref> and instructions geared toward efficient signal processing. Hardware multithreading is implemented as [[Barrel processor|barrel]] [[temporal multithreading]] - threads are switched in round-robin fashion each cycle, so the 600&nbsp;MHz physical core is presented as three logical 200&nbsp;MHz cores before V5.<ref>[http://eprint.iacr.org/2013/428.pdf Faster 128-EEA3 and 128-EIA3 Software], Roberto Avanzi and Billy Bob Brumley (Qualcomm Research), Cryptology ePrint Archive: Report 2013/428, 2 Jul 2013. Page 9.</ref><ref name=hotchip13/> Hexagon V5 switched to dynamic multithreading (DMT) with [[Context switch#LATENCY|thread switch]] on L2 misses, interrupt waiting or on special instructions.<ref name=hotchip13/><ref name=mprv5-2013>[http://pages.cs.wisc.edu/~danav/pubs/qcom/hexagon_microreport2013_v5.pdf Qualcomm Extends Hexagon DSP: Hexagon v5 Adds Floating-Point Math, Dynamic Multithreading] // Linley Gwennap, Microprocessor Report, August 2013</ref>


At Hot Chips 2013 Qualcomm announced details of their Hexagon 680 DSP. Qualcomm announced Hexagon Vector Extensions (HVX). HVX is designed to allow significant compute workloads for advanced imaging and computer vision to be processed on the DSP instead of the CPU.<ref>{{Cite web|url=https://www.anandtech.com/show/9552/qualcomm-details-hexagon-680-dsp-in-snapdragon-820-accelerated-imaging|title=Qualcomm Details Hexagon 680 DSP in Snapdragon 820: Accelerated Imaging|last=Ho|first=Joshua|website=www.anandtech.com|access-date=2019-05-12}}</ref> In March 2015 Qualcomm announced their Snapdragon Neural Processing Engine SDK which allow [[AI accelerator|AI acceleration]] using the CPU, GPU and Hexagon DSP.<ref>{{Cite web|url=https://developer.qualcomm.com/blog/device-ai-qualcomm-snapdragon-neural-processing-engine-sdk|title=On-Device AI with Qualcomm Snapdragon Neural Processing Engine SDK|website=Qualcomm Developer Network|language=en|access-date=2019-05-12}}</ref>
At Hot Chips 2013 Qualcomm announced details of their Hexagon 680 DSP. Qualcomm announced Hexagon Vector Extensions (HVX). HVX is designed to allow significant compute workloads for advanced imaging and computer vision to be processed on the DSP instead of the CPU.<ref>{{Cite web|url=https://www.anandtech.com/show/9552/qualcomm-details-hexagon-680-dsp-in-snapdragon-820-accelerated-imaging|title=Qualcomm Details Hexagon 680 DSP in Snapdragon 820: Accelerated Imaging|last=Ho|first=Joshua|website=www.anandtech.com|access-date=2019-05-12}}</ref> In March 2015 Qualcomm announced their Snapdragon Neural Processing Engine SDK which allow [[AI accelerator|AI acceleration]] using the CPU, GPU and Hexagon DSP.<ref>{{Cite web|url=https://developer.qualcomm.com/blog/device-ai-qualcomm-snapdragon-neural-processing-engine-sdk|title=On-Device AI with Qualcomm Snapdragon Neural Processing Engine SDK|website=Qualcomm Developer Network|language=en|access-date=2019-05-12}}</ref>


[[Qualcomm]]'s [[List of Qualcomm Snapdragon systems-on-chip|Snapdragon 855]] contains their 4th generation on-device AI engine, which includes the Hexagon 690 DSP and Hexagon Tensor Accelerator (HTA) for [[AI accelerator|AI acceleration]].<ref>{{Cite web|url=https://www.qualcomm.com/news/releases/2019/02/25/artificial-intelligence-engine-qualcomm-snapdragon-855-mobile-platform|title=Artificial Intelligence Engine in Qualcomm Snapdragon 855 Mobile Platform Powers On-Device AI User Experiences in Flagship Premium-Tier Smartphones|date=2019-02-24|website=Qualcomm|language=en|access-date=2019-05-12}}</ref>
[[Qualcomm]]'s [[List of Qualcomm Snapdragon systems-on-chip|Snapdragon 855]] contains their 4th generation on-device AI engine, which includes the Hexagon 690 DSP and Hexagon Tensor Accelerator (HTA) for [[AI accelerator|AI acceleration]].<ref>{{Cite web|url=https://www.qualcomm.com/news/releases/2019/02/25/artificial-intelligence-engine-qualcomm-snapdragon-855-mobile-platform|title=Artificial Intelligence Engine in Qualcomm Snapdragon 855 Mobile Platform Powers On-Device AI User Experiences in Flagship Premium-Tier Smartphones|date=2019-02-24|website=Qualcomm|language=en|access-date=2019-05-12}}</ref> [[List of Qualcomm Snapdragon systems-on-chip|Snapdragon 865]] contains the 5th generation on-device AI engine based on the Hexagon 698 DSP capable of 15 trillion operations per second (TOPS).<ref>{{Cite web|url=https://www.qualcomm.com/news/releases/2019/12/qualcomm-introduces-worlds-most-advanced-5g-mobile-platform|title=Qualcomm Introduces the World's Most Advanced 5G Mobile Platform|date=2019-12-03|website=Qualcomm|language=en|access-date=2023-05-14}}</ref> [[List of Qualcomm Snapdragon systems-on-chip|Snapdragon 888]] contains the 6th generation on-device AI engine based on the Hexagon 780 DSP capable of 26 TOPS.<ref>{{Cite web|url=https://www.qualcomm.com/news/onq/2020/12/exploring-ai-capabilities-qualcomm-snapdragon-888-mobile-platform|title=Exploring the AI capabilities of the Qualcomm Snapdragon 888 Mobile Platform|date=2020-12-01|website=Qualcomm|language=en|access-date=2023-05-14}}</ref> [[List of Qualcomm Snapdragon systems-on-chip|Snapdragon 8]] contains the 7th generation on-device AI engine based on the Hexagon DSP capable of 52 TOPS and up to 104 TOPS in some cases.<ref>{{Cite web|url=https://www.qualcomm.com/products/mobile/snapdragon/smartphones/snapdragon-8-series-mobile-platforms/snapdragon-8-gen-1-mobile-platform|title=Snapdragon 8 Gen 1 Mobile Platform|date=2020-12-01|website=Qualcomm|language=en|access-date=2023-05-14}}</ref>


== Software support ==
== Software support ==
=== Operating systems ===
=== Operating systems ===
The [[porting|port]] of [[Linux]] for Hexagon runs under a [[hypervisor]] layer ("Hexagon Virtual Machine"<ref>https://developer.qualcomm.com/download/80-nb419-3ahexagonvirtualmachinespec.pdf{{dead link|date=July 2016 |bot=InternetArchiveBot |fix-attempted=yes }} (restricted access)</ref>) and was merged with the 3.2 release of the [[kernel (operating system)|kernel]].<ref>{{cite web|url=https://lwn.net/Articles/465066/|title=3.2 merge window, part 1|publisher=[[lwn.net]]|access-date=2012-10-19}}</ref><ref>[http://kernelnewbies.org/Linux_3.2#head-2acfe3ee1657c9c2647e5bb5d10e4f511f7527d8 Linux Kernel 3.2 Release Notes] "1.4. New architecture: Hexagon"</ref> The original hypervisor is closed-source, and in April 2013 a minimal open-source hypervisor implementation for QDSP6 V2 and V3, the "Hexagon MiniVM" was released by Qualcomm under a [[BSD-style license]].<ref>Richard Kuo, [http://permalink.gmane.org/gmane.linux.ports.hexagon/553 Hexagon MiniVM] // linux.ports.hexagon, 25 Apr 2013</ref><ref>[https://www.codeaurora.org/projects/all-active-projects/hexagon-minivm Hexagon MiniVM] // CodeAurora (Qualcomm)</ref>
The [[porting|port]] of [[Linux]] for Hexagon runs under a [[hypervisor]] layer ("Hexagon Virtual Machine"<ref>https://docs.qualcomm.com/bundle/publicresource/80-NB419-3_REV_A_Hexagin_Virtual_Machine_Specification.pdf{{dead link|date=July 2016 |bot=InternetArchiveBot |fix-attempted=yes }} (restricted access)</ref>) and was merged with the 3.2 release of the [[kernel (operating system)|kernel]].<ref>{{cite web|url=https://lwn.net/Articles/465066/|title=3.2 merge window, part 1|publisher=[[lwn.net]]|access-date=2012-10-19}}</ref><ref>[http://kernelnewbies.org/Linux_3.2#head-2acfe3ee1657c9c2647e5bb5d10e4f511f7527d8 Linux Kernel 3.2 Release Notes] "1.4. New architecture: Hexagon"</ref> The original hypervisor is closed-source, and in April 2013 a minimal open-source hypervisor implementation for QDSP6 V2 and V3, the "Hexagon MiniVM" was released by Qualcomm under a [[BSD-style license]].<ref>Richard Kuo, [http://permalink.gmane.org/gmane.linux.ports.hexagon/553 Hexagon MiniVM] // linux.ports.hexagon, 25 Apr 2013</ref><ref>[https://www.codeaurora.org/projects/all-active-projects/hexagon-minivm Hexagon MiniVM] // CodeAurora (Qualcomm)</ref>


=== Compilers ===
=== Compilers ===
Support for Hexagon was added in 3.1 release of [[LLVM]] by Tony Linthicum.<ref>{{cite web|url=http://llvm.org/releases/3.1/docs/ReleaseNotes.html |title=LLVM 3.1 Release Notes |publisher=Llvm.org |date=2012-05-15 |access-date=2012-10-19}}</ref> Hexagon/HVX V66 ISA support was added in 8.0.0 release of [[LLVM]].<ref>{{cite web|url=https://releases.llvm.org/8.0.0/docs/ReleaseNotes.html |title=LLVM 8.0.0 Release Notes |publisher=Llvm.org |date=2019-03-20 |access-date=2019-04-03}}</ref> There is also a non-[[Free Software Foundation|FSF]] maintained branch of [[GNU Compiler Collection|GCC]] and [[binutils]].<ref>
Support for Hexagon was added in 3.1 release of [[LLVM]] by Tony Linthicum.<ref>{{cite web|url=http://llvm.org/releases/3.1/docs/ReleaseNotes.html |title=LLVM 3.1 Release Notes |publisher=Llvm.org |date=2012-05-15 |access-date=2012-10-19}}</ref> Hexagon/HVX V66 ISA support was added in 8.0.0 release of [[LLVM]].<ref>{{cite web|url=https://releases.llvm.org/8.0.0/docs/ReleaseNotes.html |title=LLVM 8.0.0 Release Notes |publisher=Llvm.org |date=2019-03-20 |access-date=2019-04-03}}</ref> There is also a non-[[Free Software Foundation|FSF]] maintained branch of [[GNU Compiler Collection|GCC]] and [[binutils]].<ref>
{{cite web|title=Hexagon Project Wiki|url=https://www.codeaurora.org/xwiki/bin/Hexagon/|publisher=Codeaurora.org}}
{{cite web|title=Hexagon Project Wiki|url=https://www.codeaurora.org/xwiki/bin/Hexagon/|publisher=Codeaurora.org}}
{{cite web|title=Hexagon download|url=https://www.codeaurora.org/patches/quic/hexagon/"}}{{Dead link|date=May 2019 |bot=InternetArchiveBot |fix-attempted=yes }}
{{cite web|title=Hexagon download|url=https://www.codeaurora.org/patches/quic/hexagon/%22}}{{Dead link|date=May 2019 |bot=InternetArchiveBot |fix-attempted=yes }}
</ref>
</ref>


Line 64: Line 63:
In March 2016, it was announced that semiconductor company [[Conexant]]'s AudioSmart audio processing software was being integrated into Qualcomm's Hexagon.<ref>{{cite web|url=http://www.speechtechmag.com/Articles/News/Speech-Technology-Digest/Qualcomm-to-Integrate-Conexant-AudioSmart-into-Hexagon-DSPs-109538.aspx |title=Qualcomm to Integrate Conexant AudioSmart into Hexagon DSPs |publisher=Speech Tech Magazine |date=2016-03-01 |access-date=2016-03-11}}</ref>
In March 2016, it was announced that semiconductor company [[Conexant]]'s AudioSmart audio processing software was being integrated into Qualcomm's Hexagon.<ref>{{cite web|url=http://www.speechtechmag.com/Articles/News/Speech-Technology-Digest/Qualcomm-to-Integrate-Conexant-AudioSmart-into-Hexagon-DSPs-109538.aspx |title=Qualcomm to Integrate Conexant AudioSmart into Hexagon DSPs |publisher=Speech Tech Magazine |date=2016-03-01 |access-date=2016-03-11}}</ref>


In May 2018 [[wolfSSL]] added support for using Qualcomm Hexagon.<ref>{{cite web|url=https://www.wolfssl.com/wolfssl-use-hexagon-toolchain/ |title=wolfSSL Use With Hexagon Toolchain |publisher=wolfSLS |date=2018-05-18 |access-date=2020-07-10}}</ref> This is support for running wolfSSL crypto operations on the DSP. In addition to use of crypto operations a specialized operation load management library was later added.

In May 2018 [[ wolfSSL ]] added support for using Qualcomm Hexagon. <ref>{{cite web|url=https://www.wolfssl.com/wolfssl-use-hexagon-toolchain/ |title=wolfSSL Use With Hexagon Toolchain |publisher=wolfSLS |date=2018-05-18 |access-date=2020-07-10}}</ref> This is support for running wolfSSL crypto operations on the DSP. In addition to use of crypto operations a specialized operation load management library was later added.


== Versions ==
== Versions ==
Line 146: Line 144:
630
630
|-
|-
| QDSP6 V6 or 680<ref name="bdti-v6-2015-09">[http://www.bdti.com/insidedsp/2015/09/30/qualcomm Qualcomm's QDSP6 v6: Imaging and Vision Enhancements Via Vector Extensions] // BDTI, September 29, 2015</ref>|| 14 || 2016 || 4 || 500 || 2000
| QDSP6 V6 or 680|| 14 || 2016 || 4 || 500 || 2000 (820<ref name="bdti-v6-2015-09">[http://www.bdti.com/insidedsp/2015/09/30/qualcomm Qualcomm's QDSP6 v6: Imaging and Vision Enhancements Via Vector Extensions] // BDTI, September 29, 2015</ref><ref>{{Cite news |title=Qualcomm's new Hexagon 680 DSP: Fast, efficient, shipping with Snapdragon 820 - ExtremeTech |url=https://www.extremetech.com/gaming/212817-qualcomms-new-hexagon-680-dsp-fast-efficient-shipping-with-snapdragon-820 |access-date=2022-06-10 |newspaper=Extremetech|date=25 August 2015 |last1=Hruska |first1=Joel }}</ref> & 821)
787 (660)<ref>{{Cite web |title=Qualcomm SDM660 SoC {{!}} Integrated LTE Application Processor based on Snapdragon 660 {{!}} Qualcomm |url=https://www.qualcomm.com/products/technology/processors/application-processors/sdm660 |access-date=2022-06-09 |website=www.qualcomm.com |language=en}}</ref>
|Snapdragon
|Snapdragon
820/821/636/660
820/821/636/660
Line 184: Line 183:
|
|
|Snapdragon
|Snapdragon
695/680/665/480/480+
695/685/680/665/480/480+
|-
|-
|688
|688
Line 248: Line 247:
|
|
|Snapdragon
|Snapdragon
778G/778G+/780G
778G/778G+/780G/782G
|
|-
|-
|780
|780
Line 259: Line 257:
|Snapdragon
|Snapdragon
888/888+
888/888+
|-
|790
|?
|2022
|?
|
|
|Snapdragon 8 gen 1 / 8+ gen 1
|}
|}


Line 270: Line 276:
! Snapdragon generation
! Snapdragon generation
! Chipset (SoC) ID
! Chipset (SoC) ID
! DSP Generation
! DSP generation
! DSP Frequency, MHz
! DSP frequency, MHz
! Process node, nm
! Process node, nm
|-
|-
Line 292: Line 298:
! Chipset (SoC) ID
! Chipset (SoC) ID
! QDSP6 version
! QDSP6 version
! DSP Frequency, MHz
! DSP frequency, MHz
! Process node, nm
! Process node, nm
|-
|-
Line 311: Line 317:
| S800<ref name="qualcomm-x00-2013"/> || 8974, 8274, 8674, 8074 || QDSP6V5A || 600 || 28 HPm
| S800<ref name="qualcomm-x00-2013"/> || 8974, 8274, 8674, 8074 || QDSP6V5A || 600 || 28 HPm
|-
|-
| S820<ref name="bdti-v6-2015-09"/> || 8996 || QDSP6V6 || 2000 || 14 FinFet LPP
| S820<ref name="bdti-v6-2015-09"/> || 8996 || QDSP6V6 || 2000 || 14 FinFET LPP
|}
|}



== Hardware codec supported ==
== Hardware codec supported ==
The different video codecs supported by the snapdragon SoCs.
The different video codecs supported by the Snapdragon SoCs.


'''D''' - decode; '''E''' - encode
'''D''' - decode; '''E''' - encode
Line 325: Line 330:


=== Snapdragon 200 series ===
=== Snapdragon 200 series ===
The different video codecs supported by the snapdragon 200 series.
The different video codecs supported by the Snapdragon 200 series.
{| class="wikitable"
{| class="wikitable"
! Codec
! Codec
Line 439: Line 444:


=== Snapdragon 400 series ===
=== Snapdragon 400 series ===
The different video codecs supported by the snapdragon 400 series.
The different video codecs supported by the Snapdragon 400 series.
{| class="wikitable"
{| class="wikitable"
! Codec
! Codec
Line 458: Line 463:
460<ref>{{Cite web|title=Snapdragon 460 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-460-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=14 January 2020}}</ref>
460<ref>{{Cite web|title=Snapdragon 460 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-460-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=14 January 2020}}</ref>
!Snapdragon
!Snapdragon
480<ref>{{Cite web|title=Qualcomm Snapdragon 480 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-480-5g-mobile-platform|access-date=2021-01-19|website=www.qualcomm.com|date=11 December 2020}}</ref>
480/480+<ref>{{Cite web|title=Qualcomm Snapdragon 480 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-480-5g-mobile-platform|access-date=2021-01-19|website=www.qualcomm.com|date=11 December 2020}}</ref>
|-
|-
! Availability
! Availability
Line 476: Line 481:
|546
|546
|683
|683
|
|686
|-
|-
|[[H.263|H263]]
|[[H.263|H263]]
Line 554: Line 559:
| {{No|-}}
| {{No|-}}
| {{No|-}}
| {{No|-}}
| {{No|-}}|
| {{No|-}}
| {{No|-}}
| {{No|-}}
| {{No|-}}
| {{No|-}}
Line 626: Line 631:


=== Snapdragon 600 series ===
=== Snapdragon 600 series ===
The different video codecs supported by the snapdragon 600 series.
The different video codecs supported by the Snapdragon 600 series.
{| class="wikitable"
{| class="wikitable"
! Codec
! Codec
Line 637: Line 642:
! style="width: 8em;" | Snapdragon 662<ref name="Qualcomm Snapdragon 662">{{cite web |url=https://www.qualcomm.com/products/snapdragon-662-mobile-platform |title=Snapdragon 662 Mobile Platform |date=14 January 2020 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20210110153634/https://www.qualcomm.com/products/snapdragon-662-mobile-platform |archive-date=January 10, 2021 |url-status=live }}</ref>
! style="width: 8em;" | Snapdragon 662<ref name="Qualcomm Snapdragon 662">{{cite web |url=https://www.qualcomm.com/products/snapdragon-662-mobile-platform |title=Snapdragon 662 Mobile Platform |date=14 January 2020 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20210110153634/https://www.qualcomm.com/products/snapdragon-662-mobile-platform |archive-date=January 10, 2021 |url-status=live }}</ref>
! style="width: 8em;" | Snapdragon 665<ref name="Qualcomm Snapdragon 665">{{cite web |url=https://www.qualcomm.com/products/snapdragon-665-mobile-platform |title=Snapdragon 665 Mobile Platform |date=27 March 2019 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20201204174846/https://www.qualcomm.com/products/snapdragon-665-mobile-platform |archive-date=December 4, 2020 |url-status=live }}</ref>
! style="width: 8em;" | Snapdragon 665<ref name="Qualcomm Snapdragon 665">{{cite web |url=https://www.qualcomm.com/products/snapdragon-665-mobile-platform |title=Snapdragon 665 Mobile Platform |date=27 March 2019 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20201204174846/https://www.qualcomm.com/products/snapdragon-665-mobile-platform |archive-date=December 4, 2020 |url-status=live }}</ref>
!Snapdragon 670<ref>{{Cite web|title=Snapdragon 670 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-670-mobile-platform|access-date=2020-09-07|website=www.qualcomm.com|date=2 October 2018}}</ref>
!Snapdragon 670/675/678<ref name="qualcomm.com">{{Cite web|title=Snapdragon 670 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-670-mobile-platform|access-date=2020-09-07|website=www.qualcomm.com|date=2 October 2018}}</ref>
!Snapdragon 690<ref name="Qualcomm Snapdragon 690">{{cite web |url=https://www.qualcomm.com/products/snapdragon-690-5g-mobile-platform |title=Snapdragon 690 5G Mobile Platform |date=2 June 2020 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20210125233142/https://www.qualcomm.com/products/snapdragon-690-5g-mobile-platform |archive-date=January 21, 2021 |url-status=live }}</ref>
!Snapdragon 690<ref name="Qualcomm Snapdragon 690">{{cite web |url=https://www.qualcomm.com/products/snapdragon-690-5g-mobile-platform |title=Snapdragon 690 5G Mobile Platform |date=2 June 2020 |publisher=Qualcomm |access-date=February 15, 2021 |archive-url=https://web.archive.org/web/20210125233142/https://www.qualcomm.com/products/snapdragon-690-5g-mobile-platform |archive-date=January 25, 2021 |url-status=live }}</ref>
|-
|-
! Availability
! Availability
Line 679: Line 684:
|
|
|
|
| {{partial|D<ref name="Kodi Codec SoC Support">{{Citation |url=https://web.archive.org/web/20180130112623/http://kodi.wiki:80/view/Android_hardware#Compatible_chipsets |title=Kodi Codec SoC Hardware-Support |access-date=2018-01-30 |archive-url=https://web.archive.org/web/20181230130452/https://web.archive.org/web/20180130112623/http://kodi.wiki:80/view/Android_hardware#Compatible_chipsets |archive-date=December 30, 2018 |url-status=live }}</ref> & ?}}
| {{partial|D<ref name="Kodi Codec SoC Support">{{Citation |url=http://kodi.wiki:80/view/Android_hardware#Compatible_chipsets |title=Kodi Codec SoC Hardware-Support |access-date=2018-01-30 |archive-url=https://web.archive.org/web/20180130112623/http://kodi.wiki:80/view/Android_hardware#Compatible_chipsets |archive-date=January 30, 2018 |url-status=live }}</ref> & ?}}
|
|
|
|
Line 744: Line 749:
| {{partial|D & ?}}
| {{partial|D & ?}}
| {{No|-}}
| {{No|-}}
| {{partial|D & ?}}
| {{No|-}}
|
|
| {{Yes|D & E}}
| {{Yes|D & E}}
Line 829: Line 834:
| No 4K
| No 4K
| 4K60 fps
| 4K60 fps
| 4K60 fps<ref name="qualcomm.com"/>
| 4K60 fps<ref>{{Cite web|title=Snapdragon 670 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-670-mobile-platform|access-date=2020-09-07|website=www.qualcomm.com|date=2 October 2018}}</ref>
| 4K60 fps
| 4K60 fps
|-
|-
Line 896: Line 901:


=== Snapdragon 700 series ===
=== Snapdragon 700 series ===
The different video codecs supported by the snapdragon 700 series.
The different video codecs supported by the Snapdragon 700 series.
{| class="wikitable"
{| class="wikitable"
! Codec
! Codec
Line 906: Line 911:
730G<ref>{{Cite web|title=Snapdragon 730 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-730-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=13 March 2019}}</ref>/732G<ref>{{Cite web|title=Snapdragon 732G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-732g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=17 August 2020}}</ref>
730G<ref>{{Cite web|title=Snapdragon 730 Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-730-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=13 March 2019}}</ref>/732G<ref>{{Cite web|title=Snapdragon 732G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-732g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=17 August 2020}}</ref>
!Snapdragon
!Snapdragon
765<ref>{{Cite web|title=Snapdragon 765 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-765-5g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=19 November 2019}}</ref>/765G<ref>{{Cite web|title=Snapdragon 768G 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-768g-5g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=May 2020}}</ref>
765<ref>{{Cite web|title=Snapdragon 765 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-765-5g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=19 November 2019}}</ref>/765G<ref name="ReferenceA">{{Cite web|title=Snapdragon 768G 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-768g-5g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=May 2020}}</ref>


/768G<ref name="ReferenceA"/>
/768G<ref>{{Cite web|title=Snapdragon 768G 5G Mobile Platform {{!}} Qualcomm|url=https://www.qualcomm.com/products/snapdragon-768g-5g-mobile-platform|access-date=2020-09-08|website=www.qualcomm.com|date=May 2020}}</ref>
!Snapdragon
!Snapdragon
778G<ref>{{Cite web|title=Snapdragon 778G 5G Mobile Platform|url=https://www.qualcomm.com/products/snapdragon-778g-5g-mobile-platform|access-date=2021-11-21|website=www.qualcomm.com}}</ref>
778G
!Snapdragon
!Snapdragon
780G<ref>{{Cite web|title=Snapdragon 780G 5G Mobile Platform|url=https://www.qualcomm.com/products/snapdragon-780g-5g-mobile-platform|access-date=2021-11-22|website=www.qualcomm.com}}</ref>
780G
|-
|-
! Availability
! Availability
|Q2 2018 / Q1 2019
|TBA
|Q1 2020
|Q1 2020
|Q2 2019 / Q3 2020
|?
|Q2 2019 / Q2 2019 / Q2 2020
|?
|Q2 2021
|
|Q1 2021
|
|-
|-
! Hexagon
! Hexagon
Line 927: Line 932:
|688
|688
|696
|696
|
|770
|
|770
|-
|-
|[[H.263|H263]]
|[[H.263|H263]]
Line 1,099: Line 1,104:
| {{n/a}}
| {{n/a}}
| {{n/a}}
| {{n/a}}
| colspan="2" |10-bit [[High Dynamic Range (color representation)#HDR%20in%20still%20images|HDR]] HEIF
| colspan="2" |10-bit [[High Dynamic Range (color representation)#HDR in still images|HDR]] HEIF
|}
|}


Line 1,128: Line 1,133:
!Snapdragon
!Snapdragon
888<ref name="Snapdragon 888">{{cite web |url= https://www.qualcomm.com/products/snapdragon-888-5g-mobile-platform |title= Snapdragon 888 5G Mobile Platform |date= 17 November 2020 |publisher= Qualcomm |access-date= February 15, 2021 |archive-url= https://web.archive.org/web/20210128085627/https://www.qualcomm.com/products/snapdragon-888-5g-mobile-platform |archive-date= January 28, 2021 |url-status= live }}</ref>
888<ref name="Snapdragon 888">{{cite web |url= https://www.qualcomm.com/products/snapdragon-888-5g-mobile-platform |title= Snapdragon 888 5G Mobile Platform |date= 17 November 2020 |publisher= Qualcomm |access-date= February 15, 2021 |archive-url= https://web.archive.org/web/20210128085627/https://www.qualcomm.com/products/snapdragon-888-5g-mobile-platform |archive-date= January 28, 2021 |url-status= live }}</ref>
!Snapdragon
8 gen 1
|-
|-
! Availability
! Availability
Line 1,142: Line 1,149:
2021
2021
|Q4 2020
|Q4 2020
|2021
|-
|-
! Hexagon
! Hexagon
Line 1,154: Line 1,162:
|698
|698
|780
|780
|790
|-
|-
|MPEG-4
|MPEG-4
Line 1,166: Line 1,175:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[H.263|H263]]
|[[H.263|H263]]
Line 1,178: Line 1,188:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[VC-1]]
|[[VC-1]]
Line 1,190: Line 1,201:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[H.264/MPEG-4 AVC|H.264]]
|[[H.264/MPEG-4 AVC|H.264]]
Line 1,202: Line 1,214:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|H.264 10-bit
|H.264 10-bit
Line 1,214: Line 1,227:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[VP8]]
|[[VP8]]
Line 1,226: Line 1,240:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[High Efficiency Video Coding|H.265]]
|[[High Efficiency Video Coding|H.265]]
Line 1,238: Line 1,253:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|H.265 10-bit
|H.265 10-bit
Line 1,250: Line 1,266:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|[[VP9]]
|[[VP9]]
Line 1,262: Line 1,279:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|VP9 10-bit
|VP9 10-bit
Line 1,274: Line 1,292:
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
| {{Yes|D & E}}
|
|-
|-
|AV1
|AV1
Line 1,286: Line 1,305:
| {{No|N/A}}
| {{No|N/A}}
| {{No|N/A}}
| {{No|N/A}}
|
|-
|-
|[[Versatile Video Coding|VVC]]
|[[Versatile Video Coding|VVC]]
Line 1,298: Line 1,318:
| {{No|N/A}}
| {{No|N/A}}
| {{No|N/A}}
| {{No|N/A}}
|
|-
|-
! colspan="11" |[[Frame rate|FPS]]
! colspan="11" |[[Frame rate|FPS]]
!
|-
|-
| rowspan="4" |Decoding
| rowspan="4" |Decoding
Line 1,307: Line 1,329:
| HD@480<ref name="Snapdragon 845" />
| HD@480<ref name="Snapdragon 845" />
|HD@480<ref>{{Cite web|url=https://www.xda-developers.com/qualcomm-spectra-380-isp-integrated-ai/|title=Qualcomm Spectra 380 Launched: World's First ISP With Integrated AI|date=2018-12-05|website=xda-developers|language=en-US|access-date=2018-12-06|archive-url=https://web.archive.org/web/20181206053509/https://www.xda-developers.com/qualcomm-spectra-380-isp-integrated-ai/|archive-date=December 6, 2018|url-status=live}}</ref>
|HD@480<ref>{{Cite web|url=https://www.xda-developers.com/qualcomm-spectra-380-isp-integrated-ai/|title=Qualcomm Spectra 380 Launched: World's First ISP With Integrated AI|date=2018-12-05|website=xda-developers|language=en-US|access-date=2018-12-06|archive-url=https://web.archive.org/web/20181206053509/https://www.xda-developers.com/qualcomm-spectra-380-isp-integrated-ai/|archive-date=December 6, 2018|url-status=live}}</ref>
| colspan="2" |HD@960
| colspan="3" |HD@960
|-
|-
| colspan="3" | FHD@60
| colspan="3" | FHD@60
Line 1,314: Line 1,336:
|FHD@240
|FHD@240
| colspan="2" {{dunno}}
| colspan="2" {{dunno}}
|
|-
|-
| colspan="4" | 4K@30
| colspan="4" | 4K@30
| colspan="3" | 4K@60
| colspan="3" | 4K@60
| {{dunno}}
| {{dunno}}
| colspan="2" |4K@120
| colspan="3" |4K@120
|-
|-
| colspan="7" {{n/a}}
| colspan="7" {{n/a}}
| colspan="3" |8K@30
|8K@?
| colspan="3" |8K@60
|-
|-
| rowspan="4" |Encoding
| rowspan="4" |Encoding
Line 1,329: Line 1,353:
| HD@480<ref name=":0">{{Cite web|url=https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|title=Product Brief Snapdragon 845|date=2018|website=Qualcomm|access-date=June 12, 2018|archive-url=https://web.archive.org/web/20180612162951/https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|archive-date=June 12, 2018|url-status=live}}</ref>
| HD@480<ref name=":0">{{Cite web|url=https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|title=Product Brief Snapdragon 845|date=2018|website=Qualcomm|access-date=June 12, 2018|archive-url=https://web.archive.org/web/20180612162951/https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|archive-date=June 12, 2018|url-status=live}}</ref>
|HD@480
|HD@480
| colspan="2" |HD@960
| colspan="3" |HD@960
|-
|-
| colspan="3" | FHD@60
| colspan="3" | FHD@60
Line 1,336: Line 1,360:
|[[1080p|FHD]]@240
|[[1080p|FHD]]@240
| colspan="2" {{dunno}}
| colspan="2" {{dunno}}
|
|-
|-
| colspan="6" | 4K@30
| colspan="6" | 4K@30
|[[4K resolution|4K]]@60<ref name=":0" />
|[[4K resolution|4K]]@60<ref name=":0" />
|4K@60
|4K@60
| colspan="2" |4K@120
| colspan="3" |4K@120
|-
|-
| colspan="8" {{n/a}}
| colspan="8" {{n/a}}
| colspan="2" |8K@30
| colspan="3" |8K@30
|-
|-
! colspan="11" |[[High Dynamic Range (color representation)|HDR]] formats
! colspan="11" |[[High Dynamic Range (color representation)|HDR]] formats
!
|-
|-
|Display and
|Display and
Line 1,353: Line 1,379:
|[[HDR10]],
|[[HDR10]],
[[HLG10|HLG]]<ref name=":02">{{Cite web|date=2018|title=Product Brief Snapdragon 845|url=https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|url-status=live|archive-url=https://web.archive.org/web/20180612162951/https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|archive-date=June 12, 2018|access-date=June 12, 2018|website=Qualcomm}}</ref>
[[HLG10|HLG]]<ref name=":02">{{Cite web|date=2018|title=Product Brief Snapdragon 845|url=https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|url-status=live|archive-url=https://web.archive.org/web/20180612162951/https://www.qualcomm.com/media/documents/files/snapdragon-845-mobile-platform-product-brief.pdf|archive-date=June 12, 2018|access-date=June 12, 2018|website=Qualcomm}}</ref>
| colspan="3" |[[HDR10]], [[HLG10|HLG]],
| colspan="4" |[[HDR10]], [[HLG10|HLG]],
[[HDR10+]], [[Dolby Vision]]
[[HDR10+]], [[Dolby Vision]]
|-
|-
Line 1,363: Line 1,389:
|[[HDR10]], [[HLG10|HLG]],
|[[HDR10]], [[HLG10|HLG]],
[[HDR10+]]
[[HDR10+]]
| colspan="2" |[[HDR10]], [[HLG10|HLG]],
| colspan="3" |[[HDR10]], [[HLG10|HLG]],
[[HDR10+]], [[Dolby Vision]]
[[HDR10+]], [[Dolby Vision]]
|-
|-
Line 1,369: Line 1,395:
recording
recording
| colspan="9" {{n/a}}
| colspan="9" {{n/a}}
|10-bit [[High Dynamic Range (color representation)#HDR%20in%20still%20images|HDR]] HEIF
| colspan="2" |10-bit [[High Dynamic Range (color representation)#HDR in still images|HDR]] HEIF
|}
|}


Line 1,416: Line 1,442:


[[Category:Digital signal processors]]
[[Category:Digital signal processors]]
[[Category:Instruction set architectures]]
[[Category:Qualcomm IP cores]]
[[Category:Qualcomm IP cores]]
[[Category:Very long instruction word computing]]
[[Category:Very long instruction word computing]]
[[Category:Video compression and decompression ASIC]]
[[Category:AI accelerators]]

Latest revision as of 16:36, 18 July 2024

Hexagon
DesignerQualcomm
Bits32-bit, 64-bit
Introduced2006 (QDSP6)
Design4-way multithreaded VLIW
TypeLoad–store
EncodingFixed 4 byte per instruction, up to 4 instructions in VLIW multiinstruction
OpenProprietary
Registers
General-purpose32-bit GPR: 32, can be paired to 64-bit[1]

Hexagon is the brand name for a family of digital signal processor (DSP) and later neural processing unit (NPU) products by Qualcomm.[2] Hexagon is also known as QDSP6, standing for “sixth generation digital signal processor.” According to Qualcomm, the Hexagon architecture is designed to deliver performance with low power over a variety of applications.[3][4]

Each version of Hexagon has an instruction set and a micro-architecture. These two features are intimately related.

Hexagon is used in Qualcomm Snapdragon chips, for example in smartphones, cars, wearable devices and other mobile devices and is also used in components of cellular phone networks.

Instruction set architecture

[edit]

Computing devices have instruction sets, which are their lowest, most primitive languages. Common instructions are those which cause two numbers to be added, multiplied or combined in other ways, as well as instructions that direct the processor where to look in memory for its next instruction. There are many other types of instructions.

Assemblers and compilers that translate computer programs into streams of instructions – bit streams - that the device can understand and carry out (execute). As an instruction stream executes, the integrity of system function is supported by the use of instruction privilege levels. Privileged instructions have access to more resources in the device, including memory. Hexagon supports privilege levels.

Originally, Hexagon instructions operated on integer numbers but not floating point numbers,[5] but in v5 floating point support was added.[6]

The processing unit which handles execution of instructions is capable of in-order dispatching up to 4 instructions (the packet) to 4 Execution Units every clock.[7][8]

Micro-architecture

[edit]

Micro-architecture is the physical structure of a chip or chip component that makes it possible for a device to carry out the instructions. A given instruction set can be implemented by a variety of micro-architectures. The buses – data transfer channels – for Hexagon devices are 32 bits wide. That is, 32 bits of data can be moved from one part of the chip to another in a single step. The Hexagon micro-architecture is multi-threaded,[4] which means that it can simultaneously process more than one stream of instructions, enhancing data processing speed. Hexagon supports very long instruction words,[9][10] which are groupings of four instructions that can be executed “in parallel.” Parallel execution means that multiple instructions can run simultaneously without one instruction having to complete before the next one starts. The Hexagon micro-architecture supports single instruction, multiple data operations,[11] which means that when a Hexagon device receives an instruction, it can carry out the operation on more than one piece of data at the same time.

According to 2012 estimation, Qualcomm shipped 1.2 billion DSP cores inside its system on a chip (SoCs) (average 2.3 DSP core per SoC) in 2011, and 1.5 billion cores were planned for 2012, making the QDSP6 the most shipped architecture of DSP[12] (CEVA had around 1 billion of DSP cores shipped in 2011 with 90% of IP-licensable DSP market[13]).

The Hexagon architecture is designed to deliver performance with low power over a variety of applications. It has features such as hardware assisted multithreading, privilege levels, Very Long Instruction Word (VLIW), Single Instruction Multiple Data (SIMD),[14][15] and instructions geared toward efficient signal processing. Hardware multithreading is implemented as barrel temporal multithreading - threads are switched in round-robin fashion each cycle, so the 600 MHz physical core is presented as three logical 200 MHz cores before V5.[16][17] Hexagon V5 switched to dynamic multithreading (DMT) with thread switch on L2 misses, interrupt waiting or on special instructions.[17][18]

At Hot Chips 2013 Qualcomm announced details of their Hexagon 680 DSP. Qualcomm announced Hexagon Vector Extensions (HVX). HVX is designed to allow significant compute workloads for advanced imaging and computer vision to be processed on the DSP instead of the CPU.[19] In March 2015 Qualcomm announced their Snapdragon Neural Processing Engine SDK which allow AI acceleration using the CPU, GPU and Hexagon DSP.[20]

Qualcomm's Snapdragon 855 contains their 4th generation on-device AI engine, which includes the Hexagon 690 DSP and Hexagon Tensor Accelerator (HTA) for AI acceleration.[21] Snapdragon 865 contains the 5th generation on-device AI engine based on the Hexagon 698 DSP capable of 15 trillion operations per second (TOPS).[22] Snapdragon 888 contains the 6th generation on-device AI engine based on the Hexagon 780 DSP capable of 26 TOPS.[23] Snapdragon 8 contains the 7th generation on-device AI engine based on the Hexagon DSP capable of 52 TOPS and up to 104 TOPS in some cases.[24]

Software support

[edit]

Operating systems

[edit]

The port of Linux for Hexagon runs under a hypervisor layer ("Hexagon Virtual Machine"[25]) and was merged with the 3.2 release of the kernel.[26][27] The original hypervisor is closed-source, and in April 2013 a minimal open-source hypervisor implementation for QDSP6 V2 and V3, the "Hexagon MiniVM" was released by Qualcomm under a BSD-style license.[28][29]

Compilers

[edit]

Support for Hexagon was added in 3.1 release of LLVM by Tony Linthicum.[30] Hexagon/HVX V66 ISA support was added in 8.0.0 release of LLVM.[31] There is also a non-FSF maintained branch of GCC and binutils.[32]

Adoption of the SIP block

[edit]

Qualcomm Hexagon DSPs have been available in Qualcomm Snapdragon SoC since 2006.[33][34] In Snapdragon S4 (MSM8960 and newer) there are three QDSP cores, two in the Modem subsystem and one Hexagon core in the Multimedia subsystem. Modem cores are programmed by Qualcomm only, and only Multimedia core is allowed to be programmed by user.

They are also used in some femtocell processors of Qualcomm, including FSM98xx, FSM99xx and FSM90xx.[35]

Third-party integration

[edit]

In March 2016, it was announced that semiconductor company Conexant's AudioSmart audio processing software was being integrated into Qualcomm's Hexagon.[36]

In May 2018 wolfSSL added support for using Qualcomm Hexagon.[37] This is support for running wolfSSL crypto operations on the DSP. In addition to use of crypto operations a specialized operation load management library was later added.

Versions

[edit]

There are six versions of QDSP6 architecture released: V1 (2006), V2 (2007–2008), V3 (2009), V4 (2010–2011), QDSP6 V5 (2013, in Snapdragon 800[38]); and QDSP6 V6 (2016, in Snapdragon 820).[34] V4 has 20 DMIPS per milliwatt, operating at 500 MHz.[33][34] Clock speed of Hexagon varies in 400–2000 MHz for QDSP6 and in 256–350 MHz for previous generation of the architecture, the QDSP5.[39]

Versions of QDSP6 Process node, nm Year[17] Number of simultaneous threads Per-thread clock, MHz Total core clock, MHz Product
QDSP6 V1 65[17] 2006
QDSP6 V2[40] 65 2007[17] 6 100 600
QDSP6 V3 (1st gen)[40] 45 2009 6 67 400
QDSP6 V3 (2nd gen)[40] 45 2009 4 100 400
QDSP6 V4[40] (V4M, V4C, V4L[17]) 28 2010 3[18] 167 500 Snapdragon

600

QDSP6 V5[41] (V5A, V5H[17]) 28 2013 3[17] 200 or greater with DMT[18] 600 Snapdragon

410/412/800/801

536 12/28 2014 205/208/210/212

Snapdragon 425/427/429/430/435/439

V50 28 2014 Snapdragon

415/610/615/616/805

546 14/28 2015 Snapdragon

450/617/625/626/632

V56 20/28 2015 Snapdragon

650/652/653/808/810

642 14 2017 Snapdragon

630

QDSP6 V6 or 680 14 2016 4 500 2000 (820[42][43] & 821)

787 (660)[44]

Snapdragon

820/821/636/660

682 10 2017 Snapdragon

835

683 11 2020 Snapdragon

662/460

685 10/11 2018 (3 TOPS) Snapdragon

850/845/670/675/678/710/712

686 6/8/11 2019 (3.3 TOPS) Snapdragon

695/685/680/665/480/480+

688 8 2019 (3.6 TOPS) Snapdragon

730(G)/732G

690 7 2019 (7 TOPS) Snapdragon

855/855+/860/8c/8cx
Microsoft SQ1/SQ2

692 8 2020 (5 TOPS) Snapdragon

720G/690/7c

694 8 2020 (4.7 TOPS) Snapdragon

750G

696 7 2020 (5.4 TOPS) Snapdragon

765(G)/768G

698 7 2020 (15 TOPS) Snapdragon

865/865+/870

770 5/6 2021 (12 TOPS) Snapdragon

778G/778G+/780G/782G

780 5 2021 (26 TOPS/ 32TOPS) Snapdragon

888/888+

790 ? 2022 ? Snapdragon 8 gen 1 / 8+ gen 1

Availability in Snapdragon products

[edit]

Both Hexagon (QDSP6) and pre-Hexagon (QDSP5) cores are used in modern Qualcomm SoCs, QDSP5 mostly in low-end products. Modem QDSPs (often pre-Hexagon) are not shown in the table.

QDSP5 usage:

Snapdragon generation Chipset (SoC) ID DSP generation DSP frequency, MHz Process node, nm
S1[39] MSM7627, MSM7227, MSM7625, MSM7225 QDSP5 320 65
S1[39] MSM7627A, MSM7227A, MSM7625A, MSM7225A QDSP5 350 45
S2[39] MSM8655, MSM8255, APQ8055, MSM7630, MSM7230 QDSP5 256 45
S4 Play[39] MSM8625, MSM8225 QDSP5 350 45
S200[45] 8110, 8210, 8610, 8112, 8212, 8612, 8225Q, 8625Q QDSP5 384 45 LP

QDSP6 (Hexagon) usage:

Snapdragon generation Chipset (SoC) ID QDSP6 version DSP frequency, MHz Process node, nm
S1[39] QSD8650, QSD8250 QDSP6 600 65
S3[39] MSM8660, MSM8260, APQ8060 QDSP6 (V3?) 400 45
S4 Prime[39] MPQ8064 QDSP6 (V3?) 500 28
S4 Pro[39] MSM8960 Pro, APQ8064 QDSP6 (V3?) 500 28
S4 Plus[39] MSM8960, MSM8660A, MSM8260A, APQ8060A, MSM8930,
MSM8630, MSM8230, APQ8030, MSM8627, MSM8227
QDSP6 (V3?) 500 28
S400[45] 8926, 8930, 8230, 8630, 8930AB, 8230AB, 8630AB, 8030AB, 8226, 8626 QDSP6V4 500 28 LP
S600[45] 8064T, 8064M QDSP6V4 500 28 LP
S800[45] 8974, 8274, 8674, 8074 QDSP6V5A 600 28 HPm
S820[42] 8996 QDSP6V6 2000 14 FinFET LPP

Hardware codec supported

[edit]

The different video codecs supported by the Snapdragon SoCs.

D - decode; E - encode

FHD = FullHD = 1080p = 1920x1080px

HD = 720p which can be 1366x768px or 1280x720px

Snapdragon 200 series

[edit]

The different video codecs supported by the Snapdragon 200 series.

Codec Snapdragon

200[46]

Snapdragon

200[46]

Qualcomm

205[47]

Snapdragon

208/210[48]

Snapdragon

212[49]

Availability 2013 2013 2017 2014 2015
Hexagon QDSP5 QDSP6 536 536 536
H263 D & E D & E D & E D & E D & E
VC-1
H.264 D & E D & E D & E D & E D & E
H.264 10-bit - - - - -
VP8 D & E D & E D & E D & E D & E
H.265 D HD & E HD D HD & E HD D HD & E HD D FHD & E HD D FHD & E HD
H.265 10-bit - - - - -
H.265 12-bit - - - - -
VVC
VP9 - - - - -
VP9 10-bit - - - - -
AV1 - - - - -

Snapdragon 400 series

[edit]

The different video codecs supported by the Snapdragon 400 series.

Codec Snapdragon

400[50]

Snapdragon

410/415[51]

Snapdragon

425/427

Snapdragon

429/439[52]

Snapdragon

450[53]

Snapdragon

460[54]

Snapdragon

480/480+[55]

Availability Q4 2013 2014/2015 Q1 2016/Q3 2017 Q2 2018 Q2 2017 Q1 2020 Q1 2021
Hexagon QDSP6 QDSP6 V5 536(256KB) 536 546 683 686
H263 D & E D & E D & E D & E D & E D & E D & E
VC-1
H.264 D & E D & E D & E D & E D & E D & E D & E
H.264 10-bit - - - - - - D & E
VP8 D & E D & E D & E D & E D & E D & E D & E
H.265 - D & E D & E D & E D & E D & E D & E
H.265 10-bit - - - - - -
H.265 12-bit - - - - - -
VVC - - - - - -
VP9 - - - - D & E D & E
VP9 10-bit - - - - - -
AV1 - - - - - - -
Video frame rate

support Decoding

HD 60 fps
FHD 60 fps FHD 60 fps FHD 60 fps
Video frame

rate support

Encoding

HD 60 fps
FHD 60 fps FHD 60 fps FHD 60 fps

Snapdragon 600 series

[edit]

The different video codecs supported by the Snapdragon 600 series.

Codec Snapdragon 600[56] Snapdragon 610[57] Snapdragon 650/652/653 Snapdragon 630[58] Snapdragon 632[52] Snapdragon 636/660[58] Snapdragon 662[59] Snapdragon 665[60] Snapdragon 670/675/678[61] Snapdragon 690[62]
Availability Q1 2013 Q1 2015 Q2 2018 Q1 2020 Q2 2019 2019 Q2 2020
Hexagon QDSP6 V4 QDSP6 V50 QDSP6 V56 642 546 680 683 686 685 692
H263 D & E D & E D & E D & E D & E D & E D & E D & E D & E D & E
VC-1 D[63] & ?
H.264 D & E D & E D & E D & E D & E D & E D & E D & E D & E D & E
H.264 10-bit - - - - - - - - -
VP8 D & E D & E D & E D & E D & E D & E D & E D & E D & E D & E
H.265 - D & E D & E D & E D & E D & E D & E D & E D & E
H.265 10-bit - - - D & ? - D & ? - - D & E
VVC - - - - - - - - - -
VP9 - - D[63] & ? D & E D & E D & E D & E D & E D & E D & E
VP9 10-bit - - - - - - - - -
AV1 - - - - - - - - - -
FPS
Video decoding frame rate support HD 60 fps HD 120 fps HD 240 fps[64] HD 240 fps HD 240 fps[65] HD 60 fps HD 240 fps HD 240 fps HD 240 fps
FHD 30 fps FHD 60 fps FHD 120 fps FHD 120 fps[64] FHD 120 fps FHD 120 fps[65] FHD 60 fps FHD 120 fps FHD 120 fps FHD 120 fps
No 4K No 4K 4K30 fps 4K30 fps[64] 4K30 fps 4K30 fps[65] No 4K 4K60 fps 4K60 fps[61] 4K60 fps
Video encoding frame rate support HD 60 fps HD 60 fps HD 240 fps[64] HD 240 fps HD 240 fps[65] HD 60 fps HD 240 fps HD 240 fps HD 240 fps
FHD 30 fps FHD 30 fps FHD 120 fps FHD 120 fps[64] FHD 120 fps FHD 120 fps[65] FHD 60 fps FHD 120 fps FHD 120 fps FHD 120 fps
No 4K No 4K 4K30 fps 4K30 fps[64] 4K30 fps 4K30 fps[65] No 4K 4K30 fps 4K30 fps 4K30 fps
HDR formats
Display and

playback

HDR10, HLG
Video

recording

HDR10, HLG

Snapdragon 700 series

[edit]

The different video codecs supported by the Snapdragon 700 series.

Codec Snapdragon

710[66]/712[67]

Snapdragon

720G[68]

Snapdragon

730G[69]/732G[70]

Snapdragon

765[71]/765G[72]

/768G[72]

Snapdragon

778G[73]

Snapdragon

780G[74]

Availability Q2 2018 / Q1 2019 Q1 2020 Q2 2019 / Q3 2020 Q2 2019 / Q2 2019 / Q2 2020 Q2 2021 Q1 2021
Hexagon 685 692 688 696 770 770
H263 D & E D & E D & E D & E
VC-1 D & E D & E D & E D & E
H.264 D & E D & E D & E D & E
H.264 10-bit - - ? ?
VP8 D & E D & E D & E D & E
H.265 D & E D & E D & E D & E
H.265 10-bit D D D & E D & E
H.265 12-bit - - - -
VVC - - - -
VP9 D & E D & E D & E D & E
VP9 10-bit D D D D
AV1 - - - -
FPS
Video frame

rate support

Decoding

HD 240 fps HD 240 fps HD 240 fps HD 480 fps
FHD 120 fps FHD 120 fps FHD 120 fps ?
4K 30fps 4K 30fps 4K 30fps 4K 60fps
Video frame

rate support

Encoding

HD 240 fps HD 240 fps HD 240 fps HD 480 fps
FHD 120 fps FHD 120 fps FHD 120 fps ?
4K 30fps 4K 30fps 4K 30fps ?
HDR formats
Display and

playback

10-bit HDR HDR10, HLG HDR10, HLG, HDR10+
Video

recording

HDR10, HLG HDR10, HLG, HDR10+
Photo

recording

10-bit HDR HEIF

Snapdragon 800 series

[edit]

The different video codecs supported by the Snapdragon 800 series.

Codec Snapdragon

800[75]

Snapdragon

801[75]

Snapdragon

805[76]

Snapdragon

810[77]

Snapdragon

820/821[78]

Snapdragon

835[79]

Snapdragon

845/850[80]

Snapdragon

855/855+[81]

Snapdragon

865/865+

/870[82]

Snapdragon

888[83]

Snapdragon

8 gen 1

Availability Q2 2013 Q1 2014 Q1 2014 Q3 2014 Q4 2015

Q3 2016

Q2 2017 Q1 2018 2019 2019

2021

Q4 2020 2021
Hexagon QDSP6 V5 QDSP6 V5 QDSP6 V50 QDSP6 V56 680 682 685 690[84] 698 780 790
MPEG-4 D & E D & E D & E D & E D & E D & E D & E D & E D & E D & E
H263 D & E D & E D & E D & E D & E[85] D & E D & E D & E D & E D & E
VC-1 D & E D & E D & E D & E D & E D & E
H.264 D & E D & E D & E D & E D & E[86] D & E D & E D & E D & E D & E
H.264 10-bit N/A N/A N/A N/A N/A N/A D & E D & E D & E D & E
VP8 D & E D & E D & E D & E D & E[87] D & E D & E D & E D & E D & E
H.265 N/A D & E 720P30 D & E D & E D & E D & E D & E D & E D & E D & E
H.265 10-bit N/A N/A N/A N/A D D D & E D & E D & E D & E
VP9 N/A N/A N/A N/A D D & E D & E D & E D & E D & E
VP9 10-bit N/A N/A N/A N/A D D D & E D & E D & E D & E
AV1 N/A N/A N/A N/A N/A N/A N/A N/A N/A N/A
VVC N/A N/A N/A N/A N/A N/A N/A N/A N/A N/A
FPS
Decoding

FPS

HD@120 HD@240 HD@480[80] HD@480[88] HD@960
FHD@60 FHD@120 FHD@240[80] FHD@240 ?
4K@30 4K@60 ? 4K@120
8K@? 8K@60
Encoding

FPS

HD@120 HD@240 HD@480[89] HD@480 HD@960
FHD@60 FHD@120 FHD@240[89] FHD@240 ?
4K@30 4K@60[89] 4K@60 4K@120
8K@30
HDR formats
Display and

playback

HDR HDR10,

HLG[90]

HDR10, HLG,

HDR10+, Dolby Vision

Video

recording

HDR10,

HLG[90]

HDR10, HLG,

HDR10+

HDR10, HLG,

HDR10+, Dolby Vision

Photo

recording

10-bit HDR HEIF

Code sample

[edit]

This is a single instruction packet from the inner loop of a FFT:[8][18]

{ R17:16 = MEMD(R0++M1)
  MEMD(R6++M1) = R25:24
  R20 = CMPY(R20, R8):<<1:rnd:sat
  R11:10 = VADDH(R11:10, R13:12)
}:endloop0

This packet is claimed by Qualcomm to be equal to 29 classic RISC operations; it includes vector add (4x 16-bit), complex multiply operation and hardware loop support. All instructions of the packet are done in the same cycle.

See also

[edit]

References

[edit]
  1. ^ Baseband exploitation in 2013: Hexagon challenges Archived December 24, 2013, at the Wayback Machine /Ralf-Philipp Weinmann Pacsec 20132013-11-14, Tokyo, Japan: "32-bit unified address space for code and data – Byte addressable; 32 General registers (32-bit) – also usable pairwise: 64-bit register pairs"
  2. ^ "CSDL | IEEE Computer Society". www.computer.org. Retrieved 2024-06-08.
  3. ^ "Hexagon DSP SDK". Qualcomm Developer Network. Retrieved 2021-01-14.
  4. ^ a b "Hexagon DSP SDK Processor". Qualcomm Developer Network. Retrieved 2021-01-14.
  5. ^ Humrick, Matt. "Qualcomm Details Snapdragon 835: Kryo 280 CPU, Adreno 540 GPU, X16 LTE". www.anandtech.com. Retrieved 2021-01-14.
  6. ^ Group, Lindley. "Microprocessor Report" (PDF). {{cite web}}: |last= has generic name (help)
  7. ^ "Rob Landley's Blog Thing for 2012". Landley.net. Retrieved 2012-10-19.
  8. ^ a b Porting LLVM to a Next Generation DSP, L. Taylor Simpson (Qualcomm) // LLVM Developers’ Meeting: 11/18/2011
  9. ^ "Hexagon - Microarchitectures - Qualcomm - WikiChip". en.wikichip.org. Retrieved 2021-01-14.
  10. ^ Iqbal, Faisal. "Qualcomm Hexagon DSP".
  11. ^ Technologies, Qualcomm (2018). "Qualcomm Hexagon V66 HVX Programmer's Reference Manual" (PDF).
  12. ^ Will Strauss, Forward Concepts. Wireless/DSP Market Bulletin: Qualcomm Leads in Global DSP Silicon Shipments Archived May 28, 2013, at the Wayback Machine // Forward Concepts: "In calendar year 2011, Qualcomm shipped a reported 521 million MSM chip shipments and we estimate that an average of 2.3 of its DSP cores in each unit resulted in 1.2 billion DSPs shipped in silicon. This (calendar) year, we estimate that the company will ship an average of 2.4 DSP cores with each (more complex) MSM chip."
  13. ^ [1]; [2]; Ceva grabs 90% of DSP IP market, 2012
  14. ^ Hexagon v2 Programmers Reference
  15. ^ Lucian Codrescu (Qualcomm) (March–April 2014). "Hexagon DSP: An Architecture Optimized for Mobile Multimedia and Communications" (PDF). IEEE Micro 34.2. pp. 34–43.
  16. ^ Faster 128-EEA3 and 128-EIA3 Software, Roberto Avanzi and Billy Bob Brumley (Qualcomm Research), Cryptology ePrint Archive: Report 2013/428, 2 Jul 2013. Page 9.
  17. ^ a b c d e f g h Lucian Codrescu (Qualcomm) (August 2013). "Qualcomm Hexagon DSP: An architecture optimized for mobile multimedia and communications" (PDF). Palo Alto, CA: Hot Chips 25.
  18. ^ a b c d Qualcomm Extends Hexagon DSP: Hexagon v5 Adds Floating-Point Math, Dynamic Multithreading // Linley Gwennap, Microprocessor Report, August 2013
  19. ^ Ho, Joshua. "Qualcomm Details Hexagon 680 DSP in Snapdragon 820: Accelerated Imaging". www.anandtech.com. Retrieved 2019-05-12.
  20. ^ "On-Device AI with Qualcomm Snapdragon Neural Processing Engine SDK". Qualcomm Developer Network. Retrieved 2019-05-12.
  21. ^ "Artificial Intelligence Engine in Qualcomm Snapdragon 855 Mobile Platform Powers On-Device AI User Experiences in Flagship Premium-Tier Smartphones". Qualcomm. 2019-02-24. Retrieved 2019-05-12.
  22. ^ "Qualcomm Introduces the World's Most Advanced 5G Mobile Platform". Qualcomm. 2019-12-03. Retrieved 2023-05-14.
  23. ^ "Exploring the AI capabilities of the Qualcomm Snapdragon 888 Mobile Platform". Qualcomm. 2020-12-01. Retrieved 2023-05-14.
  24. ^ "Snapdragon 8 Gen 1 Mobile Platform". Qualcomm. 2020-12-01. Retrieved 2023-05-14.
  25. ^ https://docs.qualcomm.com/bundle/publicresource/80-NB419-3_REV_A_Hexagin_Virtual_Machine_Specification.pdf[permanent dead link] (restricted access)
  26. ^ "3.2 merge window, part 1". lwn.net. Retrieved 2012-10-19.
  27. ^ Linux Kernel 3.2 Release Notes "1.4. New architecture: Hexagon"
  28. ^ Richard Kuo, Hexagon MiniVM // linux.ports.hexagon, 25 Apr 2013
  29. ^ Hexagon MiniVM // CodeAurora (Qualcomm)
  30. ^ "LLVM 3.1 Release Notes". Llvm.org. 2012-05-15. Retrieved 2012-10-19.
  31. ^ "LLVM 8.0.0 Release Notes". Llvm.org. 2019-03-20. Retrieved 2019-04-03.
  32. ^ "Hexagon Project Wiki". Codeaurora.org. "Hexagon download".[permanent dead link]
  33. ^ a b Qualcomm Announces Its 2012 Superchip: 28nm Snapdragon S4, 10/12/2011 by John Oram. Quote: "Hexagon DSPs have been in Snapdragon chips since 2006."
  34. ^ a b c QDSP6 V4: Qualcomm Gives Customers and Developers Programming Access to its DSP Core // InsideDSP, June 22, 2012
  35. ^ Qualcomm Aims Hexagon at Femtocells, October 31, 2011. Linley Gwennap// Linley WIRE
  36. ^ "Qualcomm to Integrate Conexant AudioSmart into Hexagon DSPs". Speech Tech Magazine. 2016-03-01. Retrieved 2016-03-11.
  37. ^ "wolfSSL Use With Hexagon Toolchain". wolfSLS. 2018-05-18. Retrieved 2020-07-10.
  38. ^ Qualcomm Announces Next Generation Snapdragon Premium Mobile Processors // Qualcomm, January 07, 2013
  39. ^ a b c d e f g h i j "List of Snapdragon SoCs" (PDF). Developer.qualcomm.com. Archived from the original (PDF) on 2012-10-26. Retrieved 2012-10-19.
  40. ^ a b c d QDSP6 V4: BDTI Benchmark Results and Implementation Details Of Qualcomm's DSP Core // BDTI, February 12, 2013
  41. ^ Qualcomm's QDSP6 v5: Benchmarking Results Confirm That Floating-Point Support Has Arrived // BDTI, June 12, 2013
  42. ^ a b Qualcomm's QDSP6 v6: Imaging and Vision Enhancements Via Vector Extensions // BDTI, September 29, 2015
  43. ^ Hruska, Joel (25 August 2015). "Qualcomm's new Hexagon 680 DSP: Fast, efficient, shipping with Snapdragon 820 - ExtremeTech". Extremetech. Retrieved 2022-06-10.
  44. ^ "Qualcomm SDM660 SoC | Integrated LTE Application Processor based on Snapdragon 660 | Qualcomm". www.qualcomm.com. Retrieved 2022-06-09.
  45. ^ a b c d Snapdragon 800, 600, 400, 200 Processor Specs // Qualcomm
  46. ^ a b "Snapdragon 200 Processor". Qualcomm. October 2, 2018. Archived from the original on June 30, 2018. Retrieved June 30, 2018.
  47. ^ "Qualcomm 205 Mobile Platform". Qualcomm. Archived from the original on March 20, 2017. Retrieved March 20, 2017.
  48. ^ "Qualcomm unveils the Snapdragon 210 and 208 processors". Qualcomm. 9 September 2014. Archived from the original on February 25, 2016. Retrieved February 19, 2016.
  49. ^ "Snapdragon 412 and 212 processors announced". Qualcomm. July 28, 2015. Archived from the original on February 25, 2016. Retrieved February 18, 2016.
  50. ^ "Snapdragon 400 Processor". Qualcomm. Archived from the original on November 26, 2016. Retrieved November 17, 2016.
  51. ^ "Snapdragon 415 Processor". Qualcomm. Archived from the original on June 30, 2015. Retrieved June 28, 2015.
  52. ^ a b "Introducing Snapdragon 632, 439 and 429 for enhanced mobile experiences, superior performance". Qualcomm. 26 June 2018. Archived from the original on June 27, 2018. Retrieved June 27, 2018.
  53. ^ "Qualcomm Snapdragon 450 Mobile Platform to Bring 14nm FinFET Process, Enhanced Dual-Camera Support and Fast LTE Connectivity to Mid-Range Smartphones and Tablets". Qualcomm. 27 June 2017. Archived from the original on July 7, 2017. Retrieved June 29, 2017.
  54. ^ "Snapdragon 460 Mobile Platform | Qualcomm". www.qualcomm.com. 14 January 2020. Retrieved 2020-09-08.
  55. ^ "Qualcomm Snapdragon 480 5G Mobile Platform | Qualcomm". www.qualcomm.com. 11 December 2020. Retrieved 2021-01-19.
  56. ^ "Snapdragon 600 tier processors repositioned to reflect advanced performance". Qualcomm. December 2015. Archived from the original on December 22, 2015. Retrieved December 17, 2015.
  57. ^ "Snapdragon 610 Processor". Qualcomm. Archived from the original on November 4, 2016. Retrieved November 16, 2016.
  58. ^ a b "Qualcomm Snapdragon 660 and 630 Mobile Platforms Drive Advanced Photography, Enhanced Gaming, Integrated Connectivity and Machine Learning". Qualcomm. Archived from the original on May 9, 2017. Retrieved May 12, 2017.
  59. ^ "Snapdragon 662 Mobile Platform". Qualcomm. 14 January 2020. Archived from the original on January 10, 2021. Retrieved February 15, 2021.
  60. ^ "Snapdragon 665 Mobile Platform". Qualcomm. 27 March 2019. Archived from the original on December 4, 2020. Retrieved February 15, 2021.
  61. ^ a b "Snapdragon 670 Mobile Platform | Qualcomm". www.qualcomm.com. 2 October 2018. Retrieved 2020-09-07.
  62. ^ "Snapdragon 690 5G Mobile Platform". Qualcomm. 2 June 2020. Archived from the original on January 25, 2021. Retrieved February 15, 2021.
  63. ^ a b Kodi Codec SoC Hardware-Support, archived from the original on January 30, 2018, retrieved 2018-01-30
  64. ^ a b c d e f "Snapdragon 630 Mobile Platform with X12 LTE and Spectra 160 ISP | Qualcomm". Qualcomm. Archived from the original on June 21, 2018. Retrieved June 21, 2018.
  65. ^ a b c d e f "Snapdragon 660 Mobile Platform with Spectra ISP and Hexagon 680 DSP | Qualcomm". Qualcomm. Archived from the original on June 21, 2018. Retrieved June 21, 2018.
  66. ^ "Snapdragon 710 Mobile Platform". Qualcomm. Archived from the original on May 24, 2018. Retrieved May 24, 2018.
  67. ^ "Snapdragon 712 Mobile Platform | Qualcomm". www.qualcomm.com. 22 January 2019. Retrieved 2020-09-08.
  68. ^ "Snapdragon 720G Mobile Platform". Qualcomm. 14 January 2020. Archived from the original on March 11, 2020. Retrieved January 21, 2020.
  69. ^ "Snapdragon 730 Mobile Platform | Qualcomm". www.qualcomm.com. 13 March 2019. Retrieved 2020-09-08.
  70. ^ "Snapdragon 732G Mobile Platform | Qualcomm". www.qualcomm.com. 17 August 2020. Retrieved 2020-09-08.
  71. ^ "Snapdragon 765 5G Mobile Platform | Qualcomm". www.qualcomm.com. 19 November 2019. Retrieved 2020-09-08.
  72. ^ a b "Snapdragon 768G 5G Mobile Platform | Qualcomm". www.qualcomm.com. May 2020. Retrieved 2020-09-08.
  73. ^ "Snapdragon 778G 5G Mobile Platform". www.qualcomm.com. Retrieved 2021-11-21.
  74. ^ "Snapdragon 780G 5G Mobile Platform". www.qualcomm.com. Retrieved 2021-11-22.
  75. ^ a b Shimpi, Anand Lal. "The Difference Between Snapdragon 800 and 801: Clearing up Confusion". Archived from the original on June 15, 2018. Retrieved June 15, 2018.
  76. ^ "Qualcomm Technologies Announces Next Generation Qualcomm Snapdragon 805 "Ultra HD" Processor". Qualcomm. 20 November 2013. Archived from the original on February 25, 2016. Retrieved February 19, 2016.
  77. ^ "Qualcomm's Snapdragon 808/810". Archived from the original on April 8, 2014. Retrieved April 7, 2014.
  78. ^ First Snapdragon 820 powered smartphone announced at CES Archived January 5, 2017, at the Wayback Machine – Qualcomm.com, January 5, 2016
  79. ^ "Snapdragon 835 Mobile Platform". Qualcomm. Archived from the original on September 17, 2018. Retrieved February 20, 2018.
  80. ^ a b c "Snapdragon 845 Mobile Platform". Qualcomm. Archived from the original on December 7, 2017. Retrieved December 6, 2017.
  81. ^ "Snapdragon 855 Mobile Platform". Qualcomm. 7 November 2018. Archived from the original on December 7, 2018. Retrieved December 6, 2018.
  82. ^ "Snapdragon 865 5G Mobile Platform". Qualcomm. 19 November 2019. Archived from the original on December 4, 2019. Retrieved December 4, 2019.
  83. ^ "Snapdragon 888 5G Mobile Platform". Qualcomm. 17 November 2020. Archived from the original on January 28, 2021. Retrieved February 15, 2021.
  84. ^ "How Qualcomm improved Performance, Gaming, and AI on the Snapdragon 855". xda-developers. 2018-12-05. Archived from the original on December 6, 2018. Retrieved 2018-12-06.
  85. ^ Snapdragon 820 (2016). "Snapdragon 820 product brief".{{cite web}}: CS1 maint: numeric names: authors list (link)
  86. ^ "snapdragon-820-processor-product-brief.pdf | Graphics Processing Unit | Electronics". Scribd. Archived from the original on December 30, 2018. Retrieved June 20, 2018.
  87. ^ "Eragon Snapdragon 820 SOM (APQ8096) - Based on Qualcomm® Snapdragon 820 (APQ8096) Series Processor for Embedded Systems". Archived from the original on June 20, 2018. Retrieved June 20, 2018.
  88. ^ "Qualcomm Spectra 380 Launched: World's First ISP With Integrated AI". xda-developers. 2018-12-05. Archived from the original on December 6, 2018. Retrieved 2018-12-06.
  89. ^ a b c "Product Brief Snapdragon 845" (PDF). Qualcomm. 2018. Archived (PDF) from the original on June 12, 2018. Retrieved June 12, 2018.
  90. ^ a b "Product Brief Snapdragon 845" (PDF). Qualcomm. 2018. Archived (PDF) from the original on June 12, 2018. Retrieved June 12, 2018.
[edit]