2:1 MIPI CSI-2 Image Sensor Aggregator Bridge Demo

User Guide

UG117 Version 1.0

May 2016
Contents
Acronyms in This Document ..................................................................................................................3
1. Introduction ........................................................................................................................................4
2. Functional Description ......................................................................................................................5
3. Equipment Requirements ...................................................................................................................6
4. Hardware Setup ..................................................................................................................................8
5. Device Configuration ........................................................................................................................10
   5.1. Programming Steps ....................................................................................................................10
6. Software Setup ...................................................................................................................................13
7. Ordering Information ........................................................................................................................14
Supplemental Information .......................................................................................................................15
Technical Support Assistance ................................................................................................................15
Appendix A. Debug ................................................................................................................................16
Appendix B. LIF-MD6000 Master Link Board Schematics ....................................................................17
Appendix C. Raspberry Pi Camera Link Board .......................................................................................25
Appendix D. Raspberry Pi AP Link Board ..............................................................................................26
Revision History .....................................................................................................................................27

Figures
Figure 1.1. 2:1 MIPI CSI-2 Aggregator Bridge System Diagram ...............................................................4
Figure 3.1. CrossLink LIF-MD6000 Master Link Board ..........................................................................6
Figure 3.2. Raspberry Pi AP Link Board and Raspberry Pi Camera Link Board ........................................7
Figure 4.1. Rework of Raspberry Pi cameras ........................................................................................8
Figure 4.2. Assembled Demo System ....................................................................................................9
Figure 5.1. Diamond Programmer – Getting Started ............................................................................10
Figure 5.2. Diamond Programmer ..........................................................................................................11
Figure 5.3. LIF-MD6000 Device Properties ..........................................................................................11
Figure 6.1. Full Setup showing the Final Output of Demo .......................................................................13
Figure B.1. Block Diagram ....................................................................................................................17
Figure B.2. FTDI Interface ....................................................................................................................18
Figure B.3. Power Regulator IF .............................................................................................................19
Figure B.4. MIPI Block – MIPI TX .........................................................................................................20
Figure B.5. Bank 1, 2 – LVDS RX .........................................................................................................21
Figure B.6. Bank0 – Flash IF ..................................................................................................................22
Figure B.7. I2C Expander ......................................................................................................................23
Figure B.8. Layout Guidelines ................................................................................................................24
Figure C.1. Raspberry Pi Camera Link Board .......................................................................................25
Figure D.1. Raspberry Pi AP Link Board ..............................................................................................26
# Acronyms in This Document

A list of acronyms used in this document.

<table>
<thead>
<tr>
<th>Acronym</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>AP</td>
<td>Application Processor</td>
</tr>
<tr>
<td>CSI</td>
<td>Camera Serial Interface</td>
</tr>
<tr>
<td>DSI</td>
<td>Display Serial Interface</td>
</tr>
<tr>
<td>FTDI</td>
<td>Future Technology Devices Interna</td>
</tr>
<tr>
<td>HDMI</td>
<td>High Definition Multimedia Interface</td>
</tr>
<tr>
<td>I\textsuperscript{2}C</td>
<td>Inter-Integrated Circuit</td>
</tr>
<tr>
<td>LVDS</td>
<td>Low-Voltage Differential Signaling</td>
</tr>
<tr>
<td>SPI</td>
<td>Serial Peripheral Interface</td>
</tr>
<tr>
<td>USB</td>
<td>Universal Serial Bus</td>
</tr>
</tbody>
</table>
1. Introduction

This document describes the design and setup procedure for the Lattice Semiconductor 2:1 MIPI® CSI-2 Image Sensor Aggregator Bridge development kit to demonstrate the capabilities of the CrossLink™ FPGA in video applications.

CrossLink 2:1 MIPI CSI-2 aggregator bridge development kit is a set of boards that receives MIPI CSI-2 serial data from two image sensors, combines the image from two cameras and then transmits the combined image data to Application Processor (AP) in MIPI CSI-2 format.

