

# **HiSPi-to-Parallel Sensor Bridge**

# **Reference Design**



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS and with all faults, and all risk associated with such information is entirely with Buyer. Buyer shall not rely on any data and performance specifications or parameters provided herein. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. No Lattice products should be used in conjunction with mission- or safety-critical or any other application in which the failure of Lattice's product could create a situation where personal injury, death, severe property or environmental damage may occur. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.



### **Contents**

| 1.   | Introduction                                                                                       | 4  |
|------|----------------------------------------------------------------------------------------------------|----|
| 2.   | Functional Description                                                                             | 4  |
| 3.   | Parameter Settings                                                                                 | 6  |
| 4.   | Test Bench Description                                                                             | 7  |
| 5.   | Implementation                                                                                     | 8  |
| 6.   | Hardware Validation                                                                                | 12 |
| Ref  | erences                                                                                            | 13 |
| Tec  | hnical Support Assistance                                                                          | 14 |
| Rev  | rision History                                                                                     | 15 |
|      |                                                                                                    |    |
| Fig  | gures                                                                                              |    |
| Figi | ure 1.1. HiSPi-to-Parallel Sensor Bridge Overview                                                  | 4  |
|      | ure 2.1. HiSPi-to-Parallel Sensor Bridging Block Diagram (Normal Operating Mode)                   |    |
| _    | ure 2.2. HiSPi-to-Parallel Sensor Bridging Block Diagram (HDR Operating Mode)                      |    |
| _    | ure 4.1. Simulation Structure for the HiSPi-to-Parallel Sensor Bridge                              |    |
| _    | ure 4.2. Simulation of HiSPi Bridge (Frame with Reduced Line Size)                                 |    |
| _    | ure 5.1. HiSPi Sensor Bridge Request Form                                                          |    |
| J    |                                                                                                    |    |
| Та   | ıbles                                                                                              |    |
| Tab  | ole 3.1. Configurable Parameters                                                                   | 6  |
| Tab  | le 3.2. Supported Formats in HDR Operating Mode                                                    | 6  |
|      | ıle 3.3. HiSPi-to-Parallel Sensor Interface Bridge I/Os                                            |    |
|      | le 5.1. Performance and Resource Utilization <sup>1</sup>                                          |    |
| Tab  | lle 5.2. I/O Timing Analysis of Serial Data Lanes                                                  | 10 |
|      | ole 5.3. Aptina Sensor Bridge Recommended Pinout for LatticeXP2-5/8, LatticeXO2-1200/2000/4000 and |    |
| Latt | ticeXO3L-2100/4300/6900 FPGAs                                                                      | 11 |



### 1. Introduction

The HiSPi-to-Parallel Sensor Interface Bridge is designed to convert an Aptina sensor delivering HiSPi (High-Speed Serial Pixel) serial data to a traditional parallel data bus. The parallel data bus is designed to be compatible with standard ISP (Image Signal Processing) devices (see Figure 1.1.). This reference design covers all normal HiSPi operating modes including Packetized-SP, Streaming-SP, Streaming-S and ActiveStart SP8, as defined in HiSPi Protocol v1.00.00. In addition, the reference design also supports the HDR (High Dynamic Range) operating mode defined in TN-09-215: HiSPi Protocol Specification for the MT9M024 and other Aptina sensors.



Figure 1.1. HiSPi-to-Parallel Sensor Bridge Overview

### 2. Functional Description

The HiSPi bridge can accept up to four differential serial lanes. Normally two or four lanes are used. As shown in Figure 2.1. and Figure 2.2., each serial data lane in the Lattice FPGA is sampled and converted to a 4-bit or 8-bit wide interface by using a dedicated IDDR (Input Double Data Rate) element with x2 or x4 gearing respectively. The Lane Aligner performs the word and lane alignment according to the selected HiSPi mode. The Parser decodes lines, frames and converts them to the parallel data format. The parallel output includes a pixel clock, frame valid and line valid signals as well as a data bus, which is compatible with most in-system programmable devices. Parallel output signals can be configured to LVCMOS18, LVCMOS25 or LVCMOS33 (1.8 V, 2.5 V or 3.3 V respectively). Even though the linear mode (normal operating mode) and the HDR operating mode are combined into a single packet in this reference design, they are illustrated separately for reference.



