VideoCore

From Infogalactic: the planetary knowledge core
Jump to: navigation, search

VideoCore is a low-power mobile multimedia processor architecture originally developed by Alphamosaic Ltd and now owned by Broadcom. Its two-dimensional DSP architecture makes it flexible and efficient enough to decode as well as encode a number of multimedia codecs in software, while maintaining low power usage.[1] The semiconductor intellectual property core (SIP core) has been found so far only on Broadcom SoCs.

Technical details

Multimedia system constraints

Mobile multimedia devices require a lot of high-speed video processing but at low power for long battery life. The ARM processor core has a high IPS per watt figure, and thus dominates the mobile phone market, but requires video acceleration coprocessors and display controllers for a complete system. The amount of data passing between these chips at high speed results in higher power consumption. A single processing unit has to be clocked very fast for video processing, and power is proportional to clock speed, so a single-processor solution will be power hungry.

VideoCore key features

  • Instruction set written with video processing in mind from the start. For example, saturation arithmetic so that the sum of two bright pixels does not 'wrap around' into dark values.
  • An array of graphics processing units for parallel computing of video data at relatively low clock speed.
  • Very high integration puts CPU, GPUs, memory and display circuitry on a single chip, removing the power burden of driving fast off-chip buses.

Variants

The VideoCore I-based VC01 provides video and multimedia capabilities to various Samsung phones, including SCH-V540, SCH-V4200, SCH-V490.[2]

The VideoCore II-based VC02 / BCM2722 processor provides video capabilities for Apple's 5th generation iPod.[3]

The VideoCore III-based BCM2727 processor provides video, still and 3D graphics capabilities for the Nokia N8.

The VideoCore IV BCM2763 processor improves on the VideoCore III with support for 1080p encode and decode, along with higher resolution camera support and faster 2D and 3D graphics, all at very low power. It is used in the Nokia 808 PureView,[4] and the Raspberry Pi (2835/2836 models for versions 1/2 accordingly).[5]

The VideoCore IV BCM28155 processor supports for 1080p encode and decode, improved 2D and 3D graphics with dual-core ARM Cortex-A9 CPU in BCM28155 chipset. It is used in the Samsung Galaxy S II Plus, Samsung Galaxy Grand and Amazon Fire TV Stick.

Table of SoCs adopting VideoCore SIP blocks

SoC GPU CPU Max display Utilizing devices
VC01 VideoCore 1 None CIF
List
  • Samsung SCH-V490, Samsung SCH-V420, Samsung SCH-V450, Samsung SCH-V4200, Samsung SCH-V540, Samsung SCH-X699,
BCM2702 (VC02) VideoCore 2 None SD PAL/NTSC
List
  • TCL D308, TCL D918, Samsung SPH-B3100, Samsung SPH-P730, Sandisk v-mate, BenQ S700, O2 X3, Nintendo Play-yan, Sagem MyMobileTV,
BCM2705 (VC05) VideoCore 2 None SD PAL/NTSC
BCM2091 VideoCore 4 Unspecified Unspecified
BCM2722 VideoCore 2 None SD PAL/NTSC
BCM2724 VideoCore 2 None SD PAL/NTSC
BCM2727 VideoCore 3 None HD 720p
List
BCM11181 VideoCore 3 None HD 720p
BCM2763 VideoCore 4 None Full HD 1080p
BCM2820 VideoCore 4 ARM1176 Full HD 1080p
BCM2835 VideoCore 4 ARM1176 (700 MHz) Full HD 1080p
BCM2836 VideoCore 4 Quad-core Cortex-A7 (900 MHz) Full HD 1080p
BCM11182 VideoCore 4 N/A Full HD 1080p
BCM11311 VideoCore 4 Dual-core Cortex-A9 Full HD 1080p
BCM21654 VideoCore 4 Cortex-A9 + Cortex-R4 Full HD 1080p
BCM21654G VideoCore 4 Cortex-A9 (up to 1 GHz) HD 720p
BCM21663 VideoCore 4 Cortex-A9 (up to 1.2 GHz) HD 720p
BCM21664 VideoCore 4 Cortex-A9 (up to 1 GHz) HD 720p
BCM21664T VideoCore 4 Cortex-A9 (up to 1.2 GHz) Full HD 1080p
List
BCM28150 VideoCore 4 Dual-core Cortex-A9 Full HD 1080p
List
  • Aimed at 3G baseband processing, powerful enough to run Android OS.
