

# MIPI Alliance Standard for Camera Serial Interface 2 (CSI-2)

**Version 1.00 – 29 November 2005** 

MIPI Board Approved 29-Nov-2005

#### 1 NOTICE OF DISCLAIMER

- 2 The material contained herein is not a license, either expressly or impliedly, to any IPR owned or controlled
- 3 by any of the authors or developers of this material or MIPI. The material contained herein is provided on
- 4 an "AS IS" basis and to the maximum extent permitted by applicable law, this material is provided AS IS
- 5 AND WITH ALL FAULTS, and the authors and developers of this material and MIPI hereby disclaim all
- 6 other warranties and conditions, either express, implied or statutory, including, but not limited to, any (if
- any) implied warranties, duties or conditions of merchantability, of fitness for a particular purpose, of
- 8 accuracy or completeness of responses, of results, of workmanlike effort, of lack of viruses, and of lack of
- 9 negligence.
- 10 ALSO, THERE IS NO WARRANTY OF CONDITION OF TITLE, QUIET ENJOYMENT, QUIET
- 11 POSSESSION, CORRESPONDENCE TO DESCRIPTION OR NON-INFRINGEMENT WITH REGARD
- 12 TO THIS MATERIAL OR THE CONTENTS OF THIS DOCUMENT, IN NO EVENT WILL ANY
- 13 AUTHOR OR DEVELOPER OF THIS MATERIAL OR THE CONTENTS OF THIS DOCUMENT OR
- 14 MIPI BE LIABLE TO ANY OTHER PARTY FOR THE COST OF PROCURING SUBSTITUTE
- 15 GOODS OR SERVICES, LOST PROFITS, LOSS OF USE, LOSS OF DATA, OR ANY INCIDENTAL,
- 16 CONSEQUENTIAL, DIRECT, INDIRECT, OR SPECIAL DAMAGES WHETHER UNDER
- 17 CONTRACT, TORT, WARRANTY, OR OTHERWISE, ARISING IN ANY WAY OUT OF THIS OR
- 18 ANY OTHER AGREEMENT, SPECIFICATION OR DOCUMENT RELATING TO THIS MATERIAL,
- 19 WHETHER OR NOT SUCH PARTY HAD ADVANCE NOTICE OF THE POSSIBILITY OF SUCH
- 20 DAMAGES.
- 21 Without limiting the generality of this Disclaimer stated above, the user of the contents of this Document is
- 22 further notified that MIPI: (a) does not evaluate, test or verify the accuracy, soundness or credibility of the
- contents of this Document; (b) does not monitor or enforce compliance with the contents of this Document;
- and (c) does not certify, test, or in any manner investigate products or services or any claims of compliance
- 25 with the contents of this Document. The use or implementation of the contents of this Document may
- 26 involve or require the use of intellectual property rights ("IPR") including (but not limited to) patents,
- 27 patent applications, or copyrights owned by one or more parties, whether or not Members of MIPI. MIPI
- does not make any search or investigation for IPR, nor does MIPI require or request the disclosure of any
- 29 IPR or claims of IPR as respects the contents of this Document or otherwise.
- 30 Questions pertaining to this document, or the terms or conditions of its provision, should be addressed to:
- 31 MIPI Alliance, Inc.
- 32 c/o IEEE-ISTO
- 33 445 Hoes Lane
- Piscataway, NJ 08854
- 35 Attn: Board Secretary

# Contents

| 37 | Version | 1.00 – 29 November 2005                             | i  |
|----|---------|-----------------------------------------------------|----|
| 38 | 1 Ov    | verview                                             | 6  |
| 39 | 1.1     | Scope                                               | 6  |
| 40 | 1.2     | Purpose                                             | 6  |
| 41 | 2 Ter   | rminology                                           | 7  |
| 42 | 2.1     | Definitions                                         | 7  |
| 43 | 2.2     | Abbreviations                                       | 7  |
| 44 | 2.3     | Acronyms                                            | 8  |
| 45 | 3 Ref   | ferences                                            | 10 |
| 46 | 4 Ov    | verview of CSI-2                                    | 11 |
| 47 | 5 CS    | I-2 Layer Definitions                               | 12 |
| 48 | 6 Cai   | mera Control Interface (CCI)                        | 14 |
| 49 | 6.1     | Data Transfer Protocol.                             | 14 |
| 50 | 6.2     | CCI Slave Addresses                                 | 18 |
| 51 | 6.3     | CCI Multi-Byte Registers                            | 18 |
| 52 | 6.4     | Electrical Specifications and Timing for I/O Stages | 25 |
| 53 | 7 Phy   | ysical Layer                                        | 29 |
| 54 | 8 Mu    | ulti-Lane Distribution and Merging                  | 30 |
| 55 | 8.1     | Multi-Lane Interoperability                         | 34 |
| 56 | 9 Lo    | w Level Protocol                                    | 37 |
| 57 | 9.1     | Low Level Protocol Packet Format                    | 37 |
| 58 | 9.2     | Data Identifier (DI)                                | 39 |
| 59 | 9.3     | Virtual Channel Identifier                          | 40 |
| 60 | 9.4     | Data Type (DT)                                      | 41 |
| 61 | 9.5     | Packet Header Error Correction Code                 | 42 |
| 62 | 9.6     | Checksum Generation                                 | 48 |

| 63 | 9.7   | Packet Spacing                               | 50 |
|----|-------|----------------------------------------------|----|
| 64 | 9.8   | Synchronization Short Packet Data Type Codes | 51 |
| 65 | 9.9   | Generic Short Packet Data Type Codes         | 52 |
| 66 | 9.10  | Packet Spacing Examples                      | 53 |
| 67 | 9.11  | Packet Data Payload Size Rules               | 56 |
| 68 | 9.12  | Frame Format Examples                        | 56 |
| 69 | 9.13  | Data Interleaving                            | 59 |
| 70 | 10 C  | Color Spaces                                 | 65 |
| 71 | 10.1  | RGB Color Space Definition                   | 65 |
| 72 | 10.2  | YUV Color Space Definition                   | 65 |
| 73 | 11 E  | Data Formats                                 | 66 |
| 74 | 11.1  | Generic 8-bit Long Packet Data Types         | 67 |
| 75 | 11.2  | YUV Image Data                               | 68 |
| 76 | 11.3  | RGB Image Data                               | 78 |
| 77 | 11.4  | RAW Image Data                               | 83 |
| 78 | 11.5  | User Defined Data Formats                    | 90 |
| 79 | 12 R  | Recommended Memory Storage                   | 93 |
| 80 | 12.1  | General/Arbitrary Data Reception             | 93 |
| 81 | 12.2  | RGB888 Data Reception                        | 93 |
| 82 | 12.3  | RGB666 Data Reception                        | 94 |
| 83 | 12.4  | RGB565 Data Reception                        | 95 |
| 84 | 12.5  | RGB555 Data Reception                        | 95 |
| 85 | 12.6  | RGB444 Data Reception                        | 95 |
| 86 | 12.7  | YUV422 8-bit Data Reception                  | 96 |
| 87 | 12.8  | YUV422 10-bit Data Reception                 | 96 |
| 88 | 12.9  | YUV420 8-bit (Legacy) Data Reception         | 97 |
| 89 | 12.10 | YUV420 8-bit Data Reception                  | 98 |
| 90 | 12.11 | YUV420 10-bit Data Reception                 | 99 |

|     | Version 1. | 00 29-Nov-2005                                         | MIPI Alliance Standard for CSI-2 |
|-----|------------|--------------------------------------------------------|----------------------------------|
| 91  | 12.12      | RAW6 Data Reception                                    | 101                              |
| 92  | 12.13      | RAW7 Data Reception                                    | 101                              |
| 93  | 12.14      | RAW8 Data Reception                                    | 101                              |
| 94  | 12.15      | RAW10 Data Reception                                   | 102                              |
| 95  | 12.16      | RAW12 Data Reception                                   | 102                              |
| 96  | 12.17      | RAW14 Data Reception                                   | 103                              |
| 97  | Annex A (  | informative) JPEG8 Data Format                         | 104                              |
| 98  | Annex B (  | informative) CSI-2 Implementation Example              | 110                              |
| 99  | Annex C (  | informative) CSI-2 Recommended Receiver Error Behavior | 119                              |
| 100 | Annex D (  | informative) CSI-2 Sleep Mode                          | 123                              |

# MIPI Alliance Standard for Camera Serial Interface2 (CSI-2)

#### 103 1 Overview

# 104 **1.1 Scope**

- The Camera Serial Interface 2 specification defines an interface between a peripheral device (camera) and a
- host processor (baseband, application engine). The purpose of this document is to specify a standard
- interface between a camera and a host processor for mobile applications.
- A host processor in this document means the hardware and software that performs essential core functions
- for telecommunication or application tasks. The engine of a mobile terminal includes hardware and the
- functions, which enable the basic operation of the mobile terminal. These include, for example, the printed
- circuit boards, RF components, basic electronics, and basic software, such as the digital signal processing
- software.

# **1.2 Purpose**

- Demand for increasingly higher image resolutions is pushing the bandwidth capacity of existing host
- 115 processor-to-camera sensor interfaces. Common parallel interfaces are difficult to expand, require many
- interconnects and consume relatively large amounts of power. Emerging serial interfaces address many of
- the shortcomings of parallel interfaces while introducing their own problems. Incompatible, proprietary
- interfaces prevent devices from different manufacturers from working together. This can raise system costs
- and reduce system reliability by requiring "hacks" to force the devices to interoperate. The lack of a clear
- industry standard can slow innovation and inhibit new product market entry.
- 121 CSI-2 provides the mobile industry a standard, robust, scalable, low-power, high-speed, cost-effective
- interface that supports a wide range of imaging solutions for mobile devices.

# 123 **2 Terminology**

- The MIPI Alliance has adopted Section 13.1 of the IEEE Standards Style Manual, which dictates use of the
- words "shall", "should", "may", and "can" in the development of documentation, as follows:
- The word *shall* is used to indicate mandatory requirements strictly to be followed in order to conform to the
- standard and from which no deviation is permitted (*shall* equals *is required to*).
- The use of the word *must* is deprecated and shall not be used when stating mandatory requirements; must is
- used only to describe unavoidable situations.
- The use of the word will is deprecated and shall not be used when stating mandatory requirements; will is
- only used in statements of fact.
- The word *should* is used to indicate that among several possibilities one is recommended as particularly
- suitable, without mentioning or excluding others; or that a certain course of action is preferred but not
- necessarily required; or that (in the negative form) a certain course of action is deprecated but not
- prohibited (should equals is recommended that).
- The word may is used to indicate a course of action permissible within the limits of the standard (may
- 137 equals is permitted).
- The word can is used for statements of possibility and capability, whether material, physical, or causal (can
- equals is able to).
- All sections are normative, unless they are explicitly indicated to be informative.

#### 141 **2.1 Definitions**

- Lane: A differential conductor pair, used for data transmission. For CSI-2 a data Lane is unidirectional.
- 143 **Packet:** A group of two or more bytes organized in a specified way to transfer data across the interface. All
- packets have a minimum specified set of components. The byte is the fundamental unit of data from which
- packets are made.
- 146 **Payload:** Application data only with all sync, header, ECC and checksum and other protocol-related
- information removed. This is the "core" of transmissions between application processor and peripheral.
- Sleep Mode: Sleep mode (SLM) is a leakage level only power consumption mode.
- 149 **Transmission:** The time during which high-speed serial data is actively traversing the bus. A transmission
- 150 is comprised of one or more packets. A transmission is bounded by SoT (Start of Transmission) and EoT
- 151 (End of Transmission) at beginning and end, respectively.
- 152 Virtual Channel: Multiple independent data streams for up to four peripherals are supported by this
- 153 specification. The data stream for each peripheral is a Virtual Channel. These data streams may be
- interleaved and sent as sequential packets, with each packet dedicated to a particular peripheral or channel.
- Packet protocol includes information that links each packet to its intended peripheral.

# 156 **2.2 Abbreviations**

157 e.g. For example

| 158 | 2.3 | Acronyms |
|-----|-----|----------|
| 150 | 2.5 |          |

- 159 BER Bit Error Rate
- 160 CIL Control and Interface Logic
- 161 CRC Cyclic Redundancy Check
- 162 CSI Camera Serial Interface
- 163 CSPS Chroma Sample Pixel Shifted
- 164 DDR Dual Data Rate
- 165 DI Data Identifier
- 166 DT Data Type
- 167 ECC Error Correction Code
- 168 EoT End of Transmission
- 169 EXIF Exchangeable Image File Format
- 170 FE Frame End
- 171 FS Frame Start
- High Speed; identifier for operation mode
- 173 HS-RX High-Speed Receiver (Low-Swing Differential)
- 174 HS-TX High-Speed Transmitter (Low-Swing Differential)
- 175 I2C Inter-Integrated Circuit
- 176 JFIF JPEG File Interchange Format
- 177 JPEG Joint Photographic Expert Group
- 178 LE Line End
- 179 LLP Low Level Protocol
- 180 LS Line Start
- 181 LSB Least Significant Bit
- 182 LP Low-Power; identifier for operation mode
- 183 LP-RX Low-Power Receiver (Large-Swing Single Ended)
- 184 LP-TX Low-Power Transmitter (Large-Swing Single Ended)
- 185 MIPI Mobile Industry Processor Interface

| 186 | MSB  | Most Significant Bit                                          |
|-----|------|---------------------------------------------------------------|
| 187 | PF   | Packet Footer                                                 |
| 188 | PH   | Packet Header                                                 |
| 189 | PI   | Packet Identifier                                             |
| 190 | PT   | Packet Type                                                   |
| 191 | PHY  | Physical Layer                                                |
| 192 | PPI  | PHY Protocol Interface                                        |
| 193 | RGB  | Color representation (Red, Green, Blue)                       |
| 194 | RX   | Receiver                                                      |
| 195 | SCL  | Serial Clock (for CCI)                                        |
| 196 | SDA  | Serial Data (for CCI)                                         |
| 197 | SLM  | Sleep Mode                                                    |
| 198 | SoT  | Start of Transmission                                         |
| 199 | TX   | Transmitter                                                   |
| 200 | ULPM | Ultra Low Power Mode                                          |
| 201 | VGA  | Video Graphics Array                                          |
| 202 | YUV  | Color representation (Y for luminance, U & V for chrominance) |

- 203 **3 References**
- 204 [1] I2C standard (v2.1 January 2000). Philips Semiconductor
- 205 [2] Draft MIPI Alliance Standard for D-PHY, version 0.58, July 2005

#### 4 Overview of CSI-2

The CSI-2 specification defines standard data transmission and control interfaces between transmitter and receiver. Data transmission interface (referred as CSI-2) is unidirectional differential serial interface with data and clock signals; the physical layer of this interface is the *MIPI Alliance Standard for D-PHY* [2]. Figure 1 illustrates connections between CSI-2 transmitter and receiver, which typically are a camera module and a receiver module, part of the mobile phone engine.

The control interface (referred as CCI) is a bi-directional control interface compatible with I2C standard.



Figure 1 CSI-2 and CCI Transmitter and Receiver Interface

206

207

208

209

# 215 **5 CSI-2 Layer Definitions**

216217

219

220

221

222

223

224

225

226227



Lane N - High Speed Unidirectional Data

Figure 2 CSI-2 Layer Definitions

Figure 2 defines the conceptual layer structure used in CSI-2. The layers can be characterized as follows:

• **PHY Layer.** The PHY Layer specifies the transmission medium (electrical conductors), the input/output circuitry and the clocking mechanism that captures "ones" and "zeroes" from the serial bit stream. This part of the specification documents the characteristics of the transmission medium, electrical parameters for signaling and the timing relationship between clock and data Lanes.

The mechanism for signaling Start of Transmission (SoT) and End of Transmission (EoT) is specified as well as other "out of band" information that can be conveyed between transmitting and receiving PHYs. Bit-level and byte-level synchronization mechanisms are included as part of the PHY.

- The PHY layer is described in MIPI Alliance Standard for D-PHY [2].
  - **Protocol Layer.** The Protocol layer is composed of several layers, each with distinct responsibilities. The CSI-2 protocol enables multiple data streams using a single interface on the host processor. The Protocol layer specifies how multiple data streams may be tagged and interleaved so each data stream can be properly reconstructed.
    - Pixel/Byte Packing/Unpacking Layer. The CSI-2 supports image applications with varying pixel formats from six to twenty-four bits per pixels. In the transmitter this layer packs pixels from the Application layer into bytes before sending the data to the Low Level Protocol layer. In the receiver this layer unpacks bytes from the Low Level Protocol layer into pixels before sending the data to the Application layer. Eight bits per pixel data is transferred unchanged by this layer.
    - Low Level Protocol. The Low Level Protocol (LLP) includes the means of establishing bit-level and byte-level synchronization for serial data transferred between SoT (Start of Transmission) and EoT (End of Transmission) events and for passing data to the next layer. The minimum data granularity of the LLP is one byte. The LLP also includes assignment of bit-value interpretation within the byte, i.e. the "Endian" assignment.
    - Lane Management. CSI-2 is Lane-scalable for increased performance. The number of data Lanes may be one, two, three or four depending on the bandwidth requirements of the application. The transmitting side of the interface distributes ("distributor" function) the outgoing data stream to one or more Lanes. On the receiving side, the interface collects bytes from the Lanes and merges ("merger" function) them together into a recombined data stream that restores the original stream sequence.

