# 4.11.10 Image Processing Unit (IPU) Module Parameters The purpose of the IPU is to provide comprehensive support for the flow of data from an image sensor and/or to a display device. This support covers all aspects of these activities: - Connectivity to relevant devices—cameras, displays, graphics accelerators, and TV encoders. - Related image processing and manipulation: sensor image signal processing, display processing, image conversions, and other related functions. - Synchronization and control capabilities, such as avoidance of tearing artifacts. ### 4.11.10.1 IPU Sensor Interface Signal Mapping The IPU supports a number of sensor input formats. Table 68 defines the mapping of the Sensor Interface Pins used for various supported interface formats. Table 68. Camera Input Signal Cross Reference, Format, and Bits Per Cycle | Signal<br>Name <sup>1</sup> | RGB565<br>8 bits<br>2 cycles | RGB565 <sup>2</sup><br>8 bits<br>3 cycles | RGB666 <sup>3</sup><br>8 bits<br>3 cycles | RGB888<br>8 bits<br>3 cycles | YCbCr <sup>4</sup><br>8 bits<br>2 cycles | RGB565 <sup>5</sup><br>16 bits<br>2 cycles | YCbCr <sup>6</sup><br>16 bits<br>1 cycle | YCbCr <sup>7</sup><br>16 bits<br>1 cycle | YCbCr <sup>8</sup><br>20 bits<br>1 cycle | |-----------------------------|------------------------------|-------------------------------------------|-------------------------------------------|------------------------------|------------------------------------------|--------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------| | IPUx_CSIx_<br>DATA00 | _ | _ | _ | _ | _ | _ | _ | 0 | C[0] | | IPUx_CSIx_<br>DATA01 | _ | _ | _ | _ | _ | _ | _ | 0 | C[1] | | IPUx_CSIx_<br>DATA02 | _ | _ | _ | _ | _ | _ | _ | C[0] | C[2] | | IPUx_CSIx_<br>DATA03 | _ | _ | _ | _ | _ | _ | _ | C[1] | C[3] | | IPUx_CSIx_<br>DATA04 | _ | _ | _ | _ | _ | B[0] | C[0] | C[2] | C[4] | | IPUx_CSIx_<br>DATA05 | _ | _ | _ | _ | _ | B[1] | C[1] | C[3] | C[5] | | IPUx_CSIx_<br>DATA06 | _ | _ | _ | _ | _ | B[2] | C[2] | C[4] | C[6] | | IPUx_CSIx_<br>DATA07 | _ | _ | _ | _ | _ | B[3] | C[3] | C[5] | C[7] | | IPUx_CSIx_<br>DATA08 | _ | _ | _ | _ | _ | B[4] | C[4] | C[6] | C[8] | | IPUx_CSIx_<br>DATA09 | _ | _ | _ | _ | _ | G[0] | C[5] | C[7] | C[9] | | IPUx_CSIx_<br>DATA10 | _ | _ | _ | _ | _ | G[1] | C[6] | 0 | Y[0] | | IPUx_CSIx_<br>DATA11 | _ | _ | _ | _ | _ | G[2] | C[7] | 0 | Y[1] | | IPUx_CSIx_<br>DATA12 | B[0], G[3] | R[2],G[4],B[2] | R/G/B[4] | R/G/B[0] | Y/C[0] | G[3] | Y[0] | Y[0] | Y[2] | i.MX 6Solo/6DualLite Automotive and Infotainment Applications Processors, Rev. 2.1 Freescale Semiconductor 95 #### **Electrical Characteristics** Table 68. Camera Input Signal Cross Reference, Format, and Bits Per Cycle (continued) | Signal<br>Name <sup>1</sup> | RGB565<br>8 bits<br>2 cycles | RGB565 <sup>2</sup><br>8 bits<br>3 cycles | RGB666 <sup>3</sup><br>8 bits<br>3 cycles | RGB888<br>8 bits<br>3 cycles | YCbCr <sup>4</sup><br>8 bits<br>2 cycles | RGB565 <sup>5</sup><br>16 bits<br>2 cycles | YCbCr <sup>6</sup><br>16 bits<br>1 cycle | YCbCr <sup>7</sup><br>16 bits<br>1 cycle | YCbCr <sup>8</sup><br>20 bits<br>1 cycle | |-----------------------------|------------------------------|-------------------------------------------|-------------------------------------------|------------------------------|------------------------------------------|--------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------| | IPUx_CSIx_<br>DATA13 | B[1], G[4] | R[3],G[5],B[3] | R/G/B[5] | R/G/B[1] | Y/C[1] | G[4] | Y[1] | Y[1] | Y[3] | | IPUx_CSIx_<br>DATA14 | B[2], G[5] | R[4],G[0],B[4] | R/G/B[0] | R/G/B[2] | Y/C[2] | G[5] | Y[2] | Y[2] | Y[4] | | IPUx_CSIx_<br>DATA15 | B[3], R[0] | R[0],G[1],B[0] | R/G/B[1] | R/G/B[3] | Y/C[3] | R[0] | Y[3] | Y[3] | Y[5] | | IPUx_CSIx_<br>DATA16 | B[4], R[1] | R[1],G[2],B[1] | R/G/B[2] | R/G/B[4] | Y/C[4] | R[1] | Y[4] | Y[4] | Y[6] | | IPUx_CSIx_<br>DATA17 | G[0], R[2] | R[2],G[3],B[2] | R/G/B[3] | R/G/B[5] | Y/C[5] | R[2] | Y[5] | Y[5] | Y[7] | | IPUx_CSIx_<br>DATA18 | G[1], R[3] | R[3],G[4],B[3] | R/G/B[4] | R/G/B[6] | Y/C[6] | R[3] | Y[6] | Y[6] | Y[8] | | IPUx_CSIx_<br>DATA19 | G[2], R[4] | R[4],G[5],B[4] | R/G/B[5] | R/G/B[7] | Y/C[7] | R[4] | Y[7] | Y[7] | Y[9] | <sup>&</sup>lt;sup>1</sup> IPUx\_CSIx stands for IPUx\_CSI0 or IPUx\_CSI1 ## 4.11.10.2 Sensor Interface Timings There are three camera timing modes supported by the IPU. ### 4.11.10.2.1 BT.656 and BT.1120 Video Mode Smart camera sensors, which include imaging processing, usually support video mode transfer. They use an embedded timing syntax to replace the IPUx\_CSIx\_VSYNC and IPUx\_CSIx\_HSYNC signals. The timing syntax is defined by the BT.656/BT.1120 standards. This operation mode follows the recommendations of ITU BT.656/ITU BT.1120 specifications. The only control signal used is IPUx\_CSIx\_PIX\_CLK. Start-of-frame and active-line signals are embedded in the data stream. An active line starts with a SAV code and ends with a EAV code. In some cases, digital blanking is inserted in between EAV and SAV code. The CSI decodes and filters out the timing-coding from the data stream, thus recovering IPUx\_CSIx\_VSYNC and IPUx\_CSIx\_HSYNC signals for internal use. On BT.656 one component per cycle is received over the IPUx\_CSIx\_DATA\_EN bus. On BT.1120 two components per cycle are received over the IPUx\_CSIx\_DATA\_EN bus. i.MX 6Solo/6DualLite Automotive and Infotainment Applications Processors, Rev. 2.1 96 Freescale Semiconductor <sup>&</sup>lt;sup>2</sup> The MSB bits are duplicated on LSB bits implementing color extension <sup>&</sup>lt;sup>3</sup> The two MSB bits are duplicated on LSB bits implementing color extension <sup>&</sup>lt;sup>4</sup> YCbCr, 8 bits—Supported within the BT.656 protocol (sync embedded within the data stream). <sup>&</sup>lt;sup>5</sup> RGB 16 bits— Supported in two ways: (1) As a "generic data" input, with no on-the-fly processing; (2) With on-the-fly processing, but only under some restrictions on the control protocol. <sup>&</sup>lt;sup>6</sup> YCbCr 16 bits— Supported as a "generic-data" input, with no on-the-fly processing. <sup>&</sup>lt;sup>7</sup> YCbCr 16 bits— Supported as a sub-case of the YCbCr, 20 bits, under the same conditions (BT.1120 protocol). <sup>&</sup>lt;sup>8</sup> YCbCr, 20 bits, supported only within the BT.1120 protocol (syncs embedded within the data stream).