最近在调试LATTICE  FPGA 做的视频板子,颇不顺利,所以记录下来作为以后的参考:

1、FPGA的IO口不是所有的都是双向的,有些有特殊作用的是单向的。

在查阅 LatticeECP3-17EAPinout.CSV 之后, 发现在LEF3-17EA-FN484C中,有以下几个管脚是单向的:

C4  G7  G6      : jtag 管脚

C14  C15  B15   B16  :编程管脚

K1   L5   L1   K6   N17  M18   :PLL的反馈(fb)管脚

AB2    AB3      : RESERVE

N15    : XRES

其中最容易被用掉的是 PLL的反馈管脚,要格外注意。其他的型号和封装可以参考相应的 .CSV  文件。

否则提示错误: ERROR :  the output port XX is  assigned  to an input dedicated pins [M18] .

2、在将程序下载到外部spi flash时,设置完成之后提示错误:

其中有  Except  Device  ID 0x04002310  READ:0X0000000;  则是说没有读到芯片的地址,则有可能是连接flash的读入线(相对FPGA)有问题。

尤其要检查是不是输入和输出线连接反了。

3、在下载程序到FPGA内部时,浏览芯片出现错误,或下载的时候出现错误,提示也如同上面的错误,就是读不到芯片的 ID, 那么可能是JTAG的四根连线出现问题,要详细检查。 例如我的是在TMS线上接了一个对地100nf的大电容,则把波形都滤掉了,所以出现错误而读不到数据。

4、lattice Diamond 在下载的时候 加载bit文件的时候,由于这个软件不会自动寻到正在编译的工程目录下,所以加载的bit文件可能是上个工程的路径,这样软件就会报出一个错误:

这个原因是下载文件的路径有问题,改为你当前工程的路径即可。

5、关于lattice  DDR3 IP 核的wl_err信号的调试:

lattice  的DDR3 IP核 在调试的时候要注意,硬件上电之后,DDR3 要复位 200us之上,如果时钟是74.25M的输入,则需要计数达到3000个clk,才可以开始初始化。如果是仿真,当然不需要那么久了,假设仿真时钟是6666ps,就是核内部demo的仿真参数,则如下所示

  `timescale   ps/  ps

  parameter  c = ;
always
#(c) clk = ~clk ;

那么  复位的时钟个数计数只要达到100个就可以了(demo 是200个clk周期)。

那么正确的wl_err的 信号在初始化的时候的波形是这样的:

就是在init_done 有效的时候,init_start被拉低,wl_err信号保持为低电平,表示核初始化写调整没有错误,可以正确的读写。

但是吧,有一天,我感觉    c = 6666;  这样太长了,仿真太慢了,于是我又把C调整为 c = 666; 或者 c 更小 ,我想这样是不是只要延时时间一样长,

就可以完成初始化了???于是我就实验,将c= 666,计数记到 100,甚至 16‘hffff,最后发现wl_err的波形在初始化完成时都是下图这样的:

在init_done有效的时候,wl_err被拉高,且一直保持,这就是说,核初始化过程中写调整有错误,这样的结果是——导致核的读操作不能被有效的

响应,就是度有效之后,不能读出数据 。当然这个核是没法仿真的了。  猜测 可能是 时钟的 频率 太快了。

最后没办法,老老实实把 c改为6666 吧。

Lattice FPGA 板子 调试笔记的更多相关文章

  1. FPGA DDR3调试

    FPGA DDR3调试 Spartan6 FPGA芯片中集成了MCB硬核,它可以支持到DDR3.在Xilinx的开发工具Xilinx ISE中提供了MIG IP核,设计者可以用它来直接生成 DDR3 ...

  2. Tomcat调试笔记

    调试笔记 在使用Tomcat过程中经常碰到问题,导致tomcat启动失败.如下↓ 由于报错太过笼统,我根本无法找出错误.后来我切换到Console视图下,看到了如下错误信息. 根据报错信息,错误原因是 ...

  3. JavaScript特效(调试笔记)

    JavaScript特效 一.在网页上显示当前的时间日期,例如:“2016年3月26日 星期六”. js源代码: function getTime() { var today = new Date() ...

  4. USB wifi调试笔记

    本文以realtek 8192CU WiFi模块为例,介绍USB wifi在Jelly Bean 4.1的调试笔记. 1.WIFI打不开现象概述 WiFi打不开是指您在UI的settings下选中Wi ...

  5. ida动态调试笔记

    ida动态调试笔记 目标文件:阿里安全挑战赛的第二题 点击打开链接 使用环境:ida6.8点击打开链接,adt bundle点击打开链接 首先打开avd安卓模拟器,界面如下: 在dos下运行adb命令 ...

  6. modbus-poll和modbus-slave工具的学习使用——modbus协议功能码3的解析(及欧姆龙温控器调试笔记)

    最近的项目中使用到了欧姆龙的温控器,里面有很多的通信方式,我们使用的常见的modbus——RTU方式,其他方式我们不使用,其中通信手册上面有很多通信的实例,欧姆龙modbus还区分4字节模式和2字节模 ...

  7. Lattice 的 DDR IP核使用调试笔记之工程建立

    DDR3的IP核的使用相当重要,尤其是对视频处理方面. 下面接收DDR3 的IP 核的生成步骤. 1. 选择DDR IP核的生成路径.名字以及哪种语言之后就可以设置DDR IP 的参数了. 2.选择存 ...

  8. Lattice 的 Framebuffer IP核使用调试笔记之IP核生成与参数设置

    本文由远航路上ing 原创,转载请标明出处. 这节笔记记录IP核的生成以及参数设置. 先再IP库里下载安装Framebuffer 的ipcore 并安装完毕. 一.IP核的生成: 1.先点击IP核则右 ...

  9. Lattice 的 Framebuffer IP核使用调试笔记之datasheet笔记

    本文由远航路上ing 原创,转载请标明出处. 学习使用以及调试Framebuffer IP 核已经有一段时间了,调试的时候总想记录些东西,可是忙的时候就没有时间来写,只有先找个地方记录下,以后再总结. ...

随机推荐

  1. 高性能集群软件Keepalived(1)

    1介绍 Keepalived是linux下一个轻量级的高可用解决方案,与HeartBeat,RoseHA实现的功能类似,但是还是有差别.HeartBeat是一个专业的功能完善的高可用软件,它提供了HA ...

  2. ssh中org.springframework.orm.hibernate4.support.OpenSessionInViewFilter的作用及配置

     org.springframework.orm.hibernate4.support.OpenSessionInViewFilter 是Spring为我们解决Hibernate的Session的关闭 ...

  3. python对Mysql操作和使用ORM框架(SQLAlchemy)

    python对mysql的操作 Mysql 常见操作 数据库操作 创建数据库 create database fuzjtest 删除数据库 drop database fuzjtest 查询数据库 s ...

  4. SDL绑定播放窗口 及 视频窗口缩放

    绑定播放窗口 必须在Sdl.SDL_Init之前执行 Sdl.SDL_putenv 同时SDL_SetVideoMode里播放窗口长宽不能大于绑定窗口的长宽 int i = Sdl.SDL_puten ...

  5. Web jquery表格组件 JQGrid 的使用 - 11.问题研究

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  6. debian下NTFS分区无法访问解决

    打开终端 # ntfsfix /dev/sda3 (/dev/sda3是上图中划红框的部分,根据实际情况替换) 如果这个磁盘可以正常挂载,说明问题已经解决了,其他磁盘在重启后也可以挂载了 如果不想重启 ...

  7. [NHibernate]条件查询Criteria Query

    目录 写在前面 文档与系列文章 条件查询 一个例子 总结 写在前面 上篇文章介绍了HQL查询,我个人觉得使用ORM框架就是为了让少些sql,提高开发效率,而再使用HQL就好像还是使用sql,就觉得有点 ...

  8. [NHibernate]组件之依赖对象

    目录 写在前面 文档与系列文章 组件之依赖对象 一个例子 总结 写在前面 周一至周四一直在成都出差,也一直没有更新博客了,一回到家第一件事就是扒一扒最近博客园更新的文章,然后把想看的收藏了,大概有20 ...

  9. Bash 中的 _ 是不是环境变量

    首先,我们想到的会是 export(等价于 declare -x)命令: $ export | grep 'declare -x _=' 没有找到,那么结论就是 _ 不是环境变量?当然没那么简单,否则 ...

  10. tyvj1087 sumsets

    背景 广东汕头聿怀初中 Train#2 Problem1 描述     正整数N可以被表示成若干2的幂次之和.例如,N = 7时,共有下列6种不同的方案:1) 1+1+1+1+1+1+12) 1+1+ ...