Data within the Protocol layer is organized as packets. The transmitting side of the interface appends header and optional error-checking information on to data to be transmitted at the Low Level Protocol layer. On the receiving side, the header is stripped off at the Low Level Protocol layer and interpreted by corresponding logic in the receiver. Error-checking information may be used to test the integrity of incoming data.

- Application Layer. This layer describes higher-level encoding and interpretation of data contained in the data stream. The CSI-2 specification describes the mapping of pixel values to bytes.
- The normative sections of the specification only relate to the external part of the Link, e.g. the data and bit patterns that are transferred across the Link. All internal interfaces and layers are purely informative.

# 6 Camera Control Interface (CCI)

- 261 CCI is a two-wire, bi-directional, half duplex, serial interface for controlling the transmitter. CCI is
- 262 compatible with the fast mode variant of the I2C interface. CCI shall support 400kHz operation and 7-bit
- 263 Slave Addressing.

260

- A CSI-2 receiver shall be configured as a master and a CSI-2 transmitter shall be configured as a slave on
- 265 the CCI bus. CCI is capable of handling multiple slaves on the bus. However, multi-master mode is not
- supported by CCI. Any I2C commands that are not described in this section shall be ignored and shall not
- 267 cause unintended device operation. Note that the terms master and slave, when referring to CCI, should not
- be confused with similar terminology used for D-PHY's operation; they are not related.
- Typically, there is a dedicated CCI interface between the transmitter and the receiver.
- 270 CCI is a subset of the I2C protocol, including the minimum combination of obligatory features for I2C
- 271 slave devices specified in the I2C specification. Therefore, transmitters complying with the CCI
- specification can also be connected to the system I2C bus. However, care must be taken so that I2C masters
- do not try to utilize those I2C features that are not supported by CCI masters and CCI slaves
- Each CCI transmitter may have additional features to support I2C, but that is dependent on implementation.
- Further details can be found on a particular device's data sheet.
- This specification does not attempt to define the contents of control messages sent by the CCI master. As
- such, it is the responsibility of the CSI-2 implementer to define a set of control messages and corresponding
- frame timing and I2C latency requirements, if any, that must be met by the CCI master when sending such
- control messages to the CCI slave.
- 280 The CCI defines an additional data protocol layer on top of I2C. The data protocol is presented in the
- 281 following sections.

285

#### 282 6.1 Data Transfer Protocol

- 283 The data transfer protocol is according to I2C standard. The START, REPEATED START and STOP
- conditions as well as data transfer protocol are specified in the I2C specification [1].

#### 6.1.1 Message Type

- A basic CCI message consists of START condition, slave address with read/write bit, acknowledge from
- slave, sub address (index) for pointing at a register inside the slave device, acknowledge signal from slave,
- in write operation data byte from master, acknowledge/negative acknowledge from slave and STOP
- 289 condition. In read operation data byte comes from slave and acknowledge/negative acknowledge from
- 290 master. This is illustrated in Figure 3.
- The slave address in the CCI is 7-bit.
- The CCI supports 8-bit index with 8-bit data or 16-bit index with 8-bit data. The slave device in question
- defines what the message type to be used is.

Message type with 8-bit index and 8-bit data (7-bit address)





294

296

297

298

299

300

301

302

303

304

305

306

307

308309

295

Figure 3 CCI Message Types

# 6.1.2 Read/Write Operations

The CCI compatible device shall be able to support four different read operations and two different write operations; single read from random location, sequential read from random location, single read from current location, sequential read from current location, single write to random location and sequential write starting from random location. The read/write operations are presented in the following sections.

The index in the slave device has to be auto incremented after each read/write operation. This is also explained in the following sections.

#### 6.1.2.1 Single Read from Random Location

In single read from random location the master does a dummy write operation to desired index, issues a repeated start condition and then addresses the slave again with read operation. After acknowledging its slave address, the slave starts to output data onto SDA line. This is illustrated in Figure 4. The master terminates the read operation by setting a negative acknowledge and stop condition.



Figure 4 CCI Single Read from Random Location

314315

316

317

318

319

320

321

322

323

324

# 6.1.2.2 Single Read from the Current Location

It is also possible to read from last used index by addressing the slave with read operation. The slave responses by setting the data from last used index to SDA line. This is illustrated in Figure 5. The master terminates the read operation by setting a negative acknowledge and stop condition.



Figure 5 CCI Single Read from Current Location

# 6.1.2.3 Sequential Read Starting from a Random Location

The sequential read starting from a random location is illustrated in Figure 6. The master does a dummy write to the desired index, issues a repeated start condition after an acknowledge from the slave and then addresses the slave again with a read operation. If a master issues an acknowledge after received data it acts as a signal to the slave that the read operation continues from the next index. When the master has read the last data byte it issues a negative acknowledge and stop condition.



Figure 6 CCI Sequential Read Starting from a Random Location

#### 6.1.2.4 Sequential Read Starting from the Current Location

- 325 A sequential read starting from the current location is similar to a sequential read from a random location.
- The only exception is there is no dummy write operation. The command sequence is illustrated in Figure 7.
- The master terminates the read operation by issuing a negative acknowledge and stop condition.

330

331

332

333

334335

336



# 6.1.2.5 Single Write to a Random Location

A write operation to a random location is illustrated in Figure 8. The master issues a write operation to the slave then issues the index and data after the slave has acknowledged the write operation. The write operation is terminated with a stop condition from the master.



Figure 8 CCI Single Write to a Random Location

# 6.1.2.6 Sequential Write

The sequential write operation is illustrated in Figure 9. The slave auto-increments the index after each data

byte is received. The sequential write operation is terminated with a stop condition from the master.



Figure 9 CCI Sequential Write Starting from a Random Location

#### 6.2 CCI Slave Addresses

For camera modules having only raw Bayer output the 7-bit slave address should be 011011Xb, where X = 0 or 1. For all other camera modules the 7-bit slave address should be 011110Xb.

#### 6.3 CCI Multi-Byte Registers

#### 345 **6.3.1 Overview**

339340

341

- Peripherals contain a wide range of different register widths for various control and setup purposes. The CSI-2 specification supports the following register widths:
- 8-bit generic setup registers
- 16-bit parameters like line-length, frame-length and exposure values
- 32-bit high precision setup values
- 64-bit for needs of future sensors
- In general, the byte oriented access protocols described in the sections above provide an efficient means to
- access multi-byte registers. However, the registers should reside in a byte-oriented address space, and the
- address of a multi-byte register should be the address of its first byte. Thus, addresses of contiguous multi-
- byte registers will not be contiguous. For example, a 32-bit register with its first byte at address 0x8000 can
- be read by means of a sequential read of four bytes, starting at random address 0x8000. If there is an
- additional 4-byte register with its first byte at 0x8004, it could then be accessed using a four-byte
- 358 Sequential Read from the Current Location protocol.
- 359 The motivation for a general multi-byte protocol rather than fixing the registers at 16-bits width is
- 360 flexibility. The protocol to be described below provides a way of transferring 16-bit, 32-bit or 64-bit values
- over a 16-bit index, 8-bit data, two-wire serial link while ensuring that the bytes of data transferred for a
- multi-byte register value are always consistent (temporally coherent).
- Using this protocol a single CCI message can contain one, two or all of the different register widths used
- within a device.
- The MS byte of a multi-byte register shall be located at the lowest address and the LS byte at the highest
- 366 address.

377378

379

- The address of the first byte of a multi-byte register may, or may not be, aligned to the size of the register; i.e., a multiple of the number of register bytes. The register alignment is an implementation choice between processing optimized and bandwidth optimized organizations. There are no restrictions on the number or mix of multi-byte registers within the available 64K by 8-bit index space, with the exception that rules for the valid locations for the MS bytes and LS bytes of registers are followed.
- Partial access to multi-byte registers is not allowed. A multi-byte register shall only be accessed by a single sequential message. When a multi-byte register is accessed, its first byte is accessed first, its second byte is accessed second, etc.
- When a multi-byte register is accessed, the following re-timing rules must be followed:
  - For a Write operation, the updating of the register shall be deferred to a time when the last bit of the last byte has been received
  - For a Read operation, the value read shall reflect the status of all bytes at the time that the first bit of the first byte has been read
- Section 6.3.3 describes example behavior for the re-timing of multi-byte register accesses.
- Without re-timing data may be corrupted as illustrated in Figure 10 and Figure 11 below.



Figure 10 Corruption of a 32-bit Wide Register During a Read Message

#### Internal 32-bit Register Value (Locations M, M+1, M+2 and M+3)



Figure 11 Corruption of a 32-bit Wide Register During a Write Message

# 6.3.2 The Transmission Byte Order for Multi-byte Register Values

This is a normative section.

384

385

386

388

389

390391

The first byte of a CCI message is always the MS byte of a multi-byte register and the last byte is always the LS byte.



Figure 12 Example 16-bit Register Write



Figure 13 Example 32-bit Register Write (address not shown)



Figure 14 Example 64-bit Register Write (address not shown)

# 6.3.3 Multi-Byte Register Protocol

- 397 This is an informative section.
- Each device may have both single and multi-byte registers. Internally a device must understand what addresses correspond to the different register widths.

# 6.3.3.1 Reading Multi-byte Registers

- To ensure that the value read from a multi-byte register is consistent, i.e. all bytes are temporally coherent,
- 402 the device internally transfers the contents of the register into a temporary buffer when the MS byte of the
- 403 register is read. The contents of the temporary buffer are then output as a sequence of bytes on the SDA
- line. Figure 15 and Figure 16 illustrate multi-byte register read operations.
- The temporary buffer is always updated unless the read operation is incremental within the same multi-byte
- 406 register.

392393

394395

396



Figure 15 Example 16-bit Register Read

In this definition there is no distinction made between whether the register is accessed incrementally via separate, single byte read messages with no intervening data writes or via a single multi-location read message. This protocol purely relates to the behavior of the index value.

- Examples of when the temporary buffer is updated are as follows:
  - The MS byte of a register is accessed

407

408

409

410

411

412

413

414

- The index has crossed a multi-byte register boundary
- Successive single byte reads from the same index location
- The index value for the byte about to be read is the same or less than the previous index

Unless the contents of a multi-byte register are accessed in an incremental manner the values read back are not guaranteed to be consistent.

The contents of the temporary buffer are reset to zero by START and STOP conditions.



Figure 16 Example 32-bit Register Read

# 6.3.3.2 Writing Multi-byte Registers

420 421

- To ensure that the value written is consistent, the bytes of data of a multi-byte register are written into a temporary buffer. Only after the LS byte of the register is written is the full multi-byte value transferred into the internal register location. Figure 17 and Figure 18 illustrate multi-byte register write operations.
- 426 CCI messages that only write to the LS or MS byte of a multi-byte register are not allowed. Single byte writes to a multi-byte register addresses may cause undesirable behavior in the device.

#### Internal 16-bit Register Value (Locations M and M+1) 0xFC FD 0x01 02 Internal 16-bit Register Value (Locations M+2 and M+3) 0xFE FF 0x03 04 Register Index Index M Index M+1 Index M+2 Index M+3 Temporary Buffer 0x03 00 0x00000 0x01 00 0x0000 0x00 00 A write to the LS byte of the register causes the contents of the temporary buffer to be transferred onto the register location SLAVE ĀP DATA=0x01 DATA=0x02 DATA=0x03 DATA=0x04 **ADDRESS** MS Data Byte MS Data Byte LS Data Byte LS Data Byte 0x01 0x02 0x03 0x04 DATA[15:8] DATA[7:0] DATA[15:8] DATA[7:0] DATA[15:0] DATA[15:0] From slave to master S = START condition A = Acknowledge From master to slave P = STOP condition A = Negative acknowledge Figure 17 Example 16-bit Register Write

Copyright © 2005 MIPI Alliance, Inc. All rights reserved. MIPI Alliance Member Confidential.

432

433

434

435

436

#### 0x01 02 03 04 0xFC FD FE FF Register Index Index M Index M+1 Index M+2 Index M+3 Temporary Buffer 0x00 00 00 00 0x01 00 00 00 0x01 02 00 00 0x01 02 03 00 0x00 00 00 00 A write to the LS byte of the register causes the contents of the temporary buffer to be transferred onto the register location SLAVE DATA=0x01 DATA=0x02 DATA=0x03 DATA=0x04 **ADDRESS** MS Data Byte LS Data Byte 0x01 0x02 0x03 0x04 DATA[31:24] DATA[23:16] DATA[15:8] DATA[7:0] DATA[31:0] From slave to master A = AcknowledgeS = START condition $\overline{A}$ = Negative acknowledge From master to slave P = STOP condition

# Internal 32-bit Register Value (Locations M, M+1, M+2 and M+3)

Figure 18 Example 32-bit Register Write

# 6.4 Electrical Specifications and Timing for I/O Stages

The electrical specification and timing for I/O stages conform to the I2C standard for Standard- and Fast-mode devices. Information presented in Table 1 and is taken from the I2C standard [1].

Table 1 CCI I/O Characteristics

| Parameter                | Symbol      | Standar     | rd-mode              | Fast-                | mode                | Unit |
|--------------------------|-------------|-------------|----------------------|----------------------|---------------------|------|
|                          |             | Min.        | Max.                 | Min.                 | Max.                |      |
| LOW level input voltage  | $ m V_{IL}$ | -0.5        | $0.3V_{\mathrm{DD}}$ | -0.5                 | 0.3 V <sub>DD</sub> | V    |
| HIGH level input voltage | $ m V_{IH}$ | $0.7V_{DD}$ | Note 1               | $0.7V_{\mathrm{DD}}$ | Note 1              | V    |

| Parameter                                                                                      | Symbol             | Standard-mode |      | Fast-mode                      |                      | Unit |  |
|------------------------------------------------------------------------------------------------|--------------------|---------------|------|--------------------------------|----------------------|------|--|
|                                                                                                |                    | Min.          | Max. | Min.                           | Max.                 |      |  |
| Hysteresis of Schmitt trigger inputs                                                           |                    |               |      |                                |                      |      |  |
| $V_{DD} > 2V$                                                                                  | $V_{\mathrm{HYS}}$ | N/A           | N/A  | $0.05V_{DD}$                   | -                    | V    |  |
| $V_{DD} < 2V$                                                                                  |                    | N/A           | N/A  | $0.1V_{DD}$                    | -                    |      |  |
| LOW level output voltage (open drain) at 3mA sink current                                      |                    |               |      |                                |                      |      |  |
| $V_{DD} > 2V$                                                                                  | $V_{\mathrm{OL1}}$ | 0             | 0.4  | 0                              | 0.4                  | V    |  |
| $V_{DD} < 2V$                                                                                  | $V_{OL3}$          | N/A           | N/A  | 0                              | $0.2V_{\mathrm{DD}}$ |      |  |
| HIGH level output voltage                                                                      | $ m V_{OH}$        | N/A           | N/A  | $0.8V_{\mathrm{DD}}$           |                      | V    |  |
| Output fall time from $V_{IHmin}$ to $V_{ILmax}$ with bus capacitance from 10 pF to 400 pF     | $t_{ m OF}$        | -             | 250  | 20+0.1C <sub>B</sub><br>Note 2 | 250                  | ns   |  |
| Pulse width of spikes which shall be suppressed by the input filter                            | $t_{\mathrm{SP}}$  | N/A           | N/A  | 0                              | 50                   | ns   |  |
| Input current each I/O pin with an input voltage between 0.1 $V_{\rm DD}$ and 0.9 $V_{\rm DD}$ | $I_{I}$            | -10           | 10   | -10<br>Note 3                  | 10<br>Note 3         | μΑ   |  |
| Input/Output capacitance (SDA)                                                                 | $C_{I/O}$          | -             | 8    | -                              | 8                    | pF   |  |
| Input capacitance (SCL)                                                                        | CI                 | -             | 6    | -                              | 6                    | pF   |  |

Note 1 Maximum VIH =  $V_{DDmax} + 0.5V$ 

440

Note 2  $C_B$  = capacitance of one bus line in pF

Note 3  $\,$  I/O pins of Fast-mode devices shall not obstruct the SDA and SCL line if  $V_{DD}$  is switched off

# **Table 2 CCI Timing Specification**

