Intel FPGA IP之LVDS SerDes IP学习

2024-03-04 06:12
文章标签 ip 学习 fpga intel lvds serdes

本文主要是介绍Intel FPGA IP之LVDS SerDes IP学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

FPGA 视频数据输入输出直通工程:

  • :13.2吋8bit色深,屏幕分辨率为1440*1920@60,具有两个Port,每个Port有4个差分数据对与1个差分时钟对,差分对均支持LVDS协议
  • 芯片:Cyclone V系列FPGA
  • 目的:通过FPGA的LVDS SerDes RX接口输入8bit 色深RGB图像数据,然后再通过LVDS SerDes TX接口输出8bit 色深RGB图像数据,是个直通工程

一、13.2吋屏

 1.1 13.2吋屏参数:

DCLK frequency = horizontal line*vertical field*60=783*1962*60=92_174_760Hz≈ 92.17MHz

DCLK(即,Data Clock)就是Pixel Clock。

1.2 屏的数据传输格式:

该屏有两个Port,是8bit 色深图像,传输的数据格式如下图:

由图可知:

  • 该屏有两个Port,分奇偶Port(即,Odd Port与Even Port)
  • 每个Port有4个差分数据对与1个时钟差分对
  • 每个Port的LVDS数据格式相同
  • 差分时钟的占空比为4/7,且差分时钟频率与数据速率为1:7
  • 差分时钟与差分数据对之间的相位关系,即,差分时钟高电平中间时刻对应一个像素周期的开始时刻

通过VESA的标准协议可知,VESA的10bit屏的接口兼容8bit屏接口。如下图:

VESA:单port 8bit 屏:4个数据差分对+一个像素时钟差分对Pixel Clock
数据差分对T1T2T3T4T5T6T7
0+/-R0R1R2R3R4R5G0
1+/-G1G2G3G4G5B0B1
2+/-B2B3B4B5HSVSDE
3+/-R6R7G6G7B6B7XX
VESA:单port 10bit 屏:4个数据差分对+一个像素时钟差分对Pixel Clock
数据差分对T1T2T3T4T5T6T7
0+/-R0R1R2R3R4R5G0
1+/-G1G2G3G4G5B0B1
2+/-B2B3B4B5HSVSDE
3+/-R6R7G6G7B6B7XX
4+/-R8R9G8G9B8B9XX

 参考:LVDS电平标准与LCD屏的LVDS数据格式-CSDN博客

为了提高FPGA系统兼容性,在编写Verilog程序时,用10bit 色深的VESA标准协议。

二、Cyclone V的LVDS SerDes结构

2.1 LVDS Receiver结构

2.2 LVDS Transmitter结构

三、Intel FPGA的LVDS SerDes IP配置

3.1 添加LVDS SerDes IP

IP添加方式:在IP Catalog中输入LVDS+回车,可选择ALTLVDS_RX与ALTLVDS_TX两个LVDS SerDes IP进行参数设置。

3.2 rx_serdes_ip

3.2.1 rx_serdes_ip参数设置

3.2.2 例化rx_serdes:

//定义接口

reg  [4:0]   rx_datao_p;
reg  [4:0]   rx_datae_p;

reg pixel_clk_in;

wire    [69:0]  rx_out;

wire pixel_clk_out;

//例化

lvds_rx_1 u1_lvds_rx_1(
    .rx_in                    ({rx_datao_p, rx_datae_p}),
    .rx_inclock                (pixel_clk_in),
    .rx_out                    (rx_out),
    .rx_outclock            (pixel_clk_out)
    );    

3.3 tx_serdes

3.3.1 tx_serdes_ip参数设置

3.3.2 例化tx_serdes

reg     [34:0]  tx_datao;
reg     [34:0]  tx_datae;
wire [4:0]   tx_datao_p;

wire [4:0]   tx_datae_p;

lvds_tx  u1_lvds_tx (
    .pll_areset (tx_reset),
    .tx_in      ({7'b1100011, tx_datao, 7'b1100011, tx_datae}),
    .tx_inclock (pixel_clk_out),
    .tx_out     ({tx_cko_p, tx_datao_p, tx_cke_p, tx_datae_p}));

注意: {7'b1100011, tx_datao, 7'b1100011, tx_datae}中的两个7'b1100011是两个TX Port的Pixel Clock,结合LVDS Transmitter中的Serializer工作机制即可理解。

四、附件参考

Cyclone® V Device Handbook Volume 1: Device Interfaces and Integration


 

这篇关于Intel FPGA IP之LVDS SerDes IP学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772235

相关文章

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Linux查询服务器 IP 地址的命令详解

《Linux查询服务器IP地址的命令详解》在服务器管理和网络运维中,快速准确地获取服务器的IP地址是一项基本但至关重要的技能,下面我们来看看Linux中查询服务器IP的相关命令使用吧... 目录一、hostname 命令:简单高效的 IP 查询工具命令详解实际应用技巧注意事项二、ip 命令:新一代网络配置全

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J