

www.ti.com SPRS720 –FEBRUARY 2017

# MJPEG Encoder (v01.00.17.01) on HDVICP2 and Media Controller Based Platform

#### **FEATURES**

- Supports baseline sequential mode for interleaved data formats (single scan)
- Supports YUV 444 Planar, YUV 422 IBE (YUYV), YUV 422 ILE(UYVY), YUV 420 Semi-Planar and Grayscale chroma sub-sampling formats as input
- Supports all resolutions ranging from 32x32 to 16384x8192 for YUV 420SP, YUV 422ILE and YUV 422IBE and resolutions up to 8192x8192 for YUV444 and YUV400
- Supports sub-frame data synchronization for input and output buffers
- Supports selection of quality level by user
- Supports user-defined quantization tables
- Supports 8-bit and 16-bit quantization tables
- Supports insertion of restart marker
- Supports insertion of JPEG File Interchange Format (JFIF) marker segment
- Supports insertion of comment marker segment
- Supports insertion of Exif marker segment
- Supports insertion of thumbnail in JFIF or Exif marker segment
- Graceful exit under error conditions is supported
- Does not support Arithmetic encoding
- Does not support non-interleaved YCbCr output (multiple scans)
- Does not support encoding inputs with 12bits per sample
- Does not support encoding of thumbnails.
   This encoder supports only insertion of encoded thumbnail data provided by the application.

- Supports Privacy Masking till 36 regions in a frame
- Supports Rate Control VBR and CBR for all input YUV Chroma formats.
- The other explicit features that TI's MJPEG Encoder supports are
- eXpressDSP Digital Media (XDM IVIDENC2) interface compliant
- Supports multi-channel functionality
- Supports booting of HDVICP2
- Implements different power optimization schemes
- Independent of any operating system
- Ability to get plugged in any multimedia frameworks (eg. Codec Engine, OpenMax, GStreamer, etc)

### **DESCRIPTION**

JPEG is an international standard for compression. image standard is defined in the ISO10918-1 JPEG Draft International Standard CCITT Recommendation T .81. JPEG supports baseline sequential mode both interleaved and interleaved input format and progressive mode. MJPEG (Motion JPEG) is JPEG used in video mode (for continuous image encoding/ decoding in JPEG format).



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.



## **Performance and Memory Summary**

This section describes the performance and memory usage of MJPEG Encoder.

**Table 1 Configuration Table** 

| CONFIGURATION                                                                                                    | ID            |
|------------------------------------------------------------------------------------------------------------------|---------------|
| Baseline Sequential Encoder (4:2:0 Semi Planar input and 4:2:0 interleaved output) with quality factor = 50      | MJPEG_ENC_001 |
| Baseline Sequential Encoder (4:4:4 Planar input and 4:4:4 interleaved output) with quality factor = 50           | MJPEG_ENC_002 |
| Baseline Sequential Encoder (4:2:2 YUYV interleaved input and 4:2:2 interleaved output) with quality factor = 50 | MJPEG_ENC_003 |
| Baseline Sequential Encoder (4:2:2 UYVY interleaved input and 4:2:2 interleaved output) with quality factor = 50 | MJPEG_ENC_004 |

# Table 2 Cycles Information - Profiled on DM816x REV-A2 EVM with Code Generation Tools Version 5.0.3

|                  | HDVICP2 PERFORMANCE STATISTICS (MEGA CYCLES PER SECOND) (1) |                        |                     |  |  |  |
|------------------|-------------------------------------------------------------|------------------------|---------------------|--|--|--|
| CONFIGURATION ID | TEST DESCRIPTION (2)                                        | AVERAGE <sup>(3)</sup> | PEAK <sup>(4)</sup> |  |  |  |
|                  | Motion1_640x360_420SP,Baseline Sequential                   | 13.96                  | 15.54               |  |  |  |
| MIDEO ENO 004    | Motion1_640x480_420SP,Baseline Sequential                   | 16.99                  | 18.24               |  |  |  |
| MJPEG_ENC_001    | Office_720x480_420SP.xls, Baseline Sequential               | 18.64                  | 19.74               |  |  |  |
|                  | Lambhorgini_p1280x720_fps_420SP, Baseline Sequential        | 43.59                  | 44.87               |  |  |  |
|                  | Tractor_1920x1080_420SP, Baseline Sequential                | 98.74                  | 100.61              |  |  |  |
|                  | Motion1_640x360_444P, Baseline Sequential                   | 29.38                  | 31.09               |  |  |  |
| MIDEC ENC 000    | Motion1_640x480_444P, Baseline Sequential                   | 37.75                  | 38.96               |  |  |  |
| MJPEG_ENC_002    | Office_720x480_444P, Baseline Sequential                    | 41.48                  | 42.97               |  |  |  |
|                  | Lambhorgini_1280x720_444P, Baseline Sequential              | 103.47                 | 104.81              |  |  |  |
|                  | Tractor_1920x1080_444P, Baseline Sequential                 | 228.72                 | 231.59              |  |  |  |
| MJPEG_ENC_003    | Motion1_640x360_422IBE_YUYV, Baseline Sequential            | 121.61                 | 123.36              |  |  |  |
|                  | Office_720x480_422ILE_YUYV, Baseline Sequential             | 178.35                 | 180.84              |  |  |  |
|                  | Motion1_640x360_422ILE_UYVY, Baseline Sequential            | 122.15                 | 123.86              |  |  |  |
| MJPEG_ENC_004    | Motion1_640x480_422ILE_UYVY,Baseline Sequential             | 160.86                 | 162.60              |  |  |  |
|                  | Office_720x480_422ILE_UYVY, Baseline Sequential             | 180.35                 | 182.14              |  |  |  |
|                  | Lambhorgini_1280x720_422ILE_UYVY,Baseline Sequential        | 470.77                 | 472.55              |  |  |  |
|                  | Tractor_1920x1080_422ILE_UYVY,Baseline Sequential           | 1051.72                | 1053.43             |  |  |  |

