微机原理实验四DA.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
微机原理实验四DA

微机原理实验四串行IO接口实验姓名:英俊哥学号:班级:实验目的理解UART串行通信协议以及接口设计理解SPI串行通信协议掌握UART串行接口设计掌握SPI串行接口设计(DA、AD串行接口设计)实验任务Nexys4开发板通过外界SPIDA模块,实现DA转换,利用DAC121S101DA转换芯片,基于SPI总线控制其Dout输出锯齿波。扩展周期可调输出电压可调输出其他波形,如正弦波,三角波等硬件电路框图硬件平台建立过程使用XPS创建一个基于AXI总线的最小计算机系统。配置相关参数,选择处理器频率、BRAM大小为32KB,并增加串口作为标准输入输出接口。创建最小系统的基本操作如前面的实验。硬件平台要求加入中断控制器课SPI总线接口,如下图所示,在IP Catalog中添加AXI Interrupt Controller,采用默认设置。加入AXI SPI接口控制器如下图所示,选择AXI SPI。由于该SPI接口仅需要输出数据,而且一次传输需要16位数据,一个从设备,且D/A转换芯片要求SCLK最高速率30MHz,由于AXI总线频率为100MHz,因此分频比为4,此时SCLK的频率为25MHz。具体SPI端口连接配置下图所示。External Ports 如下:配置UCF,分配物理引脚如下图所示。软件平台建立建立一个BSP文件,再建立一个新的空工程,将源码加入新的c源文件中。下载并运行该工程,将示波器探针连接到J2的1脚,可看到锯齿波的波形。C源码如下:* SPIDA1.c * * Created on: 2015-12-8 * Author: hn_wu_000 */#include xparameters.h /*XPAR parameters*/#include xspi.h /*SPI device driver*/#include xintc.h /*Interrupt controller device drive*/#include xil_exception.h#define BUFFER_SIZE 2void SpiIntrHandler(void *CallBackRef,u32 StatusEvent,u32 ByteCount);//用户定义的SPI中断服务程序static XIntc IntcInstance;static XSpi SpiInstance;volatile int TransferInProgress;//中断结束状态标志int Error;u8 ReadBuffer[BUFFER_SIZE];u8 WriteBuffer[BUFFER_SIZE];int main(void){ int Status,Count; Status=XSpi_Initialize(SpiInstance,XPAR_SPI_0_DEVICE_ID); Status=XIntc_Initialize(IntcInstance,XPAR_INTC_0_DEVICE_ID); Status=XIntc_Connect(IntcInstance,XPAR_INTC_0_SPI_0_VEC_ID,(XInterruptHandler)XSpi_InterruptHandler,(void *)SpiInstance); Status=XIntc_Start(IntcInstance,XIN_REAL_MODE); XIntc_Enable(IntcInstance,XPAR_INTC_0_SPI_0_VEC_ID); microblaze_register_handler((XInterruptHandler)XIntc_InterruptHandler,IntcInstance); microblaze_enable_interrupts(); //设置SPI接口用户中断服务函数 XSpi_SetStatusHandler(SpiInstance,SpiInstance,(XSpi_StatusHandler)SpiIntrHandler); //设置SPI接口工作模式 Status=XSpi_SetOptions(SpiInstance,XSP_MASTER_OPTION|XSP_CLK_PHASE_1_OPTION); //设置从设备选择信号 Status=XSpi_SetSlaveSelect(SpiInstance,1); //使能SPI接口 XSpi_Start(SpiInstance); //循环输出数据到SPI接口控制DAC输出锯齿波 while(1)

文档评论(0)

shenlan118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档