基于SOPC的LED循环流水灯控制设计_第1页
基于SOPC的LED循环流水灯控制设计_第2页
基于SOPC的LED循环流水灯控制设计_第3页
基于SOPC的LED循环流水灯控制设计_第4页
基于SOPC的LED循环流水灯控制设计_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、.课程报告设计课题: 基于SOPC 的LED 循环流水灯控制设计姓 名: XXX 专 业: 集成电路设计与集成系统 学 号: 1115103004 日 期 2014 年 11月 18 日 指导教师: XXX 华侨大学信息科学与工程学院电子工程系;.基于SOPC的LED循环流水灯控制设计1. 设计的任务与要求1. 将8 只LED 灯编号,奇数号亮1 秒,灭2 秒,偶数号亮3 秒,灭3 秒。2. 用数码管显示每个灯的亮灭时间。3. 循环点亮。2 系统设计整体硬件电路框图 整体电路设计由一个锁相环,SOPC搭建的CPU模块组成,由DE2内部时钟50MHZ输入控制,输出接LED7.08个LED灯,HE

2、X0-HEX7 8个数码管,用程序编程控制,来实现LED循环流水灯数码管计时功能的实现。三.单元电路设计 锁相环设计模块(PLL)SOPC设计模块在DE2 平台上建立SOPC系统的硬件,这个系统包括一个NIos II/s 嵌入式处理器、存储器、一个JTAG UART 及一个定时器,一个ID 模块和IO模块。另外,我们将加入一个自定义组件,实现对DE2 平台上七段数码管的控制。SOPC模块硬件电路图四:仿真结果5 软件设计 程序详见附录六系统测试: 实验仪器用DE2板验证,芯片型号为EP2C35F672C6,将计算机软件与DE2板相连。用8只LED灯实现循环点亮,并在8只数码管显示每只LED灯的

3、亮灭时间。七结论:从DE2板实验结果可以看出,该实验现象满足设计的任务与要求,即:1. 将8 只LED 灯编号,奇数号亮1 秒,灭2 秒,偶数号亮3 秒,灭3 秒。2. 用数码管显示每个灯的亮灭时间。3. 循环点亮。满足了该设计的1,2,3点要求,唯一不足的地方是在用数码管显示每个灯的亮灭时间时,我是用usleep()函数来延迟的,时间精度方面可能比不上用定时计数器来的准确,可以做进一步改进。附录:软件程序:#include system.h#include alt_types.h#include unistd.h#include io.hint main (void) alt_u8 led=

4、0x01; alt_u32 count; volatile int i; /i用来控制循环的次数 volatile int j; /j用来控制每次循环时间为1S while(1) led=0x01; *(unsigned int *)PIO_LED_BASE = led; /点亮第一个LED灯 for(i=1,j=1000000,count=0x00000001;i0;i-) /用数码管控制亮的时间1S IOWR(SEG7_LUT_8_0_BASE,0,count); /第一个数码管显示count值1 usleep(j); /j=1000000,延时1秒 count=count-0x00000

5、001; /count值减1 IOWR(SEG7_LUT_8_0_BASE,0,count); /第一个数码管显示count值0 led=0x00; *(unsigned int *)PIO_LED_BASE = led; /熄灭第一个LED灯 for(i=2,j=1000000,count=0x00000002;i0;i-) /用数码管控制熄灭的时间2S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00000001; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x02; *(unsigne

6、d int *)PIO_LED_BASE = led;/点亮第二个LED灯 for(i=3,j=1000000,count=0x00000030;i0;i-) /用数码管控制亮的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00000010; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第二个LED灯 for(i=3,j=1000000,count=0x00000030;i0;i-)/用数码管控制

7、熄灭的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00000010; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x04; *(unsigned int *)PIO_LED_BASE = led;/点亮第三个LED灯 for(i=1,j=1000000,count=0x00000100;i0;i-) /用数码管控制亮的时间1S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00000100; IOWR(SEG7_

8、LUT_8_0_BASE,0,count); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第三个LED灯 for(i=2,j=1000000,count=0x00000200;i0;i-)/用数码管控制熄灭的时间2S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00000100; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x08; *(unsigned int *)PIO_LED_BASE = led;/点亮第四个LED灯 for(i=

9、3,j=1000000,count=0x00003000;i0;i-)/用数码管控制亮的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00001000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第四个LED灯 for(i=3,j=1000000,count=0x00003000;i0;i-)/用数码管控制熄灭的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usle