| Parameter                                                                                   | Symbol              | Standar | d-mode | Fast-mode |      | Unit |
|---------------------------------------------------------------------------------------------|---------------------|---------|--------|-----------|------|------|
|                                                                                             |                     | Min.    | Max.   | Min.      | Max. |      |
| SCL clock frequency                                                                         | $f_{SCL}$           | 0       | 100    | 0         | 400  | kHz  |
| Hold time (repeated) START condition. After this period, the first clock pulse is generated | t <sub>HD:STA</sub> | 0.4     | -      | 0.6       | -    | μs   |

|                                                                                 |                       | 1                    |                |                                |               |    |
|---------------------------------------------------------------------------------|-----------------------|----------------------|----------------|--------------------------------|---------------|----|
| LOW period of the SCL clock                                                     | $t_{ m LOW}$          | 4.7                  | -              | 1.3                            | -             | μs |
| HIGH period of the SCL clock                                                    | $t_{ m HIGH}$         | 4.0                  | -              | 0.6                            | -             | μs |
| Setup time for a repeated START condition                                       | $t_{ m SU;STA}$       | 4.7                  | -              | 0.6                            | -             | μs |
| Data hold time                                                                  | $t_{ m HD;DAT}$       | 0<br>Note 2          | 3.45<br>Note 3 | 0<br>Note 2                    | 0.9<br>Note 3 | μs |
| Data set-up time                                                                | $t_{\mathrm{SU;DAT}}$ | 250                  | -              | 100<br>Note 4                  | -             | ns |
| Rise time of both SDA and SCL signals                                           | $t_{\mathrm{R}}$      | -                    | 1000           | 20+0.1C <sub>B</sub><br>Note 5 | 300           | ns |
| Fall time of both SDA and SCL signals                                           | $t_{ m F}$            | -                    | 300            | 20+0.1C <sub>B</sub><br>Note 5 | 300           | ns |
| Set-up time for STOP condition                                                  | t <sub>SU;STO</sub>   | 4.0                  | -              | 0.6                            | -             | μs |
| Bus free time between a STOP and START condition                                | $t_{ m BUF}$          | 4.7                  | -              | 1.3                            | -             | μs |
| Capacitive load for each bus line                                               | $C_{B}$               | -                    | 400            | -                              | 400           | pF |
| Noise margin at the LOW level for each connected device (including hysteresis)  | $V_{nL}$              | $0.1V_{DD}$          | -              | $0.1V_{DD}$                    | -             | V  |
| Noise margin at the HIGH level for each connected device (including hysteresis) | $V_{\mathrm{nH}}$     | $0.2V_{\mathrm{DD}}$ | -              | $0.2V_{DD}$                    | -             | V  |

- Note 1 All values referred to  $V_{IHmin} = 0.9 \ V_{DD}$  and  $V_{ILmax} = 0.1 \ V_{DD}$
- Note 2 A device shall internally provide a hold time of at least 300 ns for the SDA signal (referred to the  $V_{IHmin}$  of the SCL signal) to bridge the undefined region of the falling edge of SCL
- Note 3 The maximum t<sub>HD:DAT</sub> has only to be met if the device does not the LOW period (t<sub>LOW</sub>) of the SCL signal
- Note 4 A Fast-mode I2C-bus device can be used in a Standard-mode I2C-bus system, but the requirement t<sub>SU;DAT</sub> ≥
- 446 250 ns shall be then met. This will be automatically the case if the device does not stretch the LOW period of the SCL
- signal. If such device does stretch the low period of SCL signal, it shall output the next data bit to the SDA line  $t_{rMAX}$  +
- $t_{SU;DAT} = 1000 + 250 = 1250$  ns (according to the Standard-mode I2C bus specification) before the SCL line is released.
- Note 5 CB = total capacitance of one bus line in pF.
- The CCI timing is illustrated in Figure 19.



Figure 19 CCI Timing

# 7 Physical Layer

- The CSI-2 uses the MIPI Alliance Standard for D-PHY [2] physical layer.
- 456 The physical layer for a CSI-2 implementation is composed of between one and four unidirectional data
- Lanes and one clock Lane. All CSI-2 transmitters and receivers shall support continuous clock behavior on
- 458 the Clock Lane, and optionally may support non-continuous clock behavior.
- 459 For continuous clock behavior the Clock Lane remains in high-speed mode generating active clock signals
- between the transmission of data packets.
- 461 For non-continuous clock behavior the Clock Lane enters the LP-11 state between the transmission of data
- 462 packets.

464

- The minimum physical layer requirement for a CSI-2 transmitter is
  - Data Lane Module: Unidirectional master, HS-TX, LP-TX and a CIL-MUYN function
- Clock Lane Module: Unidirectional master, HS-TX, LP-TX and a CIL-MCNN function
- The minimum physical layer requirement for a CSI-2 receiver is
- Data Lane Module: Unidirectional slave, HS-RX, LP-RX, and a CIL-SUYN function
- Clock Lane Module: Unidirectional slave, HS-RX, LP-RX, and a CIL-SCNN function
- All CSI-2 implementations shall support forward escape ULPM on all Data Lanes.

# 8 Multi-Lane Distribution and Merging

CSI-2 is a Lane-scalable specification. Applications requiring more bandwidth than that provided by one data Lane, or those trying to avoid high clock rates, can expand the data path to two, three, or four Lanes wide and obtain approximately linear increases in peak bus bandwidth. The mapping between data at higher layers and the serial bit stream is explicitly defined to ensure compatibility between host processors and peripherals that make use of multiple data Lanes.

Conceptually, between the PHY and higher functional layers is a layer that handles multi-Lane configurations. In the transmitter, the layer distributes a sequence of packet bytes across N Lanes, where each Lane is an independent unit of physical-layer logic (serializers, etc.) and transmission circuitry. In the receiver, it collects incoming bytes from N Lanes and consolidates (merges) them into complete packets to pass into the packet decomposer.



Figure 20 Conceptual Overview of the Lane Distributor Function



Figure 21 Conceptual Overview of the Lane Merging Function

The Lane distributor takes a transmission of arbitrary byte length, buffers up N bytes (where N = number of Lanes), and then sends groups of N bytes in parallel across N Lanes. Before sending data, all Lanes perform the SoT sequence in parallel to indicate to their corresponding receiving units that the first byte of a packet is beginning. After SoT, the Lanes send groups of successive bytes from the first packet in parallel, following a round-robin process.

#### Examples:

483 484

485

486

487

488 489

490

491

492

493

494

495

496

497

498

- 2-Lane system (Figure 22): byte 0 of the packet goes to Lane 1, byte 1 goes to Lane 2, byte 2 to Lane 1, byte 3 goes to Lane 2, byte 4 goes to Lane 1 and so on.
- 3-Lane system (Figure 23): byte 0 of the packet goes to Lane 1, byte 1 goes to Lane 2, byte 2 to Lane 3, byte 3 goes to Lane 1, byte 4 goes to Lane 2 and so on.
- 4-Lane system (Figure 24):byte 0 of the packet goes to Lane 1, byte 1 goes to Lane 2, byte 2 to Lane 3, byte 3 goes to Lane 4, byte 4 goes to Lane 1 and so on

At the end of the transmission, there may be "extra" bytes since the total byte count may not be an integer multiple of the number of Lanes, N. One or more Lanes may send their last bytes before the others. The

- Lane distributor, as it buffers up the final set of less-than-N bytes in parallel for sending to N data Lanes, de-asserts its "valid data" signal into all Lanes for which there is no further data.
- Each D-PHY data Lane operates autonomously.
- Although multiple Lanes all start simultaneously with parallel "start packet" codes, they may complete the transaction at different times, sending "end packet" codes one cycle (byte) apart.
- The N PHYs on the receiving end of the link collect bytes in parallel, and feed them into the Lane-merging layer. This reconstitutes the original sequence of bytes in the transmission, which can then be partitioned into individual packets for the packet decoder layer.

#### Number of Bytes, N, transmitted is an integer multiple of the number of lanes:



# Number of Bytes, N, transmitted is NOT an integer multiple of the number of lanes:



Figure 22 Two Lane Multi-Lane Example

# Number of Bytes, N, transmitted is an integer multiple of the number of lanes:



# Number of Bytes, N, transmitted is NOT an integer multiple of the number of lanes (Example 1):



# Number of Bytes, N, transmitted is NOT an integer multiple of the number of lanes (Example 2):



LPS - Low Power State

SoT – Start of Transmission

EoT – End of Transmission

513

514515

# Figure 23 Three Lane Multi-Lane Example

# Number of Bytes, N, transmitted is an integer multiple of the number of lanes:



# Number of Bytes, N, transmitted is NOT an integer multiple of the number of lanes:



Figure 24 Four Lane Multi-Lane Example

# 8.1 Multi-Lane Interoperability

The Lane distribution and merging layers shall be reconfigurable via the Camera Control Interface when more than one data Lane is used.

An "N" data Lane receiver shall be connected with an "M" data Lane transmitter, by CCI configuration of the Lane distribution and merging layers within the CSI-2 transmitter and receiver when more than one data Lane is used. Thus, a receiver with four data Lanes shall work with transmitters with one, two, three or four data Lanes. Likewise, a transmitter with four data Lanes shall work with receivers with four or fewer data Lanes. Transmitter Lanes 1 to M shall be connected to the receiver Lanes 1 to M.

#### 521 Two cases:

522

523

524

- If M<=N then there is no loss of performance the receiver has sufficient data Lanes to match the transmitter (Figure 25 and Figure 26).
- If M> N then there may be a loss of performance (e.g. frame rate) as the receiver has fewer data Lanes than the transmitter (Figure 27 and Figure 28).



Figure 25 One Lane Transmitter and Four Lane Receiver Example



Figure 26 Two Lane Transmitter and Four Lane Receiver Example



Figure 27 Four Lane Transmitter and One Lane Receiver Example



Figure 28 Four Lane Transmitter and Two Lane Receiver Example

#### 9 Low Level Protocol

- The Low Level Protocol (LLP) is a byte orientated, packet based protocol that supports the transport of
- arbitrary data using Short and Long packet formats. For simplicity, all examples in this section are single
- 537 Lane configurations.

534

543

545 546

547

552

- 538 Low Level Protocol Features:
- Transport of arbitrary data (Payload independent)
- 8-bit word size
- Support for up to four interleaved virtual channels on the same link
- Special packets for frame start, frame end, line start and line end information
  - Descriptor for the type, pixel depth and format of the Application Specific Payload data
- 16-bit Checksum Code for error detection.

#### DATA:



Figure 29 Low Level Protocol Packet Overview

#### 9.1 Low Level Protocol Packet Format

- Two packet structures are defined for low-level protocol communication: Long packets and Short packets.
- For each packet structure exit from the low power state followed by the Start of Transmission (SoT)
- sequence indicates the start of the packet. The End of Transmission (EoT) sequence followed by the low
- power state indicates the end of the packet.

## 9.1.1 Low Level Protocol Long Packet Format

- Figure 30 shows the structure of the Low Level Protocol Long Packet. A Long Packet shall be identified by
- Data Types 0x10 to 0x37. See Table 3 for a description of the Data Types. A Long Packet shall consist of
- 555 three elements: a 32-bit Packet Header (PH), an application specific Data Payload with a variable number
- of 8-bit data words and a 16-bit Packet Footer (PF). The Packet Header is further composed of three
- elements: an 8-bit Data Identifier, a 16-bit Word Count field and an 8-bit ECC. The Packet footer has one
- element, a 16-bit checksum. See sections 9.2 through 9.5 for further descriptions of the packet elements.

(PF)

## DATA IDENTIFIER (DI):

Contains the Virtual Channel Identifier and the Data Type Information Data Type denotes the format/content of the Application Specific Payload Data. Used by the application specific layer.

## 16-bit WORD COUNT (WC):

The receiver reads the next WC data words independent of their values. The receiver is NOT looking for any embedded sync sequences within the payload data. The receiver uses the WC value to determine the end End of the Packet

# 8-bit Error Correction Code (ECC) for the Packet Header:

8-bit ECC code for the Packet Header. Allows 1-bit errors with the packet header to be corrected and 2-bit errors to be detected

#### APPLICATION SPECIFIC PAYLOAD CHECKSUM (CS)



on the values of the data words

560 Figure 30 Long Packet Structure

(PH)

559

563

564

565

574

575

576

561 The Data Identifier defines the Virtual Channel for the data and the Data Type for the application specific payload data. 562

The Word Count defines the number of 8-bit data words in the Data Payload between the end of the Packet Header and the start of the Packet Footer. Neither the Packet Header nor the Packet Footer shall be included in the Word Count.

The Error Correction Code (ECC) byte allows single-bit errors to be corrected and 2-bit errors to be 566 detected in the packet header. This includes both the data identifier value and the word count value. 567

After the end of the Packet Header the receiver reads the next Word Count \* 8-bit data words of the Data 568 Payload. While reading the Data Payload the receiver shall not look for any embedded sync codes. 569 570

Therefore, there are no limitations on the value of a data word.

571 Once the receiver has read the Data Payload it reads the checksum in the Packet Footer. In the generic case, 572 the length of the Data Payload shall be a multiple of 8-bit data words. In addition, each data format may

573 impose additional restrictions on the length of the payload data, e.g. multiple of four bytes.

Each byte shall be transmitted least significant bit first. Payload data may be transmitted in any byte order restricted only by data format requirements. Multi-byte elements such as Word Count, Checksum and the Short packet 16-bit Data Field shall be transmitted least significant byte first.

After the EoT sequence the receiver begins looking for the next SoT sequence.

#### 9.1.2 Low Level Protocol Short Packet Format

- Figure 31 shows the structure of the Low Level Protocol Short Packet. A Short Packet shall be identified by
- Data Types 0x00 to 0x0F. See Table 3 for a description of the Data Types. A Short Packet shall contain
- only a Packet Header; a Packet Footer shall not be present. The Word Count field in the Packet Header
- shall be replaced by a Short Packet Data Field.
- For Frame Synchronization Data Types the Short Packet Data Field shall be the frame number. For Line
- 584 Synchronization Data Types the Short Packet Data Field shall be the line number. See Table 6 for a
- description of the Frame and Line synchronization Data Types.
- For Generic Short Packet Data Types the content of the Short Packet Data Field shall be user defined.
- The Error Correction Code (ECC) byte allows single-bit errors to be corrected and 2-bit errors to be
- 588 detected in the Short Packet.



589 590

578

Figure 31 Short Packet Structure

## 591 **9.2 Data Identifier (DI)**

The Data Identifier byte contains the Virtual Channel Identifier (VC) value and the Data Type (DT) value as illustrated in Figure 32. The Virtual Channel Identifier is contained in the two MS bits of the Data Identifier Byte. The Data Type value is contained in the six LS bits of the Data Identifier Byte.



595 596

Figure 32 Data Identifier Byte

598

599

600

601

602

603

604

605 606

607

## 9.3 Virtual Channel Identifier

The purpose of the Virtual Channel Identifier is to provide separate channels for different data flows that are interleaved in the data stream.

The Virtual channel identifier number is in the top two bits of the Data Identifier Byte. The Receiver will monitor the virtual channel identifier and de-multiplex the interleaved video streams to their appropriate channel. A maximum of four data streams is supported; valid channel identifiers are 0 to 3. The virtual channel identifiers in the peripherals should be programmable to allow the host processor to control how the data streams are de-multiplexed. The principle of logical channels is presented in the Figure 33.



Figure 33 Logical Channel Block Diagram (Receiver)

Figure 34 illustrates an example of data streams utilizing virtual channel support.



608 EOT – ENGOLITATISTISSION

Figure 34 Interleaved Video Data Streams Examples

# 9.4 Data Type (DT)

- The data type value specifies the format and content of the payload data. A maximum of sixty-four data
- types are supported.

609

610

618

- There are eight different data type classes as shown in Table 3. Within each class there are up to eight
- different data type definitions. The first two classes denote short packet data types. The remaining six
- classes denote long packet data types.
- For details on the short packet data type classes please refer to section 9.8.
- For details on the five long packet data type classes please refer to section 11.

# Table 3 Data Type Classes

| Data Type   | Description                             |
|-------------|-----------------------------------------|
| 0x00 - 0x07 | Synchronization Short Packet Data Types |
| 0x08 - 0x0F | Generic Short Packet Data Types         |
| 0x10 - 0x17 | Generic Long Packet Data Types          |
| 0x18 - 0x1F | YUV Data                                |
| 0x20 - 0x27 | RGB Data                                |

| Data Type   | Description                  |
|-------------|------------------------------|
| 0x28 - 0x2F | RAW Data                     |
| 0x30 - 0x37 | User Defined Byte-based Data |
| 0x38 - 0x3F | Reserved                     |

620

626

#### **Packet Header Error Correction Code** 9.5

