本文记录了在NIOS II上实现示波器的第四部分。

本文主要包括:修改部分BUG,以及测试

本文所有的硬件以及工程参考来自魏坤示波仪,重新实现驱动并重构工程。

version 1.0 界面修改&系统调试&测试

界面修改

在示波器0.1版本中已经说明了界面的编写方法,在确定了该版本的基本功能之后,重新设计界面以及按键如下:

其中s0~s5为下排功能选择按键,其中重要的有:

  • 当通道选择为CH1时,输入耦合选择的也是CH1
  • 点按水平控制时,选择通过s8 s9来调节对应通道的水平轴

其中s6~s15用来调节参数

  • s6 s7用来调节触发的level
  • s10 ~ s14则按照左边屏幕上的说明操作

部分功能调整

按键中断陷入死循环BUG

在之前设计的策略中,s6~s15由于是用来调节参数,其在按键起来之前持续作用。于是将案件起来的判断放在了处理函数之中。但是中断结束之时对于按键弹起的操作又有单独判断。

根据不同按键分配不同策略。

即时处理STOP指令

STOP指令的处理放到中断中,而非等待系统更新状态之后,这样能够更精准的响应STOP请求。

  1. if (KEY_DATA == 4) {
  2. //等待按键抬起
  3. while (IORD_ALTERA_AVALON_PIO_DATA(KEY_PORT_BASE) != 0x03);
  4. //切换暂停和启动模式
  5. if (RUN_STOP_FLAG == 0){
  6. RUN_STOP_FLAG = 1;
  7. sprintf((char *) lcd_buffer, " STOP ");
  8. display_ascii(322, 16, 0xf800, MENU_FULL_COLOR);
  9. }
  10. else{
  11. RUN_STOP_FLAG = 0;
  12. sprintf((char *) lcd_buffer, " RUN ");
  13. display_ascii(332, 16, 0x07e0, MENU_FULL_COLOR);
  14. }
  15. } else {
  16. //正常情况
  17. if (RUN_STOP_FLAG == 0) {
  18. if (KEY_DATA != 0xff) {
  19. //将KEY_DATA传给CON_DATA
  20. CON_DATA = KEY_DATA;
  21. CON_FLAG = 1;
  22. KEY_DATA = 0xff;
  23. }
  24. if (!(CON_DATA>=6 && CON_DATA <= 9)) {
  25. //等待按键抬起
  26. while (IORD_ALTERA_AVALON_PIO_DATA(KEY_PORT_BASE) != 0x03);
  27. }
  28. }
  29. }
调整触发level以及CH1 level时水平轴及时刷新
  1. /*
  2. * 函数名:TRIG_CON
  3. * 说明 :当输入为1则增加,若输入为1则减少
  4. * 日期:2017-03-27
  5. */
  6. void TRIG_CON(unsigned char flag) {
  7. while (IORD_ALTERA_AVALON_PIO_DATA(KEY_PORT_BASE) != 0x03) {
  8. if (flag == 1 && TRIG_DATA < 244)
  9. TRIG_DATA++;
  10. else if (flag == 0 &&TRIG_DATA > 11)
  11. TRIG_DATA--;
  12. //添加此处 能够及时刷新
  13. DISP_TRIG(TRIG_DATA);
  14. //向MEM_CTL模块中写入触发condition
  15. IOWR_ALTERA_AVALON_PIO_DATA(TRIG_DATA_BASE, TRIG_DATA);
  16. TL_LOOP = 0;
  17. delay_ms(150);
  18. }
  19. }

增加系统初始化输出

在初始化LCD之后,对系统初始化的结果输出,用于跟踪系统的状态。

其中添加行与列变量,用于一行一行进行显示。

可以将该功能打包成系统输出函数,但后无需此功能,便直接写入到响应部分代码,并打包函数。

Version 1.0 版本测试

这里只给出示例测试,其余图片过大,不好上传。

正弦波测试

函数信号发生器输出