10、ep(j); count=count-0x00001000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x10; *(unsigned int *)PIO_LED_BASE = led;/点亮第五个LED灯 for(i=1,j=1000000,count=0x00010000;i0;i-)/用数码管控制亮的时间1S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00010000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x00; *(unsigned in

11、t *)PIO_LED_BASE = led;/熄灭第五个LED灯 for(i=2,j=1000000,count=0x00020000;i0;i-)/用数码管控制熄灭的时间2S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00010000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x20; *(unsigned int *)PIO_LED_BASE = led;/点亮第六个LED灯 for(i=3,j=1000000,count=0x00300000;i0;i-)/用数码管控制亮的时间

12、3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00100000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第六个LED灯 for(i=3,j=1000000,count=0x00300000;i0;i-)/用数码管控制熄灭的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x00100000; IOWR(SEG7_LUT_8

13、_0_BASE,0,count); led=0x40; *(unsigned int *)PIO_LED_BASE = led;/点亮第七个LED灯 for(i=1,j=1000000,count=0x01000000;i0;i-)/用数码管控制亮的时间1S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x01000000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第七个LED灯 /for(i=0;i0;

14、i-)/用数码管控制熄灭的时间2S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x01000000; IOWR(SEG7_LUT_8_0_BASE,0,count); led=0x80; *(unsigned int *)PIO_LED_BASE = led;/点亮第八个LED灯 /for(i=0;i0;i-)/用数码管控制亮的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x10000000; IOWR(SEG7_LUT_8_0_BASE,0,co

15、unt); led=0x00; *(unsigned int *)PIO_LED_BASE = led;/熄灭第八个LED灯 /for(i=0;i0;i-)/用数码管控制熄灭的时间3S IOWR(SEG7_LUT_8_0_BASE,0,count); usleep(j); count=count-0x10000000; IOWR(SEG7_LUT_8_0_BASE,0,count); return 0;1. 添加自定义组件七段数码管控制器 SEG7_LUT.V 是一个查找表,完成七段码显示的译码。当输入iDIG在0x00xF 之间变化时,输出oSEG 的七段码也发生相应的变化,并在数码管上显示

16、iDIG 的值。代码1 SEG7_LUT.Vmodule SEG7_LUT ( oSEG, iDIG);input 3:0 iDIG;output 6:0 oSEG;reg 6:0 oSEG;always(iDIG)begin case(iDIG) 4h1:oSEG=7b1111001; 4h2:oSEG=7b0100100; 4h3:oSEG=7b0110000; 4h4:oSEG=7b0011001; 4h5:oSEG=7b0010010; 4h6:oSEG=7b0000010; 4h7:oSEG=7b1111000; 4h8:oSEG=7b0000000; 4h9:oSEG=7b0011

17、000; 4ha:oSEG=7b0001000; 4hb:oSEG=7b0000011; 4hc:oSEG=7b1000110; 4hd:oSEG=7b0100001; 4he:oSEG=7b0000110; 4hf:oSEG=7b0001110; 4h0:oSEG=7b1000000; endcaseendendmoduleSEG7_LUT_8.V,对SEG7_LUT.V 进行了8 次例化,分别对应于七段数码管HEX0HEX7。代码2 SEG7_LUT_8.Vmodule SEG7_LUT_8 (oSEG0,oSEG1,oSEG2,oSEG3,oSEG4,oSEG5,oSEG6,oSEG7, iDIG,iWR,iCLK,iRST_N);input 31:0 iDIG;input iWR,iCLK,iRST_N;output 6:0 oSEG0,oSEG1,oSEG2,oSEG3,oSEG4,oSEG5,oSEG6,oSEG7;reg 31:0 rDIG;always(posedge iCLK or negedge iRST_N)begin if(!iRST_N) rDIG = 0; el

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论