- 621 The correct interpretation of the data identifier and word count values is vital to the packet structure. The Packet Header Error Correction Code byte allows single-bit errors in the data identifier and the word count 622
- to be corrected and two-bit errors to be detected. The 24-bit subset of the code described in section 9.5.2 623
- 624 shall be used. Therefore, bits 7 and 6 of the ECC byte shall always be zero. The error state based on ECC
- 625 decoding shall be available at the Application layer in the receiver.

#### 9.5.1 **General Hamming Code Applied to Packet Header**

- 627 The number of parity or error check bits required is given by the Hamming rule, and is a function of the 628 number of bits of information transmitted. The Hamming rule is expressed by the following inequality:
- $d + p + 1 \le 2^p$ 629 where d is the number of data bits and p is the number of parity bits.
- 630 The result of appending the computed parity bits to the data bits is called the Hamming code word. The size
- 631 of the code word c is obviously d + p, and a Hamming code word is described by the ordered set (c,d). A
- 632 Hamming code word is generated by multiplying the data bits by a generator matrix G. This
- multiplication's result is called the code word vector (c1, c2, c3,...cn), consisting of the original data bits 633
- 634 and the calculated parity bits. The generator matrix G used in constructing Hamming codes consists of I
- 635 (the identity matrix) and a parity generation matrix **A**:
- 636  $G = [I \mid A]$
- 637 The packet header plus the ECC code can be obtained as: PH = p\*G where p represents the header (24 or 638 64 bits) and **G** is the corresponding generator matrix.
- 639 Validating the received code word r, involves multiplying it by a parity check to form s, the syndrome or 640 parity check vector:  $s = \mathbf{H}^*PH$  where PH is the received packet header and  $\mathbf{H}$  is the parity check matrix:
- $\mathbf{H} = [\mathbf{A}^{\mathbf{T}} \mid \mathbf{I}]$ 641
- 642 If all elements of s are zero, the code word was received correctly. If s contains non-zero elements, then at
- 643 least one error is present. If a single bit error is encountered then the syndrome s is one of the elements of H
- 644 which will point to the bit in error. Further, in this case, if the bit in error is one of the parity bits, then the
- syndrome will be one of the elements on I, else it will be the data bit identified by the position of the 645
- syndrome in  $A^{T}$ . 646

647

#### 9.5.2 **Hamming-modified Code**

- 648 The error correcting code used is a 7+1bits Hamming-modified code (72.64) and the subset of it is 5+1bits 649
  - or (30,24). Hamming codes use parity to correct one error or detect two errors, but they are not capable of

doing both simultaneously, thus one extra parity bit needs to be added. The code used, is build to allow same syndromes to correct first 24-bits in a 64-bit sequence and those syndromes to be 6-bits wide. To specify in a compact way the encoding of parity and decoding of syndromes, the following matrix is used:

#### **Table 4 ECC Syndrome Association Matrix**

| d5d4d3 | d2d1d0 | 000040 | 05001 | 05010 | 05011 | 05100 | 05101 | 05110 | 06111 |
|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|
| 0Ь000  |        | 0x07   | 0x0B  | 0x0D  | 0x0E  | 0x13  | 0x15  | 0x16  | 0x19  |
| 0b001  |        | 0x1A   | 0x1C  | 0x23  | 0x25  | 0x26  | 0x29  | 0x2A  | 0x2C  |
| 0b010  |        | 0x31   | 0x32  | 0x34  | 0x38  | 0x1F  | 0x2F  | 0x37  | 0x3B  |
| 0b011  |        | 0x43   | 0x45  | 0x46  | 0x49  | 0x4A  | 0x4C  | 0x51  | 0x52  |
| 0b100  |        | 0x54   | 0x58  | 0x61  | 0x62  | 0x64  | 0x68  | 0x70  | 0x83  |
| 0b101  |        | 0x85   | 0x86  | 0x89  | 0x8A  | 0x3D  | 0x3E  | 0x4F  | 0x57  |
| 0b110  |        | 0x8C   | 0x91  | 0x92  | 0x94  | 0x98  | 0xA1  | 0xA2  | 0xA4  |
| 0b111  |        | 0xA8   | 0xB0  | 0xC1  | 0xC2  | 0xC4  | 0xC8  | 0xD0  | 0xE0  |

Each cell in the matrix represents a syndrome and the first twenty-four cells (the orange rows) are using the first three or five bits to build the syndrome. Each syndrome in the matrix is MSB left aligned:

e.g. 0x07=0b0000 0111=P7P6P5P4P3P2P1P0

The top row defines the three LSB of data position bit, and the left column defines the three MSB of data position bit (there are 64-bit positions in total).

e.g. 37th bit position is encoded 0b100 101 and has the syndrome 0x68.

To derive the parity P0 for 24-bits, the P0's in the orange rows will define if the corresponding bit position is used in P0 parity or not.

Similar, to derive the parity P0 for 64-bits, all P0's in Table 5 will define the corresponding bit positions to be used.

To correct a single-bit error, the syndrome has to be one of the syndromes Table 4, which will identify the bit position in error. The syndrome is calculated as:

 $S = P_{SEND}^{\ \ \ \ }P_{RECEIVED}$  where  $P_{SEND}$  is the 8/6-bit ECC field in the header and  $P_{RECEIVED}$  is the calculated parity of the received header.

Table 5 represents the same information as the matrix in Table 4, organized such that will give a better insight on the way parity bits are formed out of data bits. The orange area of the table has to be used to form the ECC to protect a 24-bit header, whereas the whole table has to be used to protect a 64-bit header.

**Table 5 ECC Parity Generation Rules** 

| Bit | P7 | P6 | P5 | P4 | Р3 | P2 | P1 | P0 | Hex  |
|-----|----|----|----|----|----|----|----|----|------|
| 0   | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0x07 |
| 1   | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0x0B |
| 2   | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 0x0D |
| 3   | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0x0E |
| 4   | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0x13 |
| 5   | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 0x15 |
| 6   | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 0x16 |
| 7   | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0x19 |
| 8   | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 0x1A |
| 9   | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0x1C |
| 10  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0x23 |
| 11  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | 0x25 |
| 12  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 0x26 |
| 13  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | 0x29 |
| 14  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0x2A |
| 15  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0x2C |
| 16  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 0x31 |
| 17  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0x32 |
| 18  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | 0x34 |
| 19  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0x38 |
| 20  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0x1F |
| 21  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 0x2F |
| 22  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 1  | 0x37 |
| 23  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 1  | 0x3B |
| 24  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 0x43 |
| 25  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 0x45 |

| Bit | P7 | P6 | P5 | P4 | Р3 | P2 | P1 | P0 | Hex  |
|-----|----|----|----|----|----|----|----|----|------|
| 26  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0x46 |
| 27  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | 0x49 |
| 28  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 0x4A |
| 29  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0x4C |
| 30  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 1  | 0x51 |
| 31  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0x52 |
| 32  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0x54 |
| 33  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0x58 |
| 34  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0x61 |
| 35  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 0  | 0x62 |
| 36  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0x64 |
| 37  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0x68 |
| 38  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0x70 |
| 39  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0x83 |
| 40  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0x85 |
| 41  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0x86 |
| 42  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0x89 |
| 43  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 0x8A |
| 44  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 1  | 0x3D |
| 45  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 0x3E |
| 46  | 0  | 1  | 0  | 0  | 1  | 1  | 1  | 1  | 0x4F |
| 47  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 1  | 0x57 |
| 48  | 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0x8C |
| 49  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0x91 |
| 50  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0x92 |
| 51  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0x94 |
| 52  | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0x98 |

| Bit | P7 | P6 | P5 | P4 | Р3 | P2 | P1 | P0 | Hex  |
|-----|----|----|----|----|----|----|----|----|------|
| 53  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0xA1 |
| 54  | 1  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0xA2 |
| 55  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0xA4 |
| 56  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0xA8 |
| 57  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0xB0 |
| 58  |    |    | 0  | 0  | 0  | 0  | 0  |    |      |
|     | 1  | 1  |    |    |    |    |    | 1  | 0xC1 |
| 59  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0xC2 |
| 60  | 1  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0xC4 |
| 61  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0xC8 |
| 62  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0xD0 |
| 63  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0xE0 |

## 9.5.3 ECC Generation on TX Side

This is an informative section.

The ECC can be easily implemented using a parallel approach as depicted in Figure 35 for a 64-bit header.



677

678

Figure 35 64-bit ECC Generation on TX side

And Figure 36 for a 24-bit header:



682

683

684

685

686

687

Figure 36 24-bit ECC Generation on TX side

The parity generators are based on Table 5.

e.g.  $P3_{24\text{-bit}} = D1^D2^D3^D7^D8^D9^D13^D14^D15^D19^D20^D21^D23$ 

# 9.5.4 Applying ECC on RX Side

Applying ECC on RX side involves generating a new ECC for the received packet, computing the syndrome using the new ECC and the received ECC, decoding the syndrome to find if a single-error has occurred and if so, correct it.



688 689

690

Figure 37 64-bit ECC on RX Side Including Error Correction

Decoding the syndrome has three aspects:

693

694

695

696

697

698

699

700

701

- Finding if the packet has any errors (if syndrome is 0, no errors are present)
- Checking if a single error has occurred by searching Table 5, if the syndrome is one of the entries in the table, then a single bit error has occurred and the corresponding bit is affected, thus this position in the data stream needs to be complemented. Also, if the syndrome is one of the rows of the identity matrix I, then one of the parity bits are in error. If the syndrome cannot be identified, then a higher order error has occurred and the error flag will be set (the stream is corrupted and cannot be restored).
- Correcting the single error detected, as indicated above.

The 24-bit implementation uses fewer terms to calculate the parity and thus the syndrome decoding block is much simpler than the 64-bit implementation.



Figure 38 24-bit ECC on RX side Including Error Correction

#### 9.6 Checksum Generation

To detect possible errors in transmission, a checksum is calculated over each data packet. The checksum is realized as 16-bit CRC. The generator polynomial is  $x^16+x^12+x^5+x^0$ .

The transmission of the checksum is illustrated in Figure 39.



Figure 39 Checksum Transmission

709710

702 703

704

705

706

707

708

Copyright © 2005 MIPI Alliance, Inc. All rights reserved.
MIPI Alliance Member Confidential.

The 16-bit checksum sequence is transmitted as part of the Packet Footer. When the Word Count is zero, the CRC shall be 0xFFFF.



Figure 40 Checksum Generation for Packet Data

The definition of a serial CRC implementation is presented in Figure 41. The CRC implementation shall be functionally equivalent with the C code presented in Figure 42. The CRC shift register is initialized to 0xFFFF at the beginning of each packet. After all payload data has passed through the CRC circuitry, the CRC circuitry contains the checksum. The 16-bit checksum produced by the C code in Figure 42 equals the final contents of the C[15:0] shift register shown in Figure 41. The checksum is then sent over CSI-2 bus to the receiver to verify that no errors have occurred in the transmission.



Polynomial:  $x^16 + x^12 + x^5 + x^0$ 

Note: C15 represents x^0, C0 represents x^15

721 722 723

713714

715

716

717

718 719

720

Figure 41 Definition of 16-bit CRC Shift Register

```
#define POLY 0x8408
                      /* 1021H bit reversed */
unsigned short crc16(char *data_p, unsigned short length)
      unsigned char i;
     unsigned int data;
     unsigned int crc = 0xffff;
      if (length == 0)
            return (unsigned short)(crc);
      do
            for (i=0, data=(unsigned int)0xff & *data_p++;
              i < 8;i++, data >>= 1)
                  if ((crc & 0x0001) ^ (data & 0x0001))
                        crc = (crc >> 1) ^ POLY;
                  else
                        crc >>= 1;
      } while (--length);
      // Uncomment to change from little to big Endian
     crc = ((crc & 0xff) << 8) | ((crc & 0xff00) >> 8);
      return (unsigned short)(crc);
```

Figure 42 16-bit CRC Software Implementation Example

The data and checksum are transmitted least significant byte first. Each bit within a byte is transmitted least significant bit first.

727 728 729

738

726

```
729 Data:
730 FF 00 00 02 B9 DC F3 72 BB D4 B8 5A C8 75 C2 7C 81 F8 05 DF FF 00 00 01
731 Checksum LS byte and MS byte:
732 F0 00
733
734 Data:
735 FF 00 00 00 1E F0 1E C7 4F 82 78 C5 82 E0 8C 70 D2 3C 78 E9 FF 00 00 01
736 Checksum LS byte and MS byte:
737 69 E5
```

# 9.7 Packet Spacing

- Between Low Level Protocol packets there must always be a transition into and out of the Low Power State (LPS). Figure 43 illustrates the packet spacing with the LPS.
- The packet spacing does not have to be a multiple of 8-bit data words as the receiver will resynchronize to the correct byte boundary during the SoT sequence prior to the Packet Header of the next packet.

#### SHORT / LONG PACKET SPACING:

Variable - always a LPS between packets



ST – Start of Transmission PF – Packet Flooter ET – End of Transmission SP – Short Packet

744 Figure 43 Packet Spacing

## 9.8 Synchronization Short Packet Data Type Codes

Short Packet Data Types shall be transmitted using only the Short Packet format. See section 9.1.2 for a format description.

**Table 6 Synchronization Short Packet Data Type Codes** 

| Data Type   | Description                |
|-------------|----------------------------|
| 0x00        | Frame Start Code           |
| 0x01        | Frame End Code             |
| 0x02        | Line Start Code (Optional) |
| 0x03        | Line End Code (Optional)   |
| 0x04 - 0x07 | Reserved                   |

## 9.8.1 Frame Synchronization Packets

- Each image frame shall begin with a Frame Start (FS) Packet containing the Frame Start Code. The FS
- Packet shall be followed by one or more long packets containing image data and zero or more short packets
- 752 containing synchronization codes. Each image frame shall end with a Frame End (FE) Packet containing
- 753 the Frame End Code. See Table 6 for a description of the synchronization code data types.
- For FS and FE synchronization packets the Short Packet Data Field shall contain a 16-bit frame number.
- 755 This frame number shall be the same for the FS and FE synchronization packets corresponding to a given
- 756 frame.

743

745

746

747

748

749

764

772

773

774

775

776 777

778

779 780

781

782

784

- The 16-bit frame number, when used, shall always be non-zero to distinguish it from the use-case where frame number is inoperative and remains set to zero.
- The behavior of the 16-bit frame number shall be as one of the following
  - Frame number is always zero frame number is inoperative.
- Frame number increments by 1 for every FS packet with the same Virtual Channel and is periodically reset to one e.g. 1, 2, 1, 2, 1, 2 or 1, 2, 3, 4, 1, 2, 3, 4
- The frame number must be a non-zero value.

## 9.8.2 Line Synchronization Packets

- Line synchronization packets are optional.
- 766 For Line Start (LS) and Line End (LE) synchronization packets the Short Packet Data Field shall contain a
- 767 16-bit line number. This line number shall be the same for the LS and LE packets corresponding to a given
- 768 line. Line numbers are logical line numbers and are not necessarily equal to the physical line numbers
- The 16-bit line number, when used, shall always be non-zero to distinguish it from the case where line number is inoperative and remains set to zero.
- The behavior of the 16-bit line number shall be as one of the following:
  - Line number is always zero line number is inoperative.
    - Line number increments by one for every LS packet within the same Virtual Channel and the same Data Type. The line number is periodically reset to one for the first LS packet after a FS packet. The intended usage is for progressive scan (non-interlaced) video data streams. The line number must be a non-zero value.
    - Line number increments by the same arbitrary step value greater than one for every LS packet within the same Virtual Channel and the same Data Type. The line number is periodically reset to a non-zero arbitrary start value for the first LS packet after a FS packet. The arbitrary start value may be different between successive frames. The intended usage is for interlaced video data streams.

## 9.9 Generic Short Packet Data Type Codes

783 Table 7 lists the Generic Short Packet Data Types.

#### **Table 7 Generic Short Packet Data Type Codes**

| Data Type | Description                 |
|-----------|-----------------------------|
| 0x08      | Generic Short Packet Code 1 |
| 0x09      | Generic Short Packet Code 2 |
| 0x0A      | Generic Short Packet Code 3 |
| 0x0B      | Generic Short Packet Code 4 |
| 0x0C      | Generic Short Packet Code 5 |

| Data Type | Description                 |
|-----------|-----------------------------|
| 0x0D      | Generic Short Packet Code 6 |
| 0x0E      | Generic Short Packet Code 7 |
| 0x0F      | Generic Short Packet Code 8 |

The intention of the Generic Short Packet Data Types is to provide a mechanism for including timing information for the opening/closing of shutters, triggering of flashes, etc within the data stream. The intent of the 16-bit User defined data field in the generic short packets is to pass a data type value and a 16-bit data value from the transmitter to application layer in the receiver. The CSI-2 receiver shall pass the data type value and the associated 16-bit data value to the application layer.

## 9.10 Packet Spacing Examples