基于NIOS-II的示波器:PART4 系统调试&测试的更多相关文章

  1. 基于NIOS II的双端口CAN通信回环测试

    基于NIOS II的双端口CAN通信回环测试 小梅哥编写,未经授权,严禁用于任何商业用途 说明:本稿件为初稿,如果大家在使用的过程中有什么疑问或者补充,或者需要本文中所述工程源文件,欢迎以邮件形式发送 ...

  2. FPGA回忆记事(一):基于Nios II的LED实验

    实验一:基于Nios II的LED实验 一.    创建Quartus II工程 1.打开Quartus II环境.开始->程序->Altera->Quartus II 9.1. 2 ...

  3. 【推荐图书】+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等

    [推荐图书]+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等 3赞 发表于 2016/7/4 21:14:12 阅读(1921) 评论(3) 初次接触FPGA,到 ...

  4. Nios II 系统时钟timestamp的应用

    在用Nios II做外设时序驱动的时候,经常会用延时函数.有时会常使用某个FPGA芯片和时钟,比如笔者一直使用的芯片是cyclone系列 EP2C35F484C8N,PLL输入SOPC时钟是50M.因 ...

  5. 在WIN7系统下用Quartus ii 11.1 NIOS II 11.1 有时候会出现Nios II 的Run as hardware 中报错:Downloading ELF Process failed

    nios工程在编译通过后RUN的过程中出现Error Running Nios II Project: ‘Downloading ELF Process failed’问题原因: 1.nios2 cp ...

  6. [置顶] 基于FPGA的VGA简易显存设计&NIOS ii软核接入

    项目简介 本项目基于Altera公司的Cyclone IV型芯片,利用NIOS II软核,2-port RAM与时序控制模块,实现64*48分辨率的显存(再大的显存板载资源m9k不够用) 实现效果如下 ...

  7. Nios ii调试问题集

    如果定义了一个类的.hpp,而在相应的.cpp中定义其中的函数时,根本找不到定义的类,这说明类在定义时出错,要注意类括号后的冒号. 2. 问题1:NiosII/Eclipse 中遇到“Launchin ...

  8. Nios II系统在Quartus II编译后Timing requirements for slow timing model timing analysis were not met. See Report window for details

    来自http://wenku.baidu.com/link?url=h0Z_KvXD3vRAn9H8mjfbVErVOF_Kd3h-BZSyF1r4sEYj3ydJGEfBHGY1mvntP4HDuF ...

  9. Nios II的Boot过程分析

    目录 1       概述....................................................................... 1 2       几种常见的 ...

随机推荐

  1. [POI2008]枪战Maf

    [POI2008]枪战Maf 题目 有n个人,每个人手里有一把手枪.一开始所有人都选定一个人瞄准(有可能瞄准自己).然后他们按某个顺序开枪,且任意时刻只有一个人开枪.因此,对于不同的开枪顺序,最后死的 ...

  2. mbos之动态图表设计

    前言 所谓,一图胜千言.人脑有80%的部分专门用于视觉处理.而随着数据时代的全面来临,我们自然有必要将数据转化为图形与图表. Mbos是一个快速,稳定的云端轻应用开发平台.帮助企业快速开发移动应用,加 ...

  3. 自定义MySQL函数

    1.MySQL创建函数语法: CREATE [DEFINER = { user | CURRENT_USER }] FUNCTION sp_name ([func_parameter[,...]]) ...

  4. jmeter - 定时器

    jmeter提供了很多元件,帮助我们更好的完成各种场景的性能测试,其中,定时器(timer)是很重要的一个元件,最新的3.0版本jemter提供了9种定时器(之前6种),下面一一介绍: 一.定时器的作 ...

  5. 6,EasyNetQ-基于Topic的路由

    RabbitMQ具有非常酷的功能,基于主题的路由,允许订阅者基于多个标准过滤消息. 主题是与邮件一起发布的点分隔的单词列表. 例子是"stock.usd.nyse"或"b ...

  6. AngularJS优缺点、使用场景

    AngularJS 优缺点 优点: AngularJS模板功能强大丰富,自带了极其丰富的angular指令. AngularJS是完全可扩展的,与其他库的兼容效果很好,每一个功能可以修改或更换,以满足 ...

  7. shell脚本报错:"[: =: unary operator expected"

    shell脚本报错:"[: =: unary operator expected" 在匹配字符串相等时,我用了类似这样的语句: if [ $STATUS == "OK&q ...

  8. JavaScript正则表达式检验与递归函数实际应用

    JS递归函数(菲波那切数列) 实例解析: 一组数字:0  1  1  2  3  5  8  13                 0  1  2  3  4  5  6  7 sl(0)=0; sl ...

  9. ssm框架的搭建实现CRUD的操作

    最近在开发公司的一个系统,系统的框架是用ssm的框架搭建的,当然和这次写博客的不一样,它拥有很多的配置文件,企业级的开发所需要的配置文件是非常繁琐的,今天记录一下一个简单的SSM框架的搭建和实现一个C ...

  10. JS中的变量和输入输出

    一.使用JS的三种方式 1.在HTML标签中,直接内嵌JS(并不提倡使用) <button onclick="alert('点你咋地')">点我</button& ...