Figure 2.1. HiSPi-to-Parallel Sensor Bridging Block Diagram (Normal Operating Mode)

Features of the normal operating mode:

- Supports HiSPi formats Packetized-SP, Streaming-SP, Streaming-S and ActiveStart SP8.
- Supports lane number range from one to four.
- Supports output parallel bit widths of 10, 12, 14 or 16 bits.





Figure 2.2. HiSPi-to-Parallel Sensor Bridging Block Diagram (HDR Operating Mode)

#### Features of the HDR operating mode:

- Supports all the HDR operating modes introduced in TN-09-215: 20-bit over 4 lanes; 12/14 bits over 3 lanes; 12 bits over two lanes or 14 bits over two lanes.
- Pixel data extraction for the selected mode.
- Embedded data extraction for the selected mode.



## 3. Parameter Settings

**Table 3.1. Configurable Parameters** 

| Parameter                 | Range/Options     | Default         |
|---------------------------|-------------------|-----------------|
| pmi_family                | "XP2"             | "XO2"           |
|                           | "XO2"             |                 |
|                           | "XO3L"            |                 |
|                           | "ECP3"            |                 |
|                           | "ECP5"            |                 |
| c_HDR_MODE <sup>1</sup>   | "true"            | "false"         |
|                           | "false"           |                 |
| c_HISPI_MODE <sup>2</sup> | "Packetized-SP"   | "Packetized-SP" |
|                           | "Streaming-SP"    |                 |
|                           | "Streaming-S"     |                 |
|                           | "ActiveStart-SP8" |                 |
| c_WORD_WIDTH <sup>3</sup> | 10/12/14/16/20    | 12              |
| c_LANE_WIDTH <sup>4</sup> | 1/2/3/4           | 4               |
| c_BRIDGES <sup>5</sup>    | Reserved          | 1               |
| c_3D                      | Reserved          | "none"          |
| pix_per_In <sup>6</sup>   | 0 to 2^12-1       | 1080            |
| FLR_enable <sup>7</sup>   | 0/1               | 0               |

#### Notes:

- 1. If parameter c\_HDR\_MODE is set to "true", the HDR operating mode is selected, otherwise the normal operating mode is selected
- 2. Parameter c\_HISPI\_MODE is only used in normal operating mode.
- 3. 10/12/14/16 are available for normal operating mode. Options 12/14/20 are available for the HDR operating mode.
- 4. In HDR operating mode, the formats listed in Table 3.2. are supported.
- 5. MachXO2 only. Defines the number of bridges to initiate.
- 6. pix\_per\_In is an input bus to the bridge core. It defines the number of pixels per active horizontal line. Used for all modes except Packetized-SP.
- 7. Adds a latency of c\_LANE\_WIDTH to the active space readout. Set to 0 for most cases.

Table 3.2. Supported Formats in HDR Operating Mode

| c_WORD_WIDTH | c_LANE_WIDTH | Description          |
|--------------|--------------|----------------------|
| 20 bits      | 4            | 20 bits over 4 lanes |
| 12 bits      | 3            | 12 bits over 3 lanes |
| 14 bits      | 3            | 14 bits over 3 lanes |
| 12 bits      | 2            | 12 bits over 2 lanes |
| 14 bits      | 2            | 14 bits over 2 lanes |



| Table 3.3. HiSPi-to-Parallel Sensor Interface Bridge I/Os |
|-----------------------------------------------------------|
|-----------------------------------------------------------|

| Signal Name             | Definition                             | Direction |
|-------------------------|----------------------------------------|-----------|
| rstn                    | Sensor Bridge reset, active low        | Input     |
| sclk                    | HiSPi serial differential clock        | Input     |
| sdata [0]               | HiSPi serial differential data; Lane 1 | Input     |
| sdata [1]               | Lane 2                                 |           |
| sdata [2]               | Lane 3                                 |           |
| sdata [3]               | Lane 4                                 |           |
| pclk                    | Pixel clock                            | Output    |
| f_valid                 | Field valid indication                 | Output    |
| l_valid                 | Line valid indication                  | Output    |
| dout [c_WORD_WIDTH-1:0] | Pixel data                             | Output    |
| Reset to sensor         | Reset for sensor                       | Output    |

### 4. Test Bench Description