- Packets are separated by an EoT, LPS, SoT sequence as defined in MIPI Alliance Standard for D-PHY [2].
- Figure 44 and Figure 45 contain examples of data frames composed of multiple packets and a single packet, respectively.
- Note that the VVALID, HVALID and DVALID signals in the figures in this section are only concepts to help illustrate the behavior of the frame start/end and line start/end packets. The VVALID, HVALID and DVALID signals do not form part of the specification

  797

Frame Start First Packet Last Packet Frame End Packet Of Data PF(EoT) LPS (SoT)(FE)(EoT)

WALID

DVALID

KEY:

SoT – Start of Transmission EoT – End of Transmission LPS – Low Power State

PH – Packet Header PF – Packet Footer FS – Frame Start FE – Frame End LS – Line Start LE – Line End

798 799 800

785

786

787

788 789

790

Figure 44 Multiple Packet Example



SoT – Start of Transmission EoT – End of Transmission LPS – Low Power State

PH – Packet Header PF – Packet Footer FS – Frame Start FE – Frame End LS – Line Start LE – Line End

801 802

Figure 45 Single Packet Example





KEY:

SoT – Start of Transmission EoT – End of Transmission LPS – Low Power State

PH – Packet Header PF – Packet Footer FS – Frame Start FE – Frame End LS – Line Start LE – Line End

803 804

805

806

Figure 46 Line and Frame Blanking Definitions

The period between the Packet Footer of one long packet and the Packet Header of the next long packet is called the Line Blanking Period.

815

816

817

818

The period between the Frame End packet in frame N and the Frame Start packet in frame N+1 is called the Frame Blanking Period (Figure 46).

The Line Blanking Period is not fixed and may vary in length. The receiver should be able to cope with a near zero Line Blanking Period as defined in *MIPI Alliance Standard for D-PHY* [2]. The transmitter defines the minimum time for the Frame Blanking Period. The Frame Blanking Period duration should be programmable in the transmitter.

- Frame Start and Frame End packets shall always be used.
- Recommendations (informative) for frame start and end packet spacing:
  - The Frame Start packet to first data packet spacing should be as close as possible to the minimum packet spacing
  - The last data packet to Frame End packet spacing should be as close as possible to the minimum packet spacing
- The intention is to ensure that the Frame Start and Frame End packets accurately denote the start and end of a frame of image data. A valid exception is when the positions of the Frame Start and Frame End packets are being used to convey pixel level accurate vertical synchronization timing information.
- The positions of the Frame Start and Frame End packets can be varied within the Frame Blanking Period in order to provide pixel level accurate vertical synchronization timing information. See Figure 47.
- Line Start and Line End packets shall be used for pixel level accurate horizontal synchronization timing information.
- The positions of the Line Start and Line End packets, if present, can be varied within the Line Blanking Period in order to provide pixel accurate horizontal synchronization timing information. See Figure 48.



Figure 47 Vertical Sync Example

828829



833

834

835

836 837

838

839

840

841

842

843

844845

846

847

848

Figure 48 Horizontal Sync Example

# 9.11 Packet Data Payload Size Rules

For YUV, RGB or RAW data types, one long packet shall contain one line of image data. Each long packet of the same Data Type shall have equal length when packets are within the same Virtual Channel and when packets are within the same frame. An exception to this rule is the YUV420 data type which is defined in section 11.2.2.

For User Defined Byte-based Data Types, long packets can have arbitrary length. The spacing between packets can also vary.

The total size of data within a long packet for all data types shall be a multiple of eight bits. However, it is also possible that a data type's payload data transmission format, as defined elsewhere in this specification, imposes additional constraints on payload size. In order to meet these constraints it may sometimes be necessary to add some number of "padding" pixels to the end of a payload e.g., when a packet with the RAW10 data type contains an image line whose length is not a multiple of four pixels as required by the RAW10 transmission format as described in Section 11.4.4. The values of such padding pixels are not specified.

## 9.12 Frame Format Examples

- This in an informative section.
- This section contains three examples to illustrate how the CSI-2 features can be used.
- General Frame Format Example, Figure 49
- Digital Interlaced Video Example, Figure 50
- Digital Interlaced Video with accurate synchronization timing information, Figure 51



PH – Packet Header PF – Packet Footer FS – Frame Start FE – Frame End LS – Line Start LE – Line End

Figure 49 General Frame Format Example



PH – Packet Header PF – Packet Footer FS – Frame Start FE – Frame End LS – Line Start LE – Line End

Figure 50 Digital Interlaced Video Example

855856



PH - Packet Header PF - Packet Footer FS - Frame Start FE - Frame End LS-Line Start LE-Line End

Figure 51 Digital Interlaced Video with Accurate Synchronization Timing Information

# 9.13 Data Interleaving

857 858

859

860 The CSI-2 supports the interleaved transmission of different image data formats within the same video data 861 stream.

- There are two methods to interleave the transmission of different image data formats:
- Data Type

876

877

882

883

- Virtual Channel Identifier
- The above methods of interleaved data transmission can be combined in any manner.

## 9.13.1 Data Type Interleaving

- The Data Type value uniquely defines the data format for that packet of data. The receiver uses the Data
- Type value in the packet header to de-multiplex data packets containing different data formats as illustrated
- 869 in Figure 52. Note, in the figure the Virtual Channel Identifier is the same in each Packet Header.
- The packet payload data format shall always agree with the Data Type code in the Packet Header as follows:
- For defined image data types any non-reserved codes in the range 0x18 to 0x3F only the single corresponding MIPI-defined packet payload data format shall be considered correct
- Reserved image data types any reserved codes in the range 0x18 to 0x3F shall not be used. No packet payload data format shall be considered correct for reserved image data types
  - For generic long packet data types (codes 0x10 thru 0x17) and user-defined, byte-based (codes 0x30 0x37), any packet payload data format shall be considered correct
- Generic long packet data types (codes 0x10 thru 0x17) and user-defined, byte-based (codes 0x30 0x37), should not be used with packet payloads that meet any MIPI image data format definition
- Synchronization short packet data types (codes 0x00 thru 0x07) shall consist of only the header and shall not include payload data bytes
  - Generic short packet data types (codes 0x08 thru 0x0F) shall consist of only the header and shall not include payload data bytes
- Data formats are defined further in section 11.

888 889

890 891

892

893



Figure 52 Interleaved Data Transmission Using Data Type Value

All of the packets within the same virtual channel, independent of the Data Type value, share the same frame start/end and line start/end synchronization information. By definition, all of the packets, independent of data type, between a Frame Start and a Frame End packet within the same virtual channel belong to the same frame.

Packets of different data types may be interleaved at either the packet level as illustrated in Figure 53 or the frame level as illustrated in Figure 54. Data formats are defined in section 11.



LPS – Low Power State
FS – Frame Start
FE – Frame End
ED – Packet Header containing Embedded Data type code
D1 – Packet Header containing Data Type 1 Image Data Code
D2 – Packet Header containing Data Type 2 Image Data Code

PF – Packet Footer

Figure 53 Packet Level Interleaved Data Transmission



896

897

898

899

900

LPS – Low Power State
FS – Frame Start
FE – Frame End
ED – Packet Header containing Embedded Data type code
D1 – Packet Header containing Data Type 1 Image Data Code
D2 – Packet Header containing Data Type 2 Image Data Code

PF - Packet Footer

Figure 54 Frame Level Interleaved Data Transmission

#### 9.13.2 Virtual Channel Identifier Interleaving

The Virtual Channel Identifier allows different data types within a single data stream to be logically separated from each other. Figure 55 illustrates data interleaving using the Virtual Channel Identifier.

902

903

906

907

908

909

910 911 Each virtual channel has its own Frame Start and Frame End packet. Therefore, it is possible for different virtual channels to have different frame rates, though the data rate for both channels would remain the same.

In addition, Data Type value Interleaving can be used for each virtual channel thereby allowing different data types within a virtual channel and thus a second level of data interleaving.

Therefore, receivers should be able to de-multiplex different data packets based on the combination of the Virtual Channel Identifier and the Data Type value. For example, data packets containing the same Data Type value but transmitted on different virtual channels are considered to belong to different frames (streams) of image data.



Figure 55 Interleaved Data Transmission using Virtual Channels

# 10 Color Spaces

- 913 The color space definitions in this section are simply references to other standards. The references are
- 914 included only for informative purposes and not for compliance. The color space used is not limited to the
- 915 references given.

912

916

## 10.1 RGB Color Space Definition

- 917 In this specification, the abbreviation RGB means the nonlinear sR'G'B' color space in 8-bit representation
- 918 based on the definition of sRGB in IEC 61966.
- The 8-bit representation results as RGB888. The conversion to the more commonly used RGB565 format is
- 920 achieved by scaling the 8-bit values to five bits (blue and red) and six bits (green). The scaling can be done
- either by simply dropping the LSBs or rounding.

## 922 10.2 YUV Color Space Definition

- 923 In this specification, the abbreviation YUV refers to the 8-bit gamma corrected Y'CBCR color space
- 924 defined in ITU-R BT601.4.

#### 11 Data Formats

- The intent of this section is to provide a definitive reference for data formats typically used in CSI-2
- 927 applications. Table 8 summarizes the formats, followed by individual definitions for each format. Generic
- data types not shown in the table are described in section 11.1. For simplicity, all examples are single Lane
- 929 configurations.

925

935

- The formats most widely used in CSI-2 applications are distinguished by a "primary" designation in Table
- 931 8. Transmitter implementations of CSI-2 should support at least one of these primary formats. Receiver
- implementations of CSI-2 should support all of the primary formats.
- The packet payload data format shall always agree with the Data Type value in the Packet Header. See
- 934 Section 9.4 for a description of the Data Type values.

# **Table 8 Primary and Secondary Data Formats Definitions**

| Data Format           | Primary | Secondary |
|-----------------------|---------|-----------|
| Data Format           | Filmary | Secondary |
| YUV420 8-bit (legacy) |         | S         |
| YUV420 8-bit          |         | S         |
| YUV420 10-bit         |         | S         |
| YUV420 8-bit (CSPS)   |         | S         |
| YUV420 10-bit (CSPS)  |         | S         |
| YUV422 8-bit          | P       |           |
| YUV422 10-bit         |         | S         |
| RGB888                | P       |           |
| RGB666                |         | S         |
| RGB565                | P       |           |
| RGB555                |         | S         |
| RGB444                |         | S         |
| RAW6                  |         | S         |
| RAW7                  |         | S         |
| RAW8                  | P       |           |
| RAW10                 | P       |           |
| RAW12                 |         | S         |

941

942

947

| Data Format                             | Primary | Secondary |
|-----------------------------------------|---------|-----------|
| RAW14                                   |         | S         |
| Generic 8-bit Long Packet Data<br>Types | P       |           |
| User Defined Byte-based Data (Note 1)   | P       |           |

- Note 1. Compressed image data should use the user defined, byte-based data type codes
- For clarity the Start of Transmission and End of Transmission sequences in the figures in this section have been omitted.

## 11.1 Generic 8-bit Long Packet Data Types

Table 9 defines the generic 8-bit Long packet data types.

# **Table 9 Generic 8-bit Long Packet Data Types**

| Data Type | Description                   |
|-----------|-------------------------------|
| 0x10      | Null                          |
| 0x11      | Blanking Data                 |
| 0x12      | Embedded 8-bit non Image Data |
| 0x13      | Reserved                      |
| 0x14      | Reserved                      |
| 0x15      | Reserved                      |
| 0x16      | Reserved                      |
| 0x17      | Reserved                      |

## 11.1.1 Null and Blanking Data

- For both the null and blanking data types the receiver must ignore the content of the packet payload data.
- A blanking packet differs from a null packet in terms of its significance within a video data stream. A null
- 945 packet has no meaning whereas the blanking packet may be used, for example, as the blanking lines
- between frames in an ITU-R BT.656 style video stream.

## 11.1.2 Embedded Information

- 948 It is possible to embed extra lines containing additional information to the beginning and to the end of each
- 949 picture frame as presented in the Figure 56. If embedded information exists, then the lines containing the
- embedded data must use the embedded data code in the data identifier.

- There may be zero or more lines of embedded data at the start of the frame. These lines are termed the frame header.
- There may be zero or more line of embedded data at the end of the frame. These lines are termed the frame footer.

## 11.2 YUV Image Data

955

- Table 10 defines the data type codes for YUV data formats described in this section. The number of lines transmitted for the YUV420 data type shall be even.
- 958 YUV420 data formats are divided into legacy and non-legacy data formats. The legacy YUV420 data format is for compatibility with existing systems. The non-legacy YUV420 data formats enable lower cost implementations.



Payload Data per packet must be a multiple of 8-bits

KEY:

961 962

963

LPS – Low Power State DI – Data Identifier WC – Word Count ECC – Error Correction Code CS – Checksum ED – Embedded Data FS – Frame Start FE – Frame End

LS-Line Start LE-Line End

Figure 56 Frame Structure with Embedded Data at the Beginning and End of the Frame

Table 10 YUV Image Data Types

| Data Type | Description  |  |
|-----------|--------------|--|
| 0x18      | YUV420 8-bit |  |

| Data Type | Type Description                              |  |
|-----------|-----------------------------------------------|--|
| 0x19      | YUV420 10-bit                                 |  |
| 0x1A      | Legacy YUV420 8-bit                           |  |
| 0x1B      | Reserved                                      |  |
| 0x1C      | YUV420 8-bit (Chroma Shifted Pixel Sampling)  |  |
| 0x1D      | YUV420 10-bit (Chroma Shifted Pixel Sampling) |  |
| 0x1E      | YUV422 8-bit                                  |  |
| 0x1F      | YUV422 10-bit                                 |  |

# 11.2.1 Legacy YUV420 8-bit

964

968

969970

973974

Legacy YUV420 8-bit data transmission is performed by transmitting UYY... / VYY... sequences in odd / even lines. U component is transferred in odd lines (1,3,5...) and V component is transferred in even lines (2,4,6...). This sequence is illustrated in Figure 57.

Table 11 specifies the packet size constraints for YUV420 8-bit packets. Each packet must be a multiple of the values in the table.

Table 11 Legacy YUV420 8-bit Packet Data Size Constraints

| Pixels | Bytes | Bits |  |
|--------|-------|------|--|
| 2      | 3     | 24   |  |

971 Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated 972 in Figure 58.



Figure 57 Legacy YUV420 8-bit Transmission



Figure 58 Legacy YUV420 8-bit Pixel to Byte Packing Bitwise Illustration

There is one spatial sampling option

975

976

977

978

979

980

• H.261, H.263 and MPEG1 Spatial Sampling (Figure 59).



Figure 59 Legacy YUV420 Spatial Sampling for H.261, H.263 and MPEG 1



983

984

985

986 987

988

991

992993

994

995

Figure 60 Legacy YUV420 8-bit Frame Format

#### 11.2.2 YUV420 8-bit

YUV420 8-bit data transmission is performed by transmitting YYYY... / UYVYUYVY... sequences in odd / even lines. Only the luminance component (Y) is transferred for odd lines (1, 3, 5...) and both luminance (Y) and chrominance (U and V) components are transferred for even lines (2, 4, 6...). The format for the even lines (UYVY) is identical to the YUV422 8-bit data format. The data transmission sequence is illustrated in Figure 61.

The payload data size, in bytes, for even lines (UYVY) is double the payload data size for odd lines (Y). This is exception to the general CSI-2 rule that each line shall have an equal length.

Table 12 specifies the packet size constraints for YUV420 8-bit packets. Each packet must be a multiple of the values in the table.

**Table 12 YUV420 8-bit Packet Data Size Constraints** 

| Odd Lines (1, 3, 5)<br>Luminance Only, Y |       | Even Lines (2, 4, 6) Luminance and Chrominance, UYVY |        |       |      |
|------------------------------------------|-------|------------------------------------------------------|--------|-------|------|
| Pixels                                   | Bytes | Bits                                                 | Pixels | Bytes | Bits |
| 2                                        | 2     | 16                                                   | 2      | 4     | 32   |

Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated in Figure 62.



996 997

Figure 61 YUV420 8-bit Data Transmission Sequence

#### Odd lines:



#### Even lines:



998 999

1000

1001

1002

1003

Figure 62 YUV420 8-bit Pixel to Byte Packing Bitwise Illustration

There are two spatial sampling options

- H.261, H.263 and MPEG1 Spatial Sampling (Figure 63).
- Chroma Shifted Pixel Sampling (CSPS) for MPEG2, MPEG4 (Figure 64).

Figure 65 shows the YUV420 frame format.



10051006

Figure 63 YUV420 Spatial Sampling for H.261, H.263 and MPEG 1

10091010

1011

1012

1013

1014

1015 1016

1019

1020



Figure 64 YUV420 Spatial Sampling for MPEG 2 and MPEG 4



Figure 65 YUV420 8-bit Frame Format

#### 11.2.3 YUV420 10-bit