- (1) Measured on DM816x REV-A2 EVM having Cortex-A8 @ 1GHz, HDVICP2 @ 533MHz, Media Controller @ 250 MHz, L3 interconnect @ 500 MHz and DDR2 @ 400 MHz and there could be a variation of around 1-2% in the numbers.
  - Media Controller code is placed in cacheable memory region in DDR.
  - b) No latency from system at process call and processing unit as frame (no sub-frame level communication) is assumed.
  - All Luma 2D Video buffers of codec being in TILED\_8 Bit Memory and all Chroma 2D Video buffers of codec being in TILED 16 Bit Memory.
- (2) Streams have been compressed with Quantization Tables and Huffman Tables suggested in the JPEG Standard document.
- (3) Measured with rate control disabled. With rate control enabled, additional 2-3 MHz cycles consumption can be expected.
- (4) Average is computed based on worst case cycles having 2 extra input frame buffer. Average is calculated @ 30fps.
- (5) Peak is based on worst case cycles having no extra input frame buffer. It is computed based on peak among 30 frames @30fps.
- (6) Performance is poor for 422UYVY and 422YUYV chroma formats due to HW limitations.



# Table 3 Memory Statistics of Media Controller - Generated with Code Generation Tools Version 5.0.3

|                                                                  |            |                   |             | MEMORY S                                   | STATISTICS <sup>(1)</sup>                   |                        |     |       |       |
|------------------------------------------------------------------|------------|-------------------|-------------|--------------------------------------------|---------------------------------------------|------------------------|-----|-------|-------|
|                                                                  |            |                   | DATA MEMORY |                                            |                                             |                        |     | 1     |       |
| RESOLUTION                                                       |            |                   |             | EXTERNAL <sup>(2)</sup>                    |                                             |                        |     |       | ]     |
|                                                                  |            |                   |             | PERSISTENT <sup>(3)</sup>                  |                                             | CONST                  |     | TOTAL |       |
| CONFIGURATION ID                                                 | RESOLUTION | PROGRAM<br>MEMORY | INTERNAL    | TILED8<br>(numBufs x<br>Width x<br>Height) | TILED16<br>(numBufs<br>x Width x<br>Height) | TILED<br>PAGE<br>/ RAW | RAW | STACK |       |
| MJPEG_ENC_001<br>MJPEG_ENC_002<br>MJPEG_ENC_003<br>MJPEG_ENC_004 | All        | 11                | 0           | 0                                          | 0                                           | 1.8                    | 229 | 2     | 242.8 |

- (1) All memory requirements are expressed in kilobytes (1 K-byte = 1024 bytes) and there might be rounding to next integer K-byte. Stack can be kept in internal/external memory, negligible performance impact can be observed in Media Controller cycles if it is placed in external memory.
- (2) Codec's request of memory container can be over-ridden by application, adhering to the below rules
  - a. TILED PAGE can be overridden by RAW
  - b. TILED8, TILED16 can be overridden by TILED PAGE, RAW
  - c. TILED16 can be overridden by TILED8, RAW, TILED PAGE

However, in case of overriding of 2B and 2C, there can be some performance impact.

(3) Persistent memory is instance specific and does not include I/O buffers.

Table 4 Split-up of Media Controller Internal Data Memory Statistics