A behavioral simulation is also included in the reference design. The simulation is supports both the ModelSim and Active-HDL environments. For either environment, set the simulator's working directory to the location of the .do script and execute it. If Lattice Diamond® is not installed in the default directory, update the macro definition LATTICE\_SRC in the script file manually.



Figure 4.1. Simulation Structure for the HiSPi-to-Parallel Sensor Bridge

The simulation is supported for both the ModelSim and Active-HDL simulators. For each simulator, set the simulator's working directory to the location of the .do script and then execute the .do script. If Lattice Diamond $^{\text{m}}$  is not installed in the default directory, update the macro definition LATTICE\_SRC in the script file manually.



Figure 4.2. Simulation of HiSPi Bridge (Frame with Reduced Line Size)



## 5. Implementation

Table 5.1. Performance and Resource Utilization<sup>1</sup>

| Device Family            | HiSPi Mode    | Word  | Lane  | Registers |     | LU  | ITs | EBRs | PLL |
|--------------------------|---------------|-------|-------|-----------|-----|-----|-----|------|-----|
|                          |               | Width | Width | LSE       | Syn | LSE | Syn |      |     |
| MachXO3L <sup>6</sup>    | Packetized-SP | 12    | 2     | 430       | 430 | 340 | 336 | 2    | 1   |
|                          | Packetized-SP | 12    | 4     | 711       | 711 | 545 | 541 | 4    | 1   |
|                          | Packetized-SP | 16    | 4     | 859       | 859 | 550 | 546 | 5    | 1   |
|                          | Streaming-SP  | 16    | 4     | 787       | 787 | 550 | 546 | 5    | 1   |
| MachXO2 <sup>™ 2</sup>   | Packetized-SP | 12    | 2     | 39        | 92  | 34  | 40  | 2    | 1   |
|                          | Packetized-SP | 12    | 4     | 67        | 73  | 5:  | 11  | 4    | 1   |
|                          | Packetized-SP | 14    | 2     | 42        | 20  | 37  | 70  | 2    | 1   |
|                          | Packetized-SP | 14    | 4     | 72        | 21  | 62  | 23  | 4    | 1   |
|                          | Streaming-SP  | 12    | 2     | 36        | 52  | 30  | 00  | 2    | 1   |
|                          | Streaming-SP  | 12    | 4     | 61        | L4  | 50  | 00  | 4    | 1   |
|                          | Streaming-SP  | 14    | 2     | 38        | 36  | 34  | 19  | 2    | 1   |
|                          | Streaming-SP  | 14    | 4     | 65        | 57  | 60  | 06  | 4    | 1   |
|                          | HDR           | 20    | 4     | 77        | 73  | 58  | 39  | 3    | 1   |
| LatticeXP2™ <sup>3</sup> | Packetized-SP | 12    | 2     | 32        | l1  | 29  | 95  | 1    | 1   |
|                          | Packetized-SP | 12    | 4     | 51        | L4  | 49  | 99  | 2    | 1   |
|                          | Packetized-SP | 14    | 2     | 34        | 17  | 33  | 12  | 1    | 1   |
|                          | Packetized-SP | 14    | 4     | 58        | 30  | 55  | 50  | 2    | 1   |
|                          | Streaming-SP  | 12    | 2     | 28        | 33  | 19  | 94  | 1    | 1   |
|                          | Streaming-SP  | 12    | 4     | 45        | 58  | 47  | 78  | 2    | 1   |
|                          | Streaming-SP  | 14    | 2     | 31        | 15  | 33  | 15  | 1    | 1   |
|                          | Streaming-SP  | 14    | 4     | 53        | 16  | 53  | 32  | 2    | 1   |
|                          | HDR           | 20    | 4     | 57        | 77  | 47  | 77  | 2    | 1   |
| ECP5™ <sup>5</sup>       | Packetized-SP | 12    | 2     | 32        | 16  | 31  | 15  | 1    | 1   |
|                          | Packetized-SP | 12    | 4     | 54        | 10  | 54  | 16  | 2    | 1   |
|                          | Packetized-SP | 14    | 2     | 35        | 50  | 38  | 34  | 1    | 1   |
|                          | Packetized-SP | 14    | 4     | 62        | 11  | 63  | 34  | 2    | 1   |
|                          | Streaming-SP  | 12    | 2     | 28        | 39  | 30  | )9  | 1    | 1   |
|                          | Streaming-SP  | 12    | 4     | 48        | 37  | 53  | 37  | 2    | 1   |
|                          | Streaming-SP  | 14    | 2     | 32        | 22  | 33  | 30  | 1    | 1   |
|                          | Streaming-SP  | 14    | 4     | 54        | 13  | 56  | 58  | 2    | 1   |
|                          | HDR           | 20    | 4     | 62        | 24  | 54  | 10  | 2    | 1   |