YUV420 10-bit data transmission is performed by transmitting YYYY... / UYVYUYVY... sequences in odd / even lines. Only the luminance component (Y) is transferred in odd lines (1, 3, 5...) and both luminance (Y) and chrominance (U and V) components transferred in even lines (2, 4, 6...). The format for the even lines (UYVY) is identical to the YUV422 –10-bit data format. The sequence is illustrated in Figure 66.

The payload data size, in bytes, for even lines (UYVY) is double the payload data size for odd lines (Y).

This is exception to the general CSI-2 rule that each line shall have an equal length.

Table 13 specifies the packet size constraints for YUV420 10-bit packets. The length of each packet must be a multiple of the values in the table.

#### Table 13 YUV420 10-bit Packet Data Size Constraints

| Odd Lines (1, 3, 5)<br>Luminance Only, Y |       | Even Lines (2, 4, 6) Luminance and Chrominance, UYVY |        |       |      |
|------------------------------------------|-------|------------------------------------------------------|--------|-------|------|
| Pixels                                   | Bytes | Bits                                                 | Pixels | Bytes | Bits |
| 4                                        | 5     | 40                                                   | 4      | 10    | 80   |

Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated in Figure 67.



1024

1025

Figure 66 YUV420 10-bit Transmission





 $\frac{1026}{1027}$ 

1028

Figure 67 YUV420 10-bit Pixel to Byte Packing Bitwise Illustration

The pixel spatial sampling options are the same as for the YUV420 8-bit data format.



1032

1033

1036

1037

1038

1039

1040

1041

Figure 68 YUV420 10-bit Frame Format

#### 11.2.4 YUV422 8-bit

YUV422 8-bit data transmission is performed by transmitting a UYVY sequence. This sequence is illustrated in Figure 69.

Table 14 specifies the packet size constraints for YUV422 8-bit packet. The length of each packet must be a multiple of the values in the table.

Table 14 YUV422 8-bit Packet Data Size Constraints

| Pixels | Bytes | Bits |
|--------|-------|------|
| 2      | 4     | 32   |

Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated in Figure 70.



Figure 69 YUV422 8-bit Transmission



Figure 70 YUV422 8-bit Pixel to Byte Packing Bitwise Illustration



10451046

1047

1048

Figure 71 YUV422 Co-sited Spatial Sampling

The pixel spatial alignment is the same as in CCIR-656 standard. The frame format for YUV422 is presented in Figure 72.



1051

1056

1050

Figure 72 YUV422 8-bit Frame Format

# 11.2.5 YUV422 10-bit

1052 YUV422 10-bit data transmission is performed by transmitting a UYVY sequence. This sequence is illustrated in Figure 73.

Table 15 specifies the packet size constraints for YUV422 10-bit packet. The length of each packet must be a multiple of the values in the table.

**Table 15 YUV422 10-bit Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|
| 2      | 5     | 40   |

Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated in Figure 74.



Figure 73 YUV422 10-bit Transmitted Bytes

#### Pixel Data:

1061

1062

1063

1064

1065

1066

1067

1068

1069



Figure 74 YUV422 10-bit Pixel to Byte Packing Bitwise Illustration

The pixel spatial alignment is the same as in the YUV422 8-bit data case. The frame format for YUV422 is presented in the Figure 75.



Figure 75 YUV422 10-bit Frame Format

# 11.3 RGB Image Data

Table 16 defines the data type codes for RGB data formats described in this section.

**Table 16 RGB Image Data Types** 

| Data Type | Description |
|-----------|-------------|
| 0x20      | RGB444      |

| Data Type | Description |
|-----------|-------------|
| 0x21      | RGB555      |
| 0x22      | RGB565      |
| 0x23      | RGB666      |
| 0x24      | RGB888      |
| 0x25      | Reserved    |
| 0x26      | Reserved    |
| 0x27      | Reserved    |

#### 1070 **11.3.1 RGB888**

1075

10781079

- RGB888 data transmission is performed by transmitting a BGR byte sequence. This sequence is illustrated in Figure 76. The RGB888 frame format is illustrated in Figure 78.
- Table 17 specifies the packet size constraints for RGB888 packets. The length of each packet must be a multiple of the values in the table.

**Table 17 RGB888 Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|
| 1      | 3     | 24   |

Bit order in transmission follows the general CSI-2 rule, LSB first. The pixel to byte mapping is illustrated in Figure 77.



Figure 76 RGB888 Transmission

Data

1080

1081

1082 1083

1084

1085

1086

1087

1088

1089

1090

1091

1092

#### 24-bit RGB pixel B0 B7 B0 B7 B7 B0 B1[7:0] G1[7:0] R1[7:0] Data Transmitted LS Bit First B0 **B7** B0 B7 B0 В7 B3 B4 B5 B6 B7 B0 B1 B2 G0 G1 G2 G3 G4 G5 G6 G7 R0 R1 R2 R3 R4 R5 R6 R7

Figure 77 RGB888 Transmission in CSI-2 Bus Bitwise Illustration



Figure 78 RGB888 Frame Format

11.3.2 RGB666

RGB666 data transmission is performed by transmitting B0..5 G0..5 R0..5 (18-bit) sequence. This sequence is illustrated in Figure 79. The frame format for RGB666 is presented in the Figure 81.

Table 18 specifies the packet size constraints for RGB666 packets. The length of each packet must be a multiple of the values in the table.

**Table 18 RGB666 Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|
| 4      | 9     | 72   |

Bit order in transmission follows the general CSI-2 rule, LSB first. In RGB666 case the length of one data word is 18-bits, not eight bits. The word wise flip is done for 18-bit BGR words i.e. instead of flipping each byte (8-bits), each 18-bits pixel value is flipped. This is illustrated in Figure 80.



Figure 79 RGB666 Transmission with 18-bit BGR-words



Figure 80 RGB666 Transmission on CSI-2 Bus Bitwise Illustration



1102

1103 1104

1095 1096

Figure 81 RGB666 Frame Format

#### 1099 11.3.3 RGB565

1100 RGB565 data transmission is performed by transmitting B0...B4, G0...G5, R0...R4 in a 16-bit sequence. This sequence is illustrated in Figure 82. The frame format for RGB565 is presented in the Figure 84. 1101

Table 19 specifies the packet size constraints for RGB565 packets. The length of each packet must be a multiple of the values in the table.

**Table 19 RGB565 Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|

1110 1111

11121113

| Pixels | Bytes | Bits |
|--------|-------|------|
| 1      | 2     | 16   |

Bit order in transmission follows the general CSI-2 rule, LSB first. In RGB565 case the length of one data word is 16-bits, not eight bits. The word wise flip is done for 16-bit BGR words i.e. instead of flipping each byte (8-bits), each two bytes (16-bits) are flipped. This is illustrated in Figure 83.



Figure 82 RGB565 Transmission with 16-bit BGR words



Figure 83 RGB565 Transmission on CSI-2 Bus Bitwise Illustration



Figure 84 RGB565 Frame format

# 1114 **11.3.4 RGB555**

1115 RGB555 data can be transmitted over a CSI-2 bus with some special arrangements. The RGB555 data 1116 should be made to look like RGB565 data. This can be accomplished by inserting padding bits to the LSBs of the green color component as illustrated in Figure 85.

1120

11221123

1124

11321133

1134

1135

Both the frame format and the package size constraints are the same as the RGB565 case.

Bit order in transmission follows the general CSI-2 rule, LSB first. In RGB555 case the length of one data word is 16-bits, not eight bits. The word wise flip is done for 16-bit BGR words i.e. instead of flipping each

byte (8-bits), each two bytes (16-bits) are flipped. This is illustrated in Figure 85.



Figure 85 RGB555 Transmission on CSI-2 Bus Bitwise Illustration

#### 11.3.5 RGB444

RGB444 data can be transmitted over a CSI-2 bus with some special arrangements. The RGB444 data should be made to look like RGB565 data. This can be accomplished by inserting padding bits to the LSBs of each color component as illustrated in Figure 86.

Both the frame format and the package size constraints are the same as the RGB565 case.

Bit order in transmission follows the general CSI-2 rule, LSB first. In RGB444 case the length of one data word is 16-bits, not eight bits. The word wise flip is done for 16-bit BGR words i.e. instead of flipping each byte (8-bits), each two bytes (16-bits) are flipped. This is illustrated in Figure 86.



Figure 86 RGB444 Transmission on CSI-2 Bus Bitwise Illustration

# 11.4 RAW Image Data

The RAW 6/7/8/10/12/14 modes are used for transmitting Raw image data from the image sensor.

The intent is that Raw image data is unprocessed image data for example Raw Bayer data or complementary color data, but RAW image data is not limited to these data types.

- It is possible to transmit e.g. light shielded pixels in addition to effective pixels. This leads to a situation 1138 where the line length is longer than sum of effective pixels per line. The line length, if not specified 1139 1140 otherwise, has to be a multiple of word (32 bits).

Table 20 defines the data type codes for RAW data formats described in this section. 1141

#### **Table 20 RAW Image Data Types**

| Data Type | Description |
|-----------|-------------|
| 0x28      | RAW6        |
| 0x29      | RAW7        |
| 0x2A      | RAW8        |
| 0x2B      | RAW10       |
| 0x2C      | RAW12       |
| 0x2D      | RAW14       |
|           |             |
| 0x2E      | Reserved    |
| 0x2F      | Reserved    |

#### 1143 11.4.1 RAW6

1148

1150 1151

1142

1144 The 6-bit Raw data transmission is performed by transmitting the pixel data over CSI-2 bus. Each line is 1145

separated by line start / end synchronization codes. This sequence is illustrated in Figure 87 (VGA case).

Table 21 specifies the packet size constraints for RAW6 packets. The length of each packet must be a 1146

multiple of the values in the table. 1147

# **Table 21 RAW6 Packet Data Size Constraints**

| Pixels | Bytes | Bits |
|--------|-------|------|
| 4      | 3     | 24   |

1149 Each 6-bit pixel is sent LSB first. This is an exception to general CSI-2 rule byte wise LSB first.