The CrossLink device can receive MIPI DSI/CSI-2 data at the rate of 1.2 Gb/s/lane and transmit it at a rate of 1.5 Gb/s/lane. The device comes with full validated Soft IPs with flexible controlling options. 2:1 MIPI CSI-2 Aggregator Bridge Soft IP is used in this demonstration.

The development kit consists of three boards:
- CrossLink Master Link board featuring a Lattice LIF-MD6000 device.
- Raspberry Pi Camera Link board to connect the Raspberry Pi camera.
- Raspberry Pi AP Link board to connect to Raspberry Pi Model B+ board.

Other boards required for the demo apart from the development kit:
- Two Raspberry Pi Cameras.
- Raspberry Pi Model B+ board to process the MIPI CSI-2 data and display on an HDMI monitor.

Figure 1.1 shows the 2:1 MIPI CSI-2 aggregator bridge system diagram.

![Figure 1.1. 2:1 MIPI CSI-2 Aggregator Bridge System Diagram](image-url)
2. Functional Description

Figure 2.1 shows the 2:1 MIPI CSI-2 Aggregator IP internal block diagram. The 2:1 MIPI CSI-2 Aggregator IP receives the serial, source-synchronous MIPI data from two MIPI CSI-2 cameras, deserializes the serial data into bytes and extracts the control signal from MIPI data packets.

The IP then uses these control signals for transmitting the deserialized data to MIPI CSI-2 Transmitter block. It takes the data from both the cameras and then combines the parallel data from two data streams and then sends to MIPI CSI-2 Transmitter block. The MIPI CSI-2 Transmitter block includes Hard D-PHY block that serializes the data and sends it out in MIPI format.

A single I2C master to dual I2C Slave Bridge is used to configure the two Raspberry Pi cameras. The Raspberry Pi Model B+ board is configured as I2C master and the two Raspberry Pi cameras as slaves. As the Raspberry Pi AP source code is closed, we have implemented special functionalities to configure the cameras, so that the demo works in such environment. As part of this special functionality, every I2C command from Raspberry Pi Model B+ board goes to both cameras.

The I2C Initialization block is implemented in MachXO3L device. In the MachXO3L design, the write commands are sent to both cameras simultaneously whereas, the read commands are answered by only one of these cameras. The I2C initialization is implemented in the bridge in order to change the register settings in the Raspberry Pi camera thus enabling continuous clock mode.
3. Equipment Requirements

The following equipment’s are required for MIPI Dual CSI-2 to CSI-2 demo:

- CrossLink Raspberry Pi 2:1 MIPI CSI-2 Aggregator Demo Kit
  - CrossLink LIF-MD6000 Master Link board
  - Raspberry Pi Camera Link board (2)
  - Raspberry Pi AP link board
- Raspberry Pi 3 Model B V1.2 board or Raspberry Pi Model B+ board.
- Extra FPC cables used for RPi cameras
- Raspberry Pi cameras with FPC cables (2)
- HDMI monitor
- HDMI to HDMI cable
- Lattice Diamond® Programmer version 3.7 or later
- USB 2.0 Type A to Mini-B cable, included in demo kit
- USB 2.0 Type A to Micro-B cable
- Power adaptors (2), included in demo kit
- Laptop
- JED File for MachXO3L
- BIT File for CrossLink

Figure 3.1 and Figure 3.2 show the top view of the CrossLink LIF-MD6000 Master Link boards used in this demo. For more details about these boards refer to www.latticesemi.com/masterlink.
Figure 3.2. Raspberry Pi AP Link Board and Raspberry Pi Camera Link Board
4. Hardware Setup

Follow these steps to set up the hardware for 2:1 MIPI CSI-2 aggregator demo:

1. Take the Raspberry Pi camera 1 and remove Y1 (oscillator) on it.
2. To synchronize both cameras to a single oscillator take the Raspberry Pi camera 2 and connect the test point beside the oscillator of camera 2 to the same test point on Raspberry Pi camera 1. Usually in a system with two cameras, only one oscillator is used. In the most cost effective system the same clock is fed to two cameras. Fix both the cameras so that they should not move as shown below.

![Figure 4.1. Rework of Raspberry Pi cameras.](image)

3. Connect U1 connector of the two Raspberry Pi Camera Link Boards to Rx connector1 and Rx connector2 of CrossLink Master Link board respectively.
4. Connect U1 connector of Raspberry Pi AP Link Board to TX connector1 of LIF-MD6000 Master Link board.
5. Fix all the boards tightly with bolts and spacers as shown in Figure 4.2.
7. Also connect jumpers between pin2 and pin4 on both J24 and J25.
8. Connect the Raspberry Pi cameras with the FPC cables to J1 connector on the two Raspberry Pi Camera Link boards.
9. Connect one end of the extra FPC cable to J1 of AP Link Board and the other end to J3 camera connector on the Raspberry Pi Model B+ board.
10. Connect the HDMI port of the Raspberry Pi Model B+ board to a screen via HDMI cable as per Figure 4.2.
Figure 4.2. Assembled Demo System
5. **Device Configuration**

This section explains the programming and configuration settings of the 2:1 MIPI CSI-2 aggregator demo kit. The 2:1 MIPI CSI-2 Aggregator demo kit supports the programming of FPGA devices from flash device or directly through FTDI chip using Mini USB (J2) connector. The programming mode and device selection is done in Lattice Diamond Programmer. All design files required for running this demo are available on Lattice website.

The “Bitstream” folder includes the bit file and JED file required for programming the CrossLink LIF-MD6000 device and Lattice MachXO3L device, respectively.

5.1. **Programming Steps**

To program the board:

1. Connect the Mini USB cable to LIF-MD6000 Master Link Board.
2. Open the Lattice Diamond Programmer tool version 3.8 or later. The window shown in Figure 5.1 appears.
3. Click OK.

![Figure 5.1. Diamond Programmer – Getting Started](image)

4. The Diamond Programmer automatically scans the device on the board, and the window shown in Figure 5.2 appears.
5. Enable only LIF-MD6000 device and change the operation to SPI Flash Programming.
6. Select the options for the External SPI Flash on the board as shown in Figure 5.3.

7. Give the location of the bit file of the 2_to_1_MIPI_CSI2_Aggregator.bit, and click Load from File.
8. Click OK.
9. Click the Programming button. When the programming is finished, the message Programming successful appears in the output window.
10. Change the **Port** in **Cable settings** (on the right side of Programmer window) from FTUSB-0 to FTUSB-1.

11. On the menu bar click **Design**, and on the drop down menu select **JTAG Scan**. The MachXO3L device on the board will be scanned by the programmer.

12. Provide the MachXO3L JED location and program the device. When the programing is finished the message **Programming successful** appears in the output window.

The hardware setup is completed.
6. Software Setup

To set up the software for 2:1 MIPI CSI-2 aggregator bridge demo:

1. Make sure your Raspberry Pi board is updated with the firmware “Raspbian Jessie: version March 2016 or later. The latest version of the software is available at
2. Open the raspi-config tool from the terminal using sudo raspi-config command.
3. Select Enable camera and press Enter.
4. Go to Finish and you will be prompted to reboot.
   These steps need to be done only once while configuring the setup for the first time.
5. Use the following command in the terminal to run the demo:
   
   raspivid -o video.h264 -t 10000

When you run the above command the image should be displayed. If the message Waiting for data appears in the terminal window then press reset button SW4 on the board.

The final images from the two cameras side by side appear as shown in Figure 6.1 below. If the images do not appear, reset the Crosslink Master Link board.