#### Notes:

- Packetized-SP and Streaming-SP linear modes are provided in NGO format. For other modes, visit the Lattice sensor bridge web
  page at http://www.latticesemi.com/Solutions/Solutions/SensorBridge.aspx or visit the Aptina HiSPi to Parallel Sensor Bridge
  page
  - http://www.latticesemi.com/en/Products/DesignSoftwareAndIP/IntellectualProperty/ReferenceDesigns/ReferenceDesigns01/AptinaHiSPitoParallelSensorBridge.aspx to create a custom HiSPi bridge.
- 2. Resource utilization characters are generated using LCMXO2-4000HE-6MG132C with Lattice Diamond 1.4 design software. When using this design in a different device, the utilization may vary.
- 3. Resource utilization characters are generated using LFXP2-8E-7M132C with Lattice Diamond 1.1 design software. When using this design in a different device, the utilization may vary.
- 4. Resource utilization in a LatticeECP3 device will be similar to the LatticeXP2 implementation.
- 5. Resource utilization characters are generated using LFE5UM-85F-8MG400C with Lattice Diamond 3.0 design software. When using this design in a different device, the utilization may vary.
- 6. Resource utilization characters are generated using LCMXO3L-4300C-6BG256C with the x4 gearing mode on Lattice Diamond 3.1 design software. When using this design in a different device or the x2 gearing mode, the utilization may vary. Diamond 3.1 users will need to install a patch to enable the x4 gearing mode on MachXO3L. To get the patch, please send your request to techsupport@latticesemi.com.



#### Table 5.2. I/O Timing Analysis of Serial Data Lanes