| Line<br>Start: | Packet<br>Header | P1[5:0]  | P2[5:0]   | P3[5:0]   | P4[5:0]  | P5[5:0]  | P6[5:0]     | P7[5:0]          |  |
|----------------|------------------|----------|-----------|-----------|----------|----------|-------------|------------------|--|
| Line<br>End:   | P634[5:0         | P635[5:0 | P636[5:0] | P637[5:0] | P638[5:0 | P639[5:0 | )] P640[5:0 | Packet<br>Footer |  |

Figure 87 RAW6 Transmission



Figure 88 RAW6 Data Transmission on CSI-2 Bus Bitwise Illustration



11541155

1157

1158

1159

1160

1161

Figure 89 RAW6 Frame Format

# 1156 **11.4.2 RAW7**

The 7-bit Raw data transmission is performed by transmitting the pixel data over CSI-2 bus. Each line is separated by line start / end synchronization codes. This sequence is illustrated in Figure 90 (VGA case). Table 22 specifies the packet size constraints for RAW7 packets. The length of each packet must be a multiple of the values in the table.

# **Table 22 RAW7 Packet Data Size Constraints**

| Pixels | Bytes | Bits |
|--------|-------|------|
| 8      | 7     | 56   |

Each 7-bit pixel is sent LSB first. This is an exception to general CSI-2 rule byte wise LSB first.

| Line<br>Start: | Packet<br>Header | P1[6:0]   | P2[6:0]   | P3[6:0]   | P4[6:0]   | P5[6:0]  | P6[6:0]    | P7[6:0]          |  |
|----------------|------------------|-----------|-----------|-----------|-----------|----------|------------|------------------|--|
| Line<br>End:   | P634[6:0         | P635[6:0] | P636[6:0] | P637[6:0] | P638[6:0] | P639[6:0 | ) P640[6:0 | Packet<br>Footer |  |

Figure 90 RAW7 Transmission

11671168

1170

1171

1172

1173



7-bit Pixel Values Transmitted LS Bit First

Figure 91 RAW7 Data Transmission on CSI-2 Bus Bitwise Illustration



7-bit Pixel Value

Figure 92 RAW7 Frame Format

# 11**69 11.4.3 RAW8**

The 8-bit Raw data transmission is performed by transmitting the pixel data over a CSI-2 bus. Table 23 specifies the packet size constraints for RAW8 packets. The length of each packet must be a multiple of the values in the table.

**Table 23 RAW8 Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|
| 1      | 1     | 8    |

- This sequence is illustrated in Figure 93 (VGA case).
- Bit order in transmission follows the general CSI-2 rule, LSB first.



Figure 93 RAW8 Transmission



Figure 94 RAW8 Data Transmission on CSI-2 Bus Bitwise Illustration



1181

1182

1184

1185

1186

1187

Figure 95 RAW8 Frame Format

#### 1183 **11.4.4 RAW10**

The transmission of 10-bit Raw data is accomplished by packing the 10-bit pixel data to look like 8-bit data format. Table 24 specifies the packet size constraints for RAW10 packets. The length of each packet must be a multiple of the values in the table.

**Table 24 RAW10 Packet Data Size Constraints** 

| Pixels | Bytes | Bits |
|--------|-------|------|
| 4      | 5     | 40   |

- This sequence is illustrated in Figure 96 (VGA case).
- Bit order in transmission follows the general CSI-2 rule, LSB first.



1190

Figure 96 RAW10 Transmission



Figure 97 RAW10 Data Transmission on CSI-2 Bus Bitwise Illustration



11951196

1198

1199

1200

1201

Figure 98 RAW10 Frame Format

#### 1197 **11.4.5 RAW12**

The transmission of 12-bit Raw data is also accomplished by packing the 12-bit pixel data to look like 8-bit data format. Table 25 specifies the packet size constraints for RAW12 packets. The length of each packet must be a multiple of the values in the table.

# **Table 25 RAW12 Packet Data Size Constraints**

| Pixels | Bytes | Bits |
|--------|-------|------|
| 2      | 3     | 24   |

- This sequence is illustrated in Figure 99 (VGA case).
- Bit order in transmission follows the general CSI-2 rule, LSB first.

12061207

12081209

1211

1212

1213

1214



1205 Figure 99 RAW12 Transmission



Figure 100 RAW12 Transmission on CSI-2 Bus Bitwise Illustration



Figure 101 RAW12 Frame Format

#### 1210 **11.4.6 RAW14**

The transmission of 14-bit Raw data is accomplished by packing the 14-bit pixel data in 8-bit slices. For every four pixels, seven bytes of data is generated. Table 26 specifies the packet size constraints for RAW14 packets. The length of each packet must be a multiple of the values in the table.

#### Table 26 RAW14 Packet Data Size Constraints

| Pixels | Bytes | Bits |
|--------|-------|------|
| 4      | 7     | 56   |

1215 The sequence is illustrated in Figure 102 (VGA case).

Bit order in transmission follows the general CSI-2 rule, LSB first.



Figure 102 RAW14 Transmission



1219 1220

1221

Figure 103 RAW14 Transmission on CSI-2 Bus Bitwise Illustration



12221223

1224

Figure 104 RAW14 Frame Format

#### 11.5 User Defined Data Formats

The User Defined Data Type values shall be used to transmit arbitrary byte-based data, such as JPEG and MPEG4 data, over the CSI-2 bus.

Bit order in transmission follows the general CSI-2 rule, LSB first.



Figure 105 User Defined 8-bit Data (128 Byte Packet)



1232

1233

1235

12281229

# Figure 106 User Defined 8-bit Data Transmission on CSI-2 Bus Bitwise Illustration

The packet data size in bits shall be divisible by 8, i.e. whole number of bytes shall be transmitted.

1234 For User Defined data:

- The frame is transmitted as a sequence of arbitrary sized packets.
- The packet size may vary from packet to packet.
- The packet spacing may vary between packets.



12381239

1240

1242

Figure 107 Transmission of User Defined 8-bit Data

- Four different User Defined data identifiers codes are available.
- Table 27 defines the User Defined data type codes.

# Table 27 User Defined 8-bit Data Types

| Data Type | Description                    |
|-----------|--------------------------------|
| 0x30      | User Defined 8-bit Data Type 1 |
| 0x31      | User Defined 8-bit Data Type 2 |

| Data Type | Description                    |
|-----------|--------------------------------|
| 0x32      | User Defined 8-bit Data Type 3 |
| 0x33      | User Defined 8-bit Data Type 4 |
| 0x34      | Reserved                       |
| 0x35      | Reserved                       |
| 0x36      | Reserved                       |
| 0x37      | Reserved                       |

# 12 Recommended Memory Storage

- 1245 This section is informative.
- The CSI-2 data protocol requires certain behavior from the receiver connected to the CSI transmitter. The
- following sections describe how different data formats should be stored inside the receiver. While
- 1248 informative, this section is provided to ease application software development by suggesting a common
- data storage format among different receivers.

# 12.1 General/Arbitrary Data Reception

- 1251 In the generic case and for arbitrary data the 1st byte of payload data transmitted maps the LS byte of the
- 1252 32-bit memory word and the 4th byte of payload data transmitted maps to the MS byte of the 32-bit
- memory word.

1244

1250

1255 1256

1257

1258

The below is the generic CSI-2 byte to 32-bit memory word mapping rule.



Figure 108 General/Arbitrary Data Reception

# 12.2 RGB888 Data Reception

The RGB888 data format byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 109 RGB888 Data Format Reception

# 12.3 RGB666 Data Reception

1260

12611262

1263

1264 1265



Figure 110 RGB666 Data Format Reception

# **12.4 RGB565 Data Reception**



Figure 111 RGB565 Data Format Reception

# **1271 12.5 RGB555 Data Reception**

1268 1269

1270

1272 1273

1274



Figure 112 RGB555 Data Format Reception

# **1275 12.6 RGB444 Data Reception**

The RGB444 data format byte to 32-bit memory word mapping has a special transform as shown in Figure 1277 113.

1280

1281 1282

1283

1284

1285 1286 1287

1288

1289



Figure 113 RGB444 Data Format Reception

# 12.7 YUV422 8-bit Data Reception

The YUV422 8-bit data format the byte to 32-bit memory word mapping does not follow the generic CSI-2 rule.

For YUV422 8-bit data format the 1st byte of payload data transmitted maps the MS byte of the 32-bit memory word and the 4th byte of payload data transmitted maps to the LS byte of the 32-bit memory word.



Figure 114 YUV422 8-bit Data Format Reception

# 12.8 YUV422 10-bit Data Reception

The YUV422 10-bit data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.

1293

1294

1295

1296

1297

1298



Figure 115 YUV422 10-bit Data Format Reception

# 12.9 YUV420 8-bit (Legacy) Data Reception

The YUV420 8-bit (legacy) data format the byte to 32-bit memory word mapping does not follow the generic CSI-2 rule.

For YUV422 8-bit (legacy) data format the 1st byte of payload data transmitted maps the MS byte of the 32-bit memory word and the 4th byte of payload data transmitted maps to the LS byte of the 32-bit memory word.



Figure 116 YUV420 8-bit Legacy Data Format Reception

# 12.10 YUV420 8-bit Data Reception

12991300

1301

1302

The YUV420 8-bit data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 117 YUV420 8-bit Data Format Reception

# 12.11 YUV420 10-bit Data Reception

13031304

1305

1306

The YUV420 10-bit data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 118 YUV420 10-bit Data Format Reception

# 1310 **12.12 RAW6 Data Reception**



Figure 119 RAW6 Data Format Reception

# 12.13 RAW7 Data Reception

1311 1312

1313

1314

1315 1316 1317

1318



Figure 120 RAW7 Data Format Reception

# 12.14 RAW8 Data Reception

The RAW8 data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 121 RAW8 Data Format Reception

#### 12.15 RAW10 Data Reception

1320 1321

1322

1323

1324

1325 1326

1327

1328

1329

The RAW10 data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 122 RAW10 Data Format Reception

# 12.16 RAW12 Data Reception

The RAW12 data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 123 RAW12 Data Format Reception

# 12.17 RAW14 Data Reception

1332

1333

1334 1335



Figure 124 RAW 14 Data Format Reception

# Annex A (informative) JPEG8 Data Format

#### A.1 Introduction

1337

1338

1339

13481349

- This Annex contains an informative example of the transmission of compressed image data format using the arbitrary Data Type values.
- 1342 JPEG8 has two non-standard extensions:
- Status information (mandatory)
- Embedded Image information e.g. a thumbnail image (optional)
- Any non-standard or additional data inside the baseline JPEG data structure has to be removed from JPEG8 data before it is compliant with e.g. standard JPEG image viewers in e.g. a personal computer.
- The JPEG8 data flow is illustrated in the Figure 125 and Figure 126.



Figure 125 JPEG8 Data Flow in the Encoder



1352

1359

1362

1363

1351

Figure 126 JPEG8 Data Flow in the Decoder

#### A.2 JPEG Data Definition

- The JPEG data generated in camera module is baseline JPEG DCT format defined in ISO/IEC 10918-1, with following additional definitions or modifications:
- sRGB color space shall be used. The JPEG is generated from YcbCr format after sRGB to YcbCr conversion.
- The JPEG metadata has to be EXIF compatible, i.e. metadata within application segments has to be placed in beginning of file, in the order illustrated in Figure 127.
  - A status line is added in the end of JPEG data as defined in section A.3.
- If needed, an embedded image is interlaced in order which is free of choice as defined in section A.4.
  - Prior to storing into a file, the CSI-2 JPEG data is processed by the data separation process described in section A.1.

| Start of Image (SOI)     |  |
|--------------------------|--|
| JFIF / EXIF Data         |  |
| Quantization Table (DQT) |  |
| Huffman Table (DHT)      |  |
| Frame Header (SOF)       |  |
| Scan Header              |  |
| Compressed Data          |  |
| End Of Image (EOI)       |  |

1366

1367

1368

Figure 127 EXIF Compatible Baseline JPEG DCT Format

# A.3 Image Status Information

- Information of at least the following items has to be stored in the end of the JPEG sequence as illustrated in Figure 128:
- Image exposure time
- Analog & digital gains used
- White balancing gains for each color component
- Camera version number
- Camera register settings
- Image resolution and possible thumbnail resolution
- The camera register settings may include a subset of camera's registers. The essential information needed for JPEG8 image is the information needed for converting the image back to linear space. This is necessary e.g. for printing service. An example of register settings is following:
- Sample frequency
- 1379 Exposure
- Analog and digital gain
- 1381 Gamma
- Color gamut conversion matrix
- 1383 Contrast
- Brightness
- 1385 Pre-gain
- The status information content has to be defined in the product specification of each camera module containing the JPEG8 feature. The format and content is manufacturer specific.

- The image status data should be arranged so that each byte is split into two 4-bit nibbles and "1010" padding sequence is added to MSB, as presented in the Table 28. This ensures that no JPEG escape
- sequences (0xFF 0x00) are present in the status data.

The SOSI and EOSI markers are defined in 14.5.

#### **Table 28 Status Data Padding**

| Data Word        | After Padding             |
|------------------|---------------------------|
| D7D6D5D4D3D2D1D0 | 1010D7D6D5D4 1010D3D2D1D0 |

| Start of Image (SOI)               |  |
|------------------------------------|--|
| JFIF / EXIF Data                   |  |
| Quantization Table (DQT)           |  |
| Huffman Table (DHT)                |  |
| Frame Header (SOF)                 |  |
| Scan Header                        |  |
| Compressed Data                    |  |
| End Of Image (EOI)                 |  |
| Start of Status Information (SOSI) |  |
| Image Status Information           |  |
| End of Status Information (EOSI)   |  |
|                                    |  |

13931394

1395

1392

Figure 128 Status Information Field in the End of Baseline JPEG Frame

# A.4 Embedded Images

- An image may be embedded inside the JPEG data, if needed. The embedded image feature is not compulsory for each camera module containing the JPEG8 feature. An example of embedded data is a 24-
- bit RGB thumbnail image.
- The philosophy of embedded / interleaved thumbnail additions is to minimize the needed frame memory.
- 1400 The EI (Embedded Image) data can be included in any part of the compressed image data segment and in as
- many pieces as needed. See Figure 129.
- Embedded Image data is separated from compressed data by SOEI (Start Of Embedded Image) and EOEI
- 1403 (End Of Embedded Image) non-standard markers, which are defined in 14.5. The amount of fields
- separated by SOEI and EOEI is not limited.
- The pixel to byte packing for image data within an EI data field should be as specified for the equivalent
- 1406 CSI-2 data format. However there is an additional restriction; the embedded image data must not generate
- any false JPEG marker sequences (0xFFXX).

1412

1413

1419

1420

1421

1427

- The suggested method of preventing false JPEG marker codes from occurring within the embedded image data it to limit the data range for the pixel values. For example
  - For RGB888 data the suggested way to solve the false synchronization code issue is to constrain the numerical range of R, G and B values from 1 to 254.
  - For RGB565 data the suggested way to solve the false synchronization code issue is to constrain the numerical range of G component from 1-62 and R component from 1-30.
- Each EI data field is separated by the SOEI / EOEI markers, has to contain an equal amount bytes and a complete number of pixels. An EI data field may contain multiple lines or a full frame of image data.
- The embedded image data is decoded and removed apart from the JPEG compressed data prior to writing the JPEG into a file. In the process, EI data fields are appended one after each other, in order of occurrence in the received JPEG data.



Figure 129 Example of TN Image Embedding Inside the Compressed JPEG Data Block

# A.5 JPEG8 Non-standard Markers

- JPEG8 uses the reserved JPEG data markers for special purposes, marking the additional segments inside the data file. These segments are not part of the JPEG, JFIF [0], EXIF [0] or any other specifications:
- instead their use is specified in this document in sections 14.3 and 14.4.
- The use of the non-standard markers is always internal to a product containing the JPEG8 camera module, and these markers are always removed from the JPEG data before storing it into a file

Table 29 JPEG8 Additional Marker Codes Listing

| Non-standard Marker Symbol | Marker Data Code |
|----------------------------|------------------|
| SOSI                       | 0xFF 0xBC        |

| Non-standard Marker Symbol | Marker Data Code |
|----------------------------|------------------|
| EOSI                       | 0xFF 0xBD        |
| SOEI                       | 0xFF 0xBE        |
| EOEI                       | 0xFF 0xBF        |

## A.6 JPEG8 Data Reception

1428

1430 1431

1432

The compressed data format the byte to 32-bit memory word mapping follows the generic CSI-2 rule.



Figure 130 JPEG8 Data Format Reception

# Annex B (informative) CSI-2 Implementation Example

#### B.1 Overview

The CSI-2 implementation example assumes that the interface comprises of D-PHY unidirectional Clock and Data, with forward escape mode functionality. The scope in this implementation example refers only to the unidirectional data link without any references to the CCI interface, as it can be seen in Figure 131. This implementation example varies from the informative PPI example in *MIPI Alliance Standard for D-PHY* [2].



1441 1442

1443

1444

1452

1433

1434

1435

Figure 131 Implementation example block diagram and coverage

- For this implementation example a layered structure is described with the following parts:
- D-PHY implementation details
- Multi lane merger details
- Protocol layer details
- This implementation example refers to a RAW8 data type only; hence no packing/unpacking or byte clock/pixel clock timing will be referenced as for this type of implementation they are not needed.
- No error recovery mechanism or error processing details will be presented, as the intent of the document is to present an implementation from the data flow perspective.

### **B.2 CSI-2 Transmitter Detailed Block Diagram**

Using the layered structure described in the overview the CSI-2 transmitter could have the block diagram in Figure 132.

1457

1458

1459



1456 Figure 132 CSI-2 Transmitter Block Diagram

## **B.3 CSI-2 Receiver Detailed Block Diagram**

Using the layered structure described in the overview, the CSI-2 receiver could have the block diagram in Figure 133.



1462

1463

Figure 133 CSI-2 Receiver Block Diagram

## B.4 Details on the D-PHY implementation

The PHY level of implementation has the top level structure as seen in Figure 134.



1467

1470

Figure 134 D-PHY Level Block Diagram

- 1468 The components can be categorized as:
- CSI-2 Transmitter side:
  - Clock lane (Transmitter)
- Data1 lane (Transmitter)
- Data2 lane (Transmitter)
- CSI-2 Receiver side:
  - Clock lane (Receiver)
- Data1 lane (Receiver)
- Data2 lane (Receiver)

#### **B.4.1 CSI-2 Clock Lane Transmitter**

1478 The suggested implementation can be seen in Figure 135.



1479

1477

1480

1484

1486

1487

1488

1489

1490

1491 1492

1493

1494 1495

1496

1497

1498

1499

Figure 135 CSI-2 Clock Lane Transmitter

- The modular D-PHY components used to build a CSI-2 clock lane transmitter are:
- **LP-TX** for the Low-power function
- **HS-TX** for the High-speed function
  - **CIL-MCNN** for the Lane control and interface logic
- 1485 The PPI interface signals to the CSI-2 clock lane transmitter are:
  - TxDDRClkHS-O (Input): High-Speed Transmit DDR Clock (Quadrature).
  - **TxRequestHS** (Input): High-Speed Transmit Request. This active high signal causes the lane module to begin transmitting a high-speed clock.
  - **TxReadyHS** (Output): High-Speed Transmit Ready. This active high signal indicates that the clock lane is transmitting HS clock.
  - **Shutdown** (Input): Shutdown Lane Module. This active high signal forces the lane module into "shutdown", disabling all activity. All line drivers, including terminators, are turned off when Shutdown is asserted. When Shutdown is high, all other PPI inputs are ignored and all PPI outputs are driven to the default inactive state. Shutdown is a level sensitive signal and does not depend on any clock.
  - TxUlpmClk (Input): Transmit Ultra Low-Power mode on Clock Lane This active high signal is asserted to cause a Clock Lane module to enter the Ultra Low-Power mode. The lane module remains in this mode until TxUlpmClk is de-asserted.

#### B.4.2 CSI-2 Clock Lane Receiver

1500 The suggested implementation can be seen in Figure 136.



1505

1506

1508

1509

1510

15111512

15131514

1515 1516

15171518

1519 1520

1521

1522

Figure 136 CSI-2 Clock Lane Receiver

1503 The modular D-PHY components used to build a CSI-2 clock lane receiver are:

- **LP-RX** for the Low-power function
  - **HS-RX** for the High-speed function
    - **CIL-SCNN** for the Lane control and interface logic
- 1507 The PPI interface signals to the CSI-2 clock lane receiver are:
  - **RxDDRClkHS** (Output): High-Speed Receive DDR Clock used to sample the data in all data lanes.
  - **RxClkActiveHS** (Output): High-Speed Reception Active. This active high signal indicates that the clock lane is receiving valid clock. This signal is asynchronous.
  - **Stopstate** (Output): Lane is in Stop state. This active high signal indicates that the lane module is currently in Stop state. This signal is asynchronous.
  - **Shutdown** (Input): Shutdown Lane Module. This active high signal forces the lane module into "shutdown", disabling all activity. All line drivers, including terminators, are turned off when Shutdown is asserted. When Shutdown is high, all PPI outputs are driven to the default inactive state. Shutdown is a level sensitive signal and does not depend on any clock.
  - **RxUlpmEsc** (Output): Escape Ultra Low Power (Receive) mode. This active high signal is asserted to indicate that the lane module has entered the ultra low power mode. The lane module remains in this mode with RxUlpmEsc asserted until a Stop state is detected on the lane interconnect.

#### B.4.3 CSI-2 Data Lane Transmitter

1523 The suggested implementation can be seen in Figure 137.



Figure 137 CSI-2 Data Lane Transmitter

- 1527 The modular D-PHY components used to build a CSI-2 data lane transmitter are:
- **LP-TX** for the Low-power function
- **HS-TX** for the High-speed function
  - **CIL-MUYN** for the Lane control and interface logic
- 1531 The PPI interface signals to the CSI-2 data lane transmitter are:
  - TxDDRClkHS-I (Input): High-Speed Transmit DDR Clock (in-phase).
    - TxByteClkHS (Input): High-Speed Transmit Byte Clock. This is used to synchronize PPI signals in the high-speed transmit clock domain. It is recommended that both transmitting data lane modules share one TxByteClkHS signal. The frequency of TxByteClkHS must be exactly 1/8 the high-speed bit rate.
    - TxDataHS[7:0] (Input): High-Speed Transmit Data. Eight bit high-speed data to be transmitted. The signal connected to TxDataHS[0] is transmitted first. Data is registered on rising edges of TxByteClkHS.
    - TxRequestHS (Input): High-Speed Transmit Request. A low-to-high transition on TxRequestHS causes the lane module to initiate a Start-of-Transmission sequence. A high-to-low transition on TxRequest causes the lane module to initiate an End-of-Transmission sequence. This active high signal also indicates that the protocol is driving valid data on TxByteDataHS to be transmitted. The lane module accepts the data when both TxRequestHS and TxReadyHS are active on the same rising TxByteClkHS clock edge. The protocol always provides valid transmit data when TxRequestHS is active. Once asserted, TxRequestHS should remain high until the all the data has been accepted.
    - TxReadyHS (Output): High-Speed Transmit Ready. This active high signal indicates that TxDataHS is accepted by the lane module to be serially transmitted. TxReadyHS is valid on rising edges of TxByteClkHS. Valid data has to be provided for the whole duration of active TxReadyHS.

1558

1559

1560

1561

1562 1563

1564

1565

1566

1567

15691570

1573

- **Shutdown** (Input): Shutdown Lane Module. This active high signal forces the lane module into "shutdown", disabling all activity. All line drivers, including terminators, are turned off when Shutdown is asserted. When Shutdown is high, all other PPI inputs are ignored and all PPI outputs are driven to the default inactive state. Shutdown is a level sensitive signal and does not depend on any clock.
  - **TxUlpmEsc** (Input): Escape mode Transmit Ultra Low Power. This active high signal is asserted with TxRequestEsc to cause the lane module to enter the ultra low power mode. The lane module remains in this mode until TxRequestEsc is de-asserted.
  - TxRequestEsc (Input): This active high signal, asserted together with TxUlpmEsc is used to
    request entry into escape mode. Once in escape mode, the lane stays in escape mode until
    TxRequestEsc is de-asserted. TxRequestEsc is only asserted by the protocol while TxRequestHS
    is low.
  - **TxClkEsc** (Input): Escape mode Transmit Clock. This clock is directly used to generate escape sequences. The period of this clock determines the symbol time for low power signals. It is therefore constrained by the normative part of the *MIPI Alliance Standard for D-PHY* [2].

#### B.4.4 CSI-2 Data Lane Receiver

The suggested implementation can be seen in Figure 138.



Figure 138 CSI-2 Data Lane Receiver

- 1571 The modular D-PHY components used to build a CSI-2 data lane receiver are:
- LP-RX for the Low-power function
  - HS-RX for the High-speed function

- CIL-SUYN for the Lane control and interface logic
- 1575 The PPI interface signals to the CSI-2 data lane receiver are:
- **RxDDRClkHS** (Input): High-Speed Receive DDR Clock used to sample the date in all data lanes.

  This signal is supplied by the CSI-2 clock lane receiver.
  - RxByteClkHS (Output): High-Speed Receive Byte Clock. This signal is used to synchronize signals in the high-speed receive clock domain. The RxByteClkHS is generated by dividing the received RxDDRClkHS.
  - RXDataHS[7:0] (Output): High-Speed Receive Data. Eight bit high-speed data received by the lane module. The signal connected to RxDataHS[0] was received first. Data is transferred on rising edges of RxByteClkHS.
  - RxValidHS (Output): High-Speed Receive Data Valid. This active high signal indicates that the lane module is driving valid data to the protocol on the RxDataHS output. There is no "RxReadyHS" signal, and the protocol is expected to capture RxDataHS on every rising edge of RxByteClkHS where RxValidHS is asserted. There is no provision for the protocol to slow down ("throttle") the receive data.
  - **RxActiveHS** (Output): High-Speed Reception Active. This active high signal indicates that the lane module is actively receiving a high-speed transmission from the lane interconnect.
    - **RxSyncHS** (Output): Receiver Synchronization Observed. This active high signal indicates that the lane module has seen an appropriate synchronization event. In a typical high-speed transmission, RxSyncHS is high for one cycle of RxByteClkHS at the beginning of a high-speed transmission when RxActiveHS is first asserted. This signal missing is signaled using ErrSotSyncHS.
  - RxUlpmEsc (Output): Escape Ultra Low Power (Receive) mode. This active high signal is asserted to indicate that the lane module has entered the ultra low power mode. The lane module remains in this mode with RxUlpmEsc asserted until a Stop state is detected on the lane interconnect.
  - **Stopstate** (Output): Lane is in Stop state. This active high signal indicates that the lane module is currently in Stop state. This signal is asynchronous.
  - **Shutdown** (Input): Shutdown Lane Module. This active high signal forces the lane module into "shutdown", disabling all activity. All line drivers including terminators, are turned off when Shutdown is asserted. When Shutdown is high, all PPI outputs are driven to the default inactive state. Shutdown is a level sensitive signal and does not depend on any clock.
  - **ErrSotHS** (Output): Start-of-Transmission (SoT) Error. If the high-speed SoT leader sequence is corrupted, but in such a way that proper synchronization can still be achieved, this error signal is asserted for one cycle of RxByteClkHS. This is considered to be a "soft error" in the leader sequence and confidence in the payload data is reduced.
  - **ErrSotSyncHS** (Output): Start-of-Transmission Synchronization Error. If the high-speed SoT leader sequence is corrupted in a way that proper synchronization cannot be expected, this error is asserted for one cycle of RxByteClkHS.
- **ErrControl** (Output): Control Error. This signal is asserted when an incorrect line state sequence is detected.
- **ErrEsc** (Output): Escape Entry Error. If an unrecognized escape entry command is received, this signal is asserted and remains high until the next change in line state. The only escape entry command supported by the receiver is the ULPM mode.

| 1618                                                 | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1619                                                 | CSI-2 Recommended Receiver Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 1620                                                 | Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 1621                                                 | C.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 1622<br>1623<br>1624<br>1625<br>1626<br>1627<br>1628 | This section proposes one approach to handling error conditions at the receiving side of a CSI-2 Link. Although the section is informative and therefore does not affect compliance for CSI-2, the approach is offered by the MIPI Camera Working Group as a recommended approach. The CSI-2 receiver assumes the case of a CSI-2 Link comprised of unidirectional Lanes for D-PHY Clock and Data Lanes with Escape Mode functionality on the Data Lanes and a continuously running clock. This Annex does not discuss other cases, including those that differ widely in implementation, where the implementer should consider other potential error situations. |  |  |
| 1629<br>1630<br>1631                                 | Because of the layered structure of a compliant CSI-2 receiver implementation, the error behavior is described in a similar way with several "levels" where errors could occur, each requiring some implementation at the appropriate functional layer of the design:                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 1632<br>1633                                         | • <i>D-PHY Level errors</i> Refers to any PHY related transmission error and is unrelated to the transmission's contents:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 1634                                                 | • Start of Transmission (SoT) errors, which can be:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 1635<br>1636                                         | <ul> <li>Recoverable, if the PHY successfully identifies the Sync code but an error was<br/>detected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 1637<br>1638                                         | <ul> <li>Unrecoverable, if the PHY does not successfully identify the sync code but does detect<br/>a HS transmission.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1639<br>1640                                         | • <i>Control Error</i> , which signals that the PHY has detected a control sequence that should not be present in this implementation of the Link.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 1641<br>1642                                         | <ul> <li>Packet Level errors         This type of error refers strictly to data integrity of the received Packet Header and payload data:     </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| 1643                                                 | • Packet Header errors, signaled through the ECC code, that result in:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1644                                                 | <ul> <li>A single bit-error, which can be detected and corrected by the ECC code</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 1645<br>1646                                         | <ul> <li>Two bit-errors in the header, which can be detected but not corrected by the ECC code,<br/>resulting in a corrupt header</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 1647                                                 | • Packet payload errors, signaled through the CRC code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1648<br>1649<br>1650                                 | <ul> <li>Protocol Decoding Level errors         This type of error refers to errors present in the decoded Packet Header or errors resulting from an incomplete sequence of events:     </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 1651<br>1652                                         | • Frame Sync Error, caused when a FS could not be successfully paired with a FE on a given virtual channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 1653<br>1654                                         | • <i>Unrecognized ID</i> , caused by the presence of an unimplemented or unrecognized ID in the header                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1655<br>1656<br>1657                                 | The proposed methodology for handling errors is signal based, since it offers an easy path to a viable CSI-2 implementation that handles all three error levels. Even so, error handling at the Protocol Decoding Level should implement sequential behavior using a state machine for proper operation.                                                                                                                                                                                                                                                                                                                                                          |  |  |

#### C.2 D-PHY Level Error

1658

1665

1666

1667

1668

1669

1670

16711672

1673

1674 1675

1677

1678

1679

1680

1681

1682

1683

1684

1685

1686

1689

- The recommended behavior for handling this error level covers only those errors generated by the Data Lane(s), since an implementation can assume that the Clock Lane is running reliably as provided by the expected BER of the Link, as discussed in *MIPI Alliance Standard for D-PHY* [2]. Note that this error handling behavior assumes unidirectional Data Lanes without escape mode functionality. Considering this, and using the signal names and descriptions from the *MIPI Alliance Standard for D-PHY* [2], PPI Annex, signal errors at the PHY-Protocol Interface (PPI) level consist of the following:
  - ErrSotHS: Start-of-Transmission (SoT) Error. If the high-speed SoT leader sequence is corrupted, but in such a way that proper synchronization can still be achieved, this error signal is asserted for one cycle of RxByteClkHS. This is considered to be a "soft error" in the leader sequence and confidence in the payload data is reduced.
  - **ErrSotSyncHS:** Start-of-Transmission Synchronization Error. If the high-speed SoT leader sequence is corrupted in a way that proper synchronization cannot be expected, this error signal is asserted for one cycle of RxByteClkHS.
  - **ErrControl:** Control Error. This signal is asserted when an incorrect line state sequence is detected. For example, if a Turn-around request or Escape Mode request is immediately followed by a Stop state instead of the required Bridge state, this signal is asserted and remains high until the next change in line state.
- 1676 The recommended receiver error behavior for this level is:
  - **ErrSotHS** should be passed to the Application Layer. Even though the error was detected and corrected and the Sync mechanism was unaffected, confidence in the data integrity is reduced and the application should be informed. This signal should be referenced to the corresponding data packet.
  - **ErrSotSyncHS** should be passed to the Protocol Decoding Level, since this is an unrecoverable error. An unrecoverable type of error should also be signaled to the Application Layer, since the whole transmission until the first D-PHY Stop state should be ignored if this type of error occurs.
  - **ErrControl** should be passed to the Application Layer, since this type of error doesn't normally occur if the interface is configured to be unidirectional. Even so, the application needs to be aware of the error and configure the interface accordingly through other, implementation specific means.
- Also, it is recommended that the PPI StopState signal for each implemented Lane should be propagated to the Application Layer during configuration or initialization to indicate the Lane is ready.

#### C.3 Packet Level Error

- The recommended behavior for this error level covers only errors recognized by decoding the Packet Header's ECC byte and computing the CRC of the data payload.
- Decoding and applying the ECC byte of the Packet Header should signal the following errors:
- **ErrEccDouble:** Asserted when an ECC syndrome was computed and two bit-errors are detected in the received Packet Header.
- **ErrEccCorrected:** Asserted when an ECC syndrome was computed and a single bit-error in the Packet Header was detected and corrected.
- ErrEccNoError: Asserted when an ECC syndrome was computed and the result is zero indicating a Packet Header that is considered to be without errors or has more than two bit-errors. CSI-2's ECC mechanism cannot detect this type of error.

1706

1707

1708 1709

1710

1711

1712

1713 1714

1715

1718

1719

1720

1727

1728

1729

1730

1732

1733

1734 1735

1736

1737

1738

1739 1740

1741

- 1700 Also, computing the CRC code over the whole payload of the received packet could generate the following 1701 errors:
- 1702 **ErrCrc:** Asserted when the computed CRC code is different than the received CRC code.
- ErrID: Asserted when a Packet Header is decoded with an unrecognized or unimplemented data 1704
- 1705 The recommended receiver error behavior for this level is:
  - **ErrEccDouble** should be passed to the Application Layer since assertion of this signal proves that the Packet Header information is corrupt, and therefore the WC is not usable, and thus the packet end cannot be estimated. Commonly, this type of error will be accompanied with an ErrCrc. This type of error should also be passed to the Protocol Decoding Level, since the whole transmission until D-PHY Stop state should be ignored.
    - **ErrEccCorrected** should be passed to the Application Layer since the application should be informed that an error had occurred but was corrected, so the received Packet Header was unaffected, although the confidence in the data integrity is reduced.
  - **ErrEccNoError** can be passed to the Protocol Decoding Level to signal the validity of the current Packet Header.
- ErrCrc should be passed to the Protocol Decoding Level to indicate that the packet's payload data 1716 1717 might be corrupt.
  - **ErrID** should be passed to the Application Layer to indicate that the data packet is unidentified and cannot be unpacked by the receiver. This signal should be asserted after the ID has been identified and de-asserted on the first Frame End (FE) on same virtual channel.

#### C.4 Protocol Decoding Level Error 1721

- 1722 The recommended behavior for this error level covers errors caused by decoding the Packet Header information and detecting a sequence that is not allowed by the CSI-2 protocol or a sequence of detected 1723 errors by the previous layers. CSI-2 implementers will commonly choose to implement this level of error 1724 handling using a state machine that should be paired with the corresponding virtual channel. The state 1725 1726 machine should generate at least the following error signals:
  - ErrFrameSync: Asserted when a Frame End (FE) is not paired with a Frame Start (FS) on the same virtual channel. A ErrSotSyncHS should also generate this error signal.
  - **ErrFrameData:** Asserted after a FE when the data payload received between FS and FE contains errors
- 1731 The recommended receiver error behavior for this level is:
  - **ErrFrameSync** should be passed to the Application Layer with the corresponding virtual channel, since the frame could not be successfully identified. Several error cases on the same virtual channel can be identified for this type of error.
    - If a FS is followed by a second FS on the same virtual channel, the frame corresponding to the first FS is considered in error.
    - If a Packet Level ErrEccDouble was signaled from the Protocol Layer, the whole transmission until the first D-PHY Stop-state should be ignored since it contains no information that can be safely decoded and cannot be qualified with a data valid signal.
    - If a FE is followed by a second FE on the same virtual channel, the frame corresponding to the second FE is considered in error.

1746

| 1742 | • | If an ErrSotSyncHS was signaled from the PHY Layer, the whole transmission until the first |
|------|---|--------------------------------------------------------------------------------------------|
| 1743 |   | D-PHY Stop state should be ignored since it contains no information that can be safely     |
| 1744 |   | decoded and cannot be qualified with a data valid signal.                                  |

• **ErrFrameData**: should be passed to the Application Layer to indicate that the frame contains data errors. This signal should be asserted on any ErrCrc and de-asserted on the first FE.

## Annex D (informative) CSI-2 Sleep Mode

#### 1749 **D.1 Overview**

1747

1748

- Since a camera in a mobile terminal spends most of its time in an inactive state, implementers need a way
- to put the CSI-2 Link into a low power mode that approaches, or may be as low as, the leakage level. This
- section proposes one approach for putting a CSI-2 Link in a "Sleep Mode" (SLM). Although the section is
- informative and therefore does not affect compliance for CSI-2, the approach is offered by the MIPI
- 1754 Camera Working Group as a recommended approach.
- 1755 This approach relies on an aspect of a D-PHY transmitter's behavior that permits regulators to be disabled
- safely when LP-00 (Space state) is on the Link. Accordingly, this will be the output state for a CSI-2
- camera transmitter in SLM.
- 1758 SLM can be thought of as a three-phase process:
- 1759 1. SLM Command Phase. The 'ENTER SLM' command is issued to the TX side only, or to both sides of the Link.
- 2. SLM Entry Phase. The CSI-2 Link has entered, or is entering, the SLM in a controlled or synchronized manner. This phase is also part of the power-down process.
- 3. SLM Exit Phase. The CSI-2 Link has exited the SLM and the interface/device is operational. This phase is also part of the power-up process.
- In general, when in SLM, both sides of the interface will be in ULPM, as defined in *MIPI Alliance* Standard for D-PHY [2].

#### 1767 D.2 SLM Command Phase

- For the first phase, initiation of SLM occurs by a mechanism outside the scope of CSI-2. Of the many mechanisms available, two examples would be:
- 1. An External SLEEP signal input to the CSI-2 transmitter and optionally also to the CSI-2 Receiver. When at logic 0, the CSI-2 Transmitter and, if connected, the CSI Receiver, will enter Sleep mode. When at logic 1, normal operation will take place.
- 2. A CCI control command, provided on the I2C control Link, is used to trigger ULPM.

## 1774 **D.3 SLM Entry Phase**

- 1775 For the second phase, consider one option:
- 1776 Only the TX side enters SLM and propagates the ULPM mode to the RX side by sending a D-PHY
- 1777 'ULPM' command on Clock Lane and on Data Lane(s). In the following picture only Data Lane 'ULPM'
- 1778 command is used as an example.



1781

1782

1783

1784

1785

1786

1787

1788

1789

1790

1791

1792

1793

Figure 139 SLM Synchronization

### D.4 SLM Exit Phase

For the third phase, three options are presented and assume the camera peripheral is in ULPM or Sleep mode at power-up:

- 1. Use a SLEEP signal to power-up both sides of the interface.
- 2. Detect any CCI activity on the I2C control Link, which have been in 00 state ({SCL, SDA}), after receiving the I2C instruction to enter ULPM command as per Section D.2, option 2. Any change on those lines should wake up the camera peripheral. The drawback of this method is that I2C lines are used exclusively for control of the camera.
- 3. Detect a wake-up sequence on the I2C lines. This sequence, which may vary by implementation, shall not disturb the I2C interface so that it can be used by other devices. One example sequence is: StopI2C-StartI2C-StopI2C. See section 6 for details on CCI.

A handshake using the 'ULPM' mechanism in the as described in MIPI Alliance Standard for D-PHY [2] should be used for powering up the interface.