|                               | DATA MEMORY - INTERNAL <sup>(1)</sup> |         |            |  |
|-------------------------------|---------------------------------------|---------|------------|--|
| CONFIGURATION ID              | SHARED                                |         | INICTANIOS |  |
| MJPEG_ENC_001 / MJPEG_ENC_002 | CONSTANTS                             | SCRATCH | INSTANCE   |  |
| MJPEG_ENC_003 / MJPEG_ENC_004 | 0                                     | 0       | 0          |  |

<sup>(1)</sup> Internal memory refers to on chip memory. If the system doesn't have enough internal memory, then external memory can also be used. Memory requirements are expressed in kilobytes.

#### **Notes**

- I/O buffers:
  - Input buffer size = 6120 KB (for 1920x1088, YUV444 image)
  - Output buffer size = 4080 KB (considering worst case for 1920x1088, YUV444 image)
- None of the buffers at input and output level is accessed by Media Controller processor hence the data should be valid in DDR (not in cache)
- Total data memory for N non pre-emptive instances = Constants + Runtime Tables + Scratch + N \* (Instance + I/O buffers + Stack)
- Total data memory for N pre-emptive instances = Constants + Runtime Tables + N \* (Instance + I/O buffers + Stack + Scratch)
- MAIL BOX FIFO #0 and #1 are used and user numbering for Media Controller as 2 and for HDVICP2 as 3 is assumed



- It is assumed that RTS library from ARM is available in system because few symbols like memcpy are used in codec
- All constants and Input/Output Buffers to encoder are assumed to be in VDMA addressable space in DDR

#### References

- ITU-CCITT recommendation T.81 (reproduction of ISO/IEC 10918-1)
- eXpressDSP Algorithm Interoperability Standard (TMS320 Algorithm Interface Standard)
- MJPEG Encoder on HDVICP2 and Media Controller Based Platform User's Guide

## Glossary

| Term      | Description                                                                                           |
|-----------|-------------------------------------------------------------------------------------------------------|
| Constants | Elements that go into .const memory section                                                           |
| Scratch   | Memory space that can be reused across different instances of the algorithm                           |
| Shared    | Sum of Constants and Scratch                                                                          |
| Instance  | Persistent-memory that contains persistent information - allocated for each instance of the algorithm |

# **Acronyms**

| Acronym | Description                                                  |
|---------|--------------------------------------------------------------|
| CCITT   | Committee Consultative International Telephone and Telegraph |
| DCT     | Discrete Cosine Transform                                    |
| DRI     | Define Restart Interval Marker                               |
| DSP     | Digital Signal Processing                                    |
| IEC     | International Electrotechnical Commission                    |
| ISO     | International Organization for Standardization               |
| ITU     | International Telecommunication Union                        |
| JFIF    | JPEG File Interchange Format                                 |
| JPEG    | Joint Photographic Experts Group                             |
| MJPEG   | Motion JPEG                                                  |
| RST     | Restart Marker                                               |
| XDM     | eXpressDSP Digital Media                                     |

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All semiconductor products (also referred to herein as "components") are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TI's terms and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily performed.

TI assumes no liability for applications assistance or the design of Buyers' products. Buyers are responsible for their products and applications using TI components. To minimize the risks associated with Buyers' products and applications, Buyers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information published by TI regarding third-party products or services does not constitute a license to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of significant portions of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use of any TI components in safety-critical applications.

In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TI's goal is to help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and requirements. Nonetheless, such components are subject to these terms.

No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties have executed a special agreement specifically governing such use.

Only those TI components which TI has specifically designated as military grade or "enhanced plastic" are designed and intended for use in military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components which have **not** been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.

#### Products Applications

www.ti.com/audio Automotive and Transportation www.ti.com/automotive Audio **Amplifiers** amplifier.ti.com Communications and Telecom www.ti.com/communications **Data Converters** dataconverter.ti.com Computers and Peripherals www.ti.com/computers **DLP® Products** www.dlp.com Consumer Electronics www.ti.com/consumer-apps DSP dsp.ti.com **Energy and Lighting** www.ti.com/energy

DSP dsp.ti.com Energy and Lighting www.ti.com/energy
Clocks and Timers www.ti.com/clocks Industrial www.ti.com/industrial
Interface interface.ti.com Medical www.ti.com/medical
Logic logic.ti.com Security www.ti.com/security

Power Mgmt Space, Avionics and Defense <u>www.ti.com/space-avionics-defense</u>

Microcontrollers microcontroller.ti.com Video and Imaging www.ti.com/video

RFID www.ti-rfid.com

OMAP Applications Processors <u>www.ti.com/omap</u> TI E2E Community <u>e2e.ti.com</u>

Wireless Connectivity <u>www.ti.com/wirelessconnectivity</u>

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265