BCM21553 VideoCore 4 ARM11 Full HD 1080p
List
BCM28145/28155 VideoCore 4 Dual-core Cortex-A9 (up to 1.2 GHz) Full HD 1080p
BCM23550 VideoCore 4 Quad-core Cortex-A7 (up to 1.2 GHz) Full HD 1080p
List

VideoCore products

VideoCore chips can run complete applications - they are not simply video DSP chips that require a separate processor to supply and collect data. In practice they are often used like this, as companies usually prefer to cautiously assimilate new technology rather than take a big risk in porting a large amount of application code from an existing ARM-based design. The Apple video iPod is a good example of this approach.

Low-power laptops use low-power processors and graphics chips, and therefore often struggle to play video at full frame rates. It isn't desirable or practical to port a full operating system onto a VideoCore chip, so only the video decoding need be offloaded onto a video accelerator board (e.g. using the BCM70015 chip).[citation needed]

Blu-ray players can also use it as a low-power video accelerator.

Noting that VideoCore chips were usually used with ARM-based chips, the latest chips have VideoCore and ARM processors.

Linux support

<templatestyles src="Module:Hatnote/styles.css"></templatestyles>

On 28 February 2014, on the day of the second anniversary of the Raspberry Pi Broadcom, together with the Raspberry Pi foundation, announced the release of full documentation for the VideoCore IV's 3D subsystem, the "VideoCore® IV 3D" processor(QPU):

And a complete source release of the graphics stack under a 3-clause BSD license.[9][10]

However, only a minor part of the driver was actually released as open source and all of the actual video acceleration is done using a firmware coded for its proprietary GPU, and which was not open sourced; the entire SoC itself is managed / initialized by a ThreadX based RTOS that is loaded into the Videocore's VPU during bootup[11]

An architectural overview of the videocore based system was compiled (based on Reverse engineering & patent research) by Herman Hermitage and is available on github:

In June 2014, Eric Anholt left Intel to instead work for Broadcom to develop a free driver (DRM/KMS driver and Gallium3D-driver) for VC4 (VideoCore 4).[12] After just one week, he reported a noteworthy progress.[13][14]

<templatestyles src="Template:Blockquote/styles.css" />

I've taken on a new role as an open source developer there. I'm going to be working on building an MIT-licensed Mesa 3D and kernel DRM driver for the 2708 (aka the 2835), the chip that's in the Raspberry Pi.

The free licensed 3D graphics code was committed to Mesa on 29 August 2014,[15] and first appeared on 10.3 release.

Market competitors

Similar mobile multimedia chip ranges include Adreno, Texas Instruments OMAP, Nvidia Tegra, AllWinner A1X and Freescale i.MX. These four are ARM-based with arrays of graphics processing units.

Data sources

The Broadcom YouTube page[16] has videos demonstrating the video processing capability, but their website only goes as far as providing product briefs. Detailed data and development tools are only available under NDA, and then only for manufacturers with a market for very many units. However, on 28 February 2014, on the day of the second anniversary of the Raspberry PI Broadcom, together with the Raspberry PI foundation, announced the release of full documentation for the VideoCore IV graphics core, and a complete source release of the graphics stack under a 3-clause BSD license.[9][10]

See also

References

<templatestyles src="Reflist/styles.css" />

Cite error: Invalid <references> tag; parameter "group" is allowed only.

Use <references />, or <references group="..." />
  1. Alphamosaic Ltd > Technology – VideoCore, archived on 9 February 2003.
  2. [4]
  3. Lua error in package.lua at line 80: module 'strict' not found.
  4. http://www.staygrab.com/nokia-808-pureview/
  5. https://www.raspberrypi.org/documentation/hardware/raspberrypi/bcm2835/README.md
  6. 6.0 6.1 Raspberry Pi - FAQ
  7. Engadget - Roku 2 line passes through the FCC with modest hardware updates and a reset button
  8. www.xolo.in/Opus-HD
  9. 9.0 9.1 http://arstechnica.com/information-technology/2014/02/raspberry-pi-marks-2nd-birthday-with-plan-for-open-source-graphics-driver/
  10. 10.0 10.1 http://www.raspberrypi.org/archives/6299
  11. Lua error in package.lua at line 80: module 'strict' not found.
  12. Lua error in package.lua at line 80: module 'strict' not found.
  13. Lua error in package.lua at line 80: module 'strict' not found.
  14. Lua error in package.lua at line 80: module 'strict' not found.
  15. http://cgit.freedesktop.org/mesa/mesa/commit/?id=1850d0a1cbf044dc4d29b7a9ede2c634f667d853
  16. Broadcom YouTube page