Appendix A and Appendix B describe tips to diagnose problems with the 2:1 MIPI CSI-2 aggregator bridge demo. For details about the hardware part numbers, see Appendix A. If the hardware is correct and you do not get the demo output, see Appendix B for debug.

![Figure 6.1. Full Setup showing the Final Output of Demo](image-url)
7. Ordering Information

<table>
<thead>
<tr>
<th>Description</th>
<th>Ordering Part Number</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>Lattice CrossLink Master Link Board</td>
<td>CrossLink-ML-EVN</td>
<td>Initial Release</td>
</tr>
<tr>
<td>RPI Camera Link Board</td>
<td>RPI-CL-EVN</td>
<td>Initial Release</td>
</tr>
<tr>
<td>RPI AP Link Board</td>
<td>RPI-APL-EVN</td>
<td>Initial Release</td>
</tr>
</tbody>
</table>
Supplemental Information
Additional resources related to the Lattice Dual CSI-2 to CSI-2 kit including updated documentation and design project are available at www.latticesemi.com/rpiboards.

Technical Support Assistance
Submit a technical support case via www.latticesemi.com/techsupport.
Appendix A. Debug

Check the following:

1. The part number of the cameras. The camera part number for this demo is “Raspberry Pi camera Rev 1.3”. You can check this part number on the top of Raspberry Pi camera.
2. The version of Raspbian Jessie on the Raspberry Pi, This should be version March 2016 or later.
3. Run the camera demo by directly connecting the Raspberry Pi camera to the Raspberry Pi Model B+ board.
4. The part number of the extra FPC cable. This should be AdaFruit Industries-1646 (E248682 AWM 20941).
5. Check if the cables from the camera to the RPi Camera Link board are connected properly.
6. Check if you have mounted jumpers properly.
Appendix B. LIF-MD6000 Master Link Board Schematics

Figure B.1. Block Diagram
Figure B.2. FTDI Interface
Figure B.3. Power Regulator IF
Figure B.4. MIPI Block – MIPI TX
Figure B.6. Bank0 – Flash IF
Figure B.7. I²C Expander
Routing guidelines for MIPI & LVDS

1) All differential routes are required to have the same length between the positive (true) and the negative (complimentary) routes. Spacing between the positive (true) and the negative (complimentary) shall be 2 times trace width.
2) Target differential impedance shall be 100 Ohms
3) Trace length matching to be within 1.0 mm (40 mil) across the entire bus.
4) Use small bumps for skew corrections
5) Place signal vias close together and remove copper in between vias. Traces to be fully shielded with GND stitching terminating at both trace and points
6) Board trace impedance results must be within ±10 percent of target and Power plane impedance to be within +/- 10 percent of target at operating frequency

MIPI LVDS Simulation Requirement

1) MIPI Differential Mode insertion Loss shall be > -1.6dB at 750 MHz
2) MIPI Differential Mode Return Loss shall be < -15dB at 750 MHz
3) MIPI Common Mode Return Loss shall be < -15dB at 750 MHz
4) LVDS differential mode return loss shall be < -16.5dB at 600 MHz
5) LVDS common mode return loss shall be < -16.5dB at 600 MHz
6) LVDS insertion loss shall be > -1.7dB at 600 MHz
7) LVDS Cross coupling shall be < -22 dB for victim IO at 600MHz
8) Power plane impedance to be within +/- 10 percent of target at operating frequency
Appendix C. Raspberry Pi Camera Link Board

Figure C.1. Raspberry Pi Camera Link Board
Appendix D. Raspberry Pi AP Link Board

Figure D.1. Raspberry Pi AP Link Board
## Revision History

<table>
<thead>
<tr>
<th>Date</th>
<th>Version</th>
<th>Change Summary</th>
</tr>
</thead>
<tbody>
<tr>
<td>May 2016</td>
<td>1.0</td>
<td>Initial release.</td>
</tr>
</tbody>
</table>