|                                 | Setup (ns)                                | Hold (ns)     | Setup (ns)    | Hold (ns) | Setup (ns)    | Hold (ns) |
|---------------------------------|-------------------------------------------|---------------|---------------|-----------|---------------|-----------|
| MachXO3L <sup>4</sup>           | Speed G                                   | Speed Grade 4 |               | Grade 5   | Speed (       | Grade 6   |
|                                 | -                                         | -             | -0.472        | 1.012     | -0.387        | 0.788     |
| MachXO2 <sup>1</sup>            | Speed Grade 4 Speed Grade 5 Speed Grade 6 |               | ade 4 Speed G |           | Grade 6       |           |
|                                 | 0.248                                     | 0.292         | 0.246         | 0.223     | 0.243         | 0.158     |
| LatticeXP2 <sup>2</sup>         | Speed Grade 5                             |               | Speed Grade 6 |           | Speed Grade 7 |           |
|                                 | -0.272                                    | 0.447         | -0.268        | 0.380     | -0.263        | 0.317     |
| ECP5 <sup>3</sup> Speed Grade 8 |                                           | Speed         | Grade 6       | Speed (   | Grade 7       |           |
|                                 | -0.104                                    | 0.481         | -0.268        | 0.380     | -0.263        | 0.317     |

#### Notes:

- 1. Timing parameters are generated using LCMXO2-4000HE-6MG132C with Lattice Diamond 1.4 design software.
- 2. Timing parameters are generated using LFXP2-8E-7M132C with Lattice Diamond 1.4 design software.
- 3. Timing parameters are generated using LFE5UM-85F-8MG400C with Lattice Diamond 3.0 design software.
- 4. Timing parameters are generated for LCMXO3L-4300C-6BG256C on Lattice Diamond 3.1 design software.



Table 5.3. Aptina Sensor Bridge Recommended Pinout for LatticeXP2-5/8, LatticeXO2-1200/2000/4000 and LatticeXO3L-2100/4300/6900 FPGAs

| Signal Name      | LatticeXP2<br>132-csBGA Pin | MachXO2<br>132-csBGA Pin | MachXO3L<br>BG256 Pin |
|------------------|-----------------------------|--------------------------|-----------------------|
| rstn_to_sensor 1 | B9                          | F2                       | G3                    |
| rstn_to_bridge 2 | F12                         | C1                       | E2                    |
| sclk_p           | H1                          | N6                       | T7                    |
| sclk_n           | Н3                          | P6                       | R8                    |
| sdata_p [0]      | D2                          | M11                      | P12                   |
| sdata_n [0]      | E3                          | P12                      | T13                   |
| sdata_p [1]      | D1                          | P8                       | R9                    |
| sdata_n [1]      | E1                          | M8                       | T10                   |
| sdata_p [2]      | H2                          | P2                       | P4                    |
| sdata_n [2]      | G3                          | N2                       | T4                    |
| sdata_p [3]      | L1                          | M7                       | Т9                    |
| sdata_n [3]      | L3                          | N8                       | P9                    |
| pclk             | P2                          | A11                      | B11                   |
| f_valid          | P14                         | B7                       | A8                    |
| l_valid          | P13                         | C4                       | B6                    |
| dout [0]         | N8                          | C6                       | C7                    |
| dout [1]         | M6                          | B3                       | B5                    |
| dout [2]         | M5                          | C11                      | C11                   |
| dout [3]         | M7                          | A12                      | B12                   |
| dout [4]         | N12                         | A7                       | C8                    |
| dout [5]         | N7                          | B5                       | В7                    |
| dout [6]         | P12                         | A9                       | A10                   |
| dout [7]         | P5                          | A10                      | A11                   |
| dout [8]         | P6                          | A2                       | C4                    |
| dout [9]         | N2                          | B12                      | A12                   |
| dout [10]        | P7                          | C12                      | C12                   |
| dout [11]        | N4                          | B13                      | A13                   |

#### Notes:

- 1. rstn\_to\_sensor is used in the top level design to reset the Aptina sensor, but is not part of the sensor bridge itself. It is recommended to connect the reset pin for sensor control in your design.
- 2. rstn\_to\_bridge controls a reset counter in our top level design. This is done to remove debounce and ensure the sensor and bridge have been completely restarted. After reset the sensor is held Idle before programming the sensor via I2C. The top level design holds the sensor and bridge in reset for ~2.5 seconds. The sensor is then programmed after an additional ~2.5 seconds.

To request a reference design meeting your specific design requirements visit the Lattice Semiconductor website and complete the HiSPi Sensor Bridge Configuration Request form.

www. lattice semi. com/products/intellectual property/reference designs/aptina his pitoparallel sens/his pisens or bridge configur. cfm





Figure 5.1. HiSPi Sensor Bridge Request Form

### 6. Hardware Validation

The HiSPi-to-Parallel Sensor Bridge reference design has been hardware tested using the HDR-60 and an interface board to the Aptina MT9M024 sensor. In addition, the Texas Instruments 812X IP Network Camera uses this bridge with the Aptina J003 sensor.



## **References**

- HiSPi Protocol v1.00.00
- TN-09-215: HiSPi Protocol Specification for the MT9M023 and MT9M033 Introduction



## **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport.



## **Revision History**

#### Revision 1.4, November 2019

| Section     | Change Summary                                        |  |
|-------------|-------------------------------------------------------|--|
| All         | Changed document number from RD1120 to FPGA-RD-02069. |  |
|             | Updated document template.                            |  |
| Disclaimers | Added this section.                                   |  |

#### Revision 1.3, April 2014

| Section            | Change Summary                              |  |
|--------------------|---------------------------------------------|--|
| Parameter Settings | Updated Table 3.1, Configurable Parameters. |  |
| All                | Updated Sapphire device to ECP5 device.     |  |
|                    | Added support for MachXO3L device.          |  |

#### Revision 1.2, July 2013

| Section                      | Change Summary                                                      |  |
|------------------------------|---------------------------------------------------------------------|--|
| All                          | Updated for Sapphire.                                               |  |
|                              | Updated the Performance and Resource Utilization and the I/O Timing |  |
|                              | Analysis of Serial Data Lanes tables.                               |  |
|                              | Updated document with new corporate logo.                           |  |
| Technical Support Assistance | Updated Technical Support Assistance information.                   |  |

#### Revision 1.1, December 2011

| Section | Change Summary                                                |
|---------|---------------------------------------------------------------|
| All     | Product name/trademark adjustment. Included MachXO3LF device. |

#### Revision 1.0. April 2011

| Section | Change Summary   |
|---------|------------------|
| All     | Initial release. |



www.latticesemi.com