DSP实验报告.doc_第1页
DSP实验报告.doc_第2页
DSP实验报告.doc_第3页
DSP实验报告.doc_第4页
DSP实验报告.doc_第5页
免费预览已结束,剩余27页可下载查看

下载本文档

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

文档简介

dsp实验报告 班 级:电 信 073班 实 验 者: 同实验者:电气与信息工程学院 实验一 i/o实验实验目的:熟悉szdspii实验平台的使用;了解dsp对i/o口的访问方式;熟悉简单的程序设计及指令运用。实验设备:计算机;dsp硬件仿真器;dsp实验开发平台。实验硬件设置:在做实验以前,需要接通该实验的硬件电路,本实验为:先将实验箱右侧的船型开关往“i”方向打开电源,然后将系统主板的开关s33往下拨接通+/-5v电源,然后将cpld/fpga模块上的电源开关s9往下(on)拨,开关s10往下拨来选通主板上发光二极管等输出指示设备;将系统主板中“mcu/dsp选择档”选中mcu(往下拨),将“功能键7”拨上去,电击键盘中的rst键,mcu将对所有发光二极管进行检测,如果所有的发光二极管正常,则将“mcu/dsp选择挡”选中dsp,将功能键1到7都拨下来。然后开始做实验,注意在做实验时开始按了rst硬件复位后,实验不要再按rst键,以免由于dsp复位而失败。如果实验中硬件工作不正常,可按rst对整个系统硬件进行复位。实验原理:本程序主要是实现将数据往一个i/o端口送,从而显示一种状态,来验证dsp对i/o口的访问。该实验是由dsp直接编程,往发光二极管送数,运用portw指令,观察发光二极管的变化,从而完成基本的i/o实验。硬件框图dspcpld锁存8个指示灯d8-d15高八位数据指示灯的片选1002h实验程序框图开始dsp初始化dsp送出不同的数据输出到1002h实验程序.title ex9.global _c_int00.mmregsfg_addr .set 1002h data.set60h ;double ram data.sect .vectorsreset:b _c_int00nopnop.space 31*4*16 delay.macro sec_tenth;延时 sec_tenth/10 秒stm sec_tenth-1,ar5loop1?stm #09h,ar6loop0?stm #19999,ar7banz $,*ar7-banz loop0?,*ar6-banz loop1?,*ar5-.endm.text_c_int00:ld #0h,dpstm #3000h,sprsbx intmstm #07fffh,swwsr ssbx xf ;xf=1 st #1007h,clkmd;工作在20mhzrpt #0ffhnop stm #0ffffh,ifrorm #000h,imrrsbx sxmst #8100h,data wrdeng: portwdata,fg_addr delay#10 nop st #4200h,data portwdata,fg_addr delay#10 st #2400h,data portwdata,fg_addr delay#10 st #1800h,data portwdata,fg_addr delay#10 st #1800h,data portwdata,fg_addr delay#10 rpt #10 nop st #2400h,data portwdata,fg_addr delay#10 rpt #10 nop st #4200h,data portwdata,fg_addr delay#10 rpt #10 nop st #8100h,data portwdata,fg_addr delay#10 rpt #10 nop stm #00h,data ; portwdata,fg_addr delay#10 nop st #100h,data portwdata,fg_addr delay#10 st #200h,data portwdata,fg_addr delay#10 st #400h,data portwdata,fg_addr delay#10 st #800h,data portwdata,fg_addr delay#10 rpt #10 nop st #1000h,data portwdata,fg_addr delay#10 rpt #10 nop st #2000h,data portwdata,fg_addr delay#10 rpt #10 nop st #4000h,data portwdata,fg_addr delay#10 rpt #10 nop stm #8000h,data portwdata,fg_addr delay#10 rpt #10 nop ; st #8000h,data portwdata,fg_addr delay#10 st #4000h,data portwdata,fg_addr delay#10 st #2000h,data portwdata,fg_addr delay#10 st #1000h,data portwdata,fg_addr delay#10 rpt #10 nop st #800h,data portwdata,fg_addr delay#10 rpt #10 nop st #400h,data portwdata,fg_addr delay#10 rpt #10 nop st #200h,data portwdata,fg_addr delay#10 rpt #10 nop stm #100h,data portwdata,fg_addr delay#10 rpt #10 nop st #8100h,data b wrdengaaa nop b aaa .end 思考题:有哪三种以上的寻址方式可以完成上述实验?并描述其原理。答:共有以下四种寻址方式可以完成上述实验:绝对寻址绝对寻址利用16位地址寻址存储单元,其特点是指令中包含一个固定地址。16位地址可以用其地址标号或程序中定义的符号常数来表示。由于绝对地址代码的位数为16位,所以绝对地址寻址的指令至少为2个字长累加器寻址累加器寻址是将累加器的内容作为地址去访问程序存储单元,即将尅假期中的数作为地址,用来对存放数据的程序存储器寻址。直接寻址直接寻址是利用数据指针和堆栈指针寻址,其特点是数据存储器地址由基地址和偏移地址共同构成,共16位。基地址位于数据存储器地址的高9位,偏移地址位于数据存储器地址的低7位。间接寻址间接寻址是利用辅助寄存器内容作为地址指针访问存储器。tms320c54x有8个16位辅助寄存器(ar0ar7)。每一个寄存器都可以用来寻址64千字数据存储空间中任何一个单元。两个辅助存储器算术运算单元(arau0和arau1)可以根据辅助寄存器的内容进行操作,完成16位无符号数算术运算。实验二 数码显示实验一、实验目的熟练掌握dsp的各种指令;进一步熟悉dsp的i/o访问方式的操作,通过i/o方式将数据显示到数码管上。二、实验设备计算机,dsp硬件仿真器,dsp实验开发平台。注意:在做实验以前,需要接通该实验的硬件电路,本实验为:先将实验箱右侧的船型开关往“i”方向打开电源,然后将系统主板的开关s33往下拨接通+/-5v电源,然后将cpld/fpga模块上的电源开关s9往下(on)拨,开关s10往下拨来选通主板上发光二极管等输出指示设备;将系统主板中“mcu/dsp选择档”选中mcu(往下拨),将“功能键6”拨上去,点击键盘中的mon键,mcu将对所用的led管进行检测。如果所有的led管正常,将“mcu/dsp选择档”选中dsp(往上拨),将功能键1到7都拨下来,然后开始做实验。注意在做实验时开始按了rst硬件复位后,实验不要再按rst键,以免由于dsp复位而失败。三、实验原理 此实验是由dsp通过io方式对数码管进行操作,即是向数码管送数据,高4位为数码管的段码,低4位为数码管的位码,dsp用的数据线是d8d15,如要在第0位显示一个8,就只要送入80h,其次,该实验中要求熟练运用dsp的各种指令,能使显示数据出现左移或右移等。四、实验程序框图开始初始化dsp,设置i/o等待寄存器将内存中的数据或采用其他方式将数据发送到数码管去显示,其i/o地址为:1003h。具体显示方法见上述实验原理。改变数据重复发送实验程序:.title ex9.global _c_int00.mmregssm_addr .set 1003h ;数码管的i/o地址sm_data.set60h ;段码在数据线的高4位,位码在数据线的次高4位.;在cpld模块中程序为demo程序的情况下,段码显示已译码,比如:要显示7,;只要往数据线的高4位发7即可.位码为0-7,在次高位数据线对应的数值也为0-7.sect .vectorsreset:b _c_int00nopnop.space 31*4*16 .text_c_int00:ld #0h,dp ;设置数据页指针stm #2000h,sp ;设置堆栈指针rsbx intmstm #07fffh,swwsr ssbx xf st #1007h,clkmd;工作在20mhzrpt #0ffhnop stm #0ffffh,ifrorm #000h,imrrsbx sxmaaa nop call led07 ;显示0到7 call led8f ;显示8到f b aaaled8f st #8000h,sm_data st #07h, ar3wrdeng: portwsm_data,sm_addr ;8-f rpt #10000 nop st #02fffh,ar6 call delay addm #1100h,sm_data ;送位码,屏蔽低8位数据 banz wrdeng, *ar3- retled07 nop st #07h, ar3 stm #0h,sm_datawrdeng1 nop ;0-7 portw sm_data,sm_addr st #02fffh,ar6 call delay addm #1100h,sm_data ;送位码,屏蔽低8位数据 banz wrdeng1, *ar3- retdelaystm #0f0h,ar7;延时子程序banz $,*ar7-banz delay,*ar6- ret五、实验思考如何设置dp、sp值,以及dp、sp在程序中所起的作用是什么?如何理解、设置i/o等待寄存器?答:dp为状态寄存器0(st0)中的9位数据存储器页指针,sp为堆栈指针。可通过装载指令ld设置dp,通过存储指令stm设置sp。当程序调用子程序时,需要将程序计数器pc的值和一些重要的寄存器值进行压栈保护,以便程序返回时能从间断处继续执行。通过设置dp,sp可完成。为了方便地使c54x与慢速的片内存储器和i/o接口,可以通过软件可编程来延长等待周期,最多可达到7-14个机器周期,i/o空间复位值为111b。实验三、交通灯实验一、实验目的了解数据输出程序的设计方法;模拟交通灯控制, 能正确的模拟交通灯。运用定时中断二、实验设备计算机,dsp硬件仿真器,dsp实验开发平台。注意:在做实验以前,需要接通该实验的硬件电路,本实验为:先将实验箱右侧的船型开关往“i”方向打开电源,然后将系统主板的开关s33往下拨接通+/-5v电源,然后将cpld/fpga模块上的电源开关s9往下(on)拨,开关s10往下拨来选通主板上双色发光二极管(交通灯)等输出指示设备;将系统主板中“mcu/dsp选择档”选中mcu(往下拨),将“功能键7”拨上去,点击键盘中的rst键,mcu将对所用发光二极管进行检测,如果所有的双色发光二极管正常,则将“mcu/dsp选择挡”选中dsp(往上拨),将功能键1到7都拨下来。然后开始做实验,注意在做实验时,开始按了rst硬件复位后,实验中不要再按rst键,以免由于dsp复位而失败。如果实验中硬件工作不正常,可按rst对整个系统硬件进行复位。三、实验原理及说明掌握dsp的定时器、i/o访问原理,用i/o口控制红绿黄灯的开关。四、实验程序框图 开始 初始化dsp全部红灯延时1秒南北绿灯、东西红灯,延时20秒南北绿灯闪3次、东西红灯南北黄灯、东西红灯延时3秒南北红灯、东西绿灯闪3次南北红灯、东西绿灯20秒延时20秒南北红灯、东西黄灯延时3秒 实验程序.title ex8.global _c_int00.mmregsled_addr.set1001hstatus0 .set 60h status1 .set 61hstatus2 .set 62hstatus3 .set 63hstatus4 .set 64hsta2_pre_0 .set 65hsta2_pre_1 .set 66hsta4_pre_0 .set 67hsta4_pre_1 .set 68hdelay.macro sec_tenth;延时 sec_tenth/10 秒stm sec_tenth-1,ar5loop1?stm #09h,ar6loop0?stm #19999,ar7banz $,*ar7-banz loop0?,*ar6-banz loop1?,*ar5-.endm.sect .vectorsreset:b _c_int00nopnop.space 4*127.text_c_int00ld #0h,dpstm #3000h,spssbx intmssbx sxmstm #07fffh,swwsr;io总线外部等待时间14个周期stm #0h,clkmd;20mhz工作tstbitf clkmd,#1hbc tst,tcstm #1007h,clkmdrpt #0ffhnopst #0ffffh,ifrorm #000h,imr st #0aa00h,status0loopbportw status0,led_addr;全部红灯delay #100;延时1秒circlest #6600h,status1portw status1,led_addr;南北红灯、东西绿灯 delay #200;延时20秒stm #2h,brc rptb flash1 st #6600h, sta2_pre_0 portw sta2_pre_0,led_addr delay #30st #2200h,sta2_pre_1 portw sta2_pre_1,led_addr delay #30flash1nop;南北绿灯闪3次、东西红灯st #0ee00h, status2portw status2,led_addr;南北黄灯、东西红灯delay #30;延时3秒 st #9900h,status3portw status3,led_addr;南北红灯、东西绿灯delay #200;延时20秒stm #2h,brcrptb flash2st #09900h, sta4_pre_0portw sta4_pre_0,led_addrdelay #30st #08800h,sta4_pre_1portw sta4_pre_1,led_addrdelay #30;南北红灯、东西绿灯闪3次flash2nopst #0bb00h,status4portw status4,led_addr;南北红灯、东西黄灯delay #30;延时3秒 b circle .end六、实验思考如果在程序运行过程中遇到硬件中断,如何保护保持原有的现场?答:将程序计数器pc值(返回地址)保存到数据存储器的堆栈顶部。在中断响应时,程序计数器扩展寄存器(xpc)不会压入堆栈的顶部,也就是说,它不会保存在堆栈中。因此,如果isr位于和中断向量表不同的页面,用户必须在分支转移到isr之前将xpc压入堆栈,远程返回指令fret(e)可以用于从isr返回。实验四、同步串口一、实验目的了解同步串口工作原理;了解ad50工作原理。二、实验设备计算机,dsp硬件仿真器,dsp实验开发平台,耳机,麦克风。注意:在做实验以前,需要接通该实验的硬件电路,本实验为:先将实验箱右侧的船型开关往“i”方向打开电源,然后将系统主板的开关s33往下拨接通+/-5v电源,然后将cpld/fpga模块上的电源开关s9往下(on)拨。 三、实验要求通过dsp的同步串口能向ad50发送控制字和数据,接收ad50发送的数据。四、实验原理及说明同步串口实验,主要是通过5402的同步串口访问a/d芯片,使学生了解同步串口工作原理。该实验所需的硬件主要是dsp、dram、tms320ad50、tlc2272,在实验过程中如果tlc320ad50c工作不正常,请按复位键(mon键或rst)对实验仪器硬件复位。编写dsp同步串口程序访问ad50,将麦克风的语音信号经过tlc2272(双路低噪声)滤波,通过ad50的a/d转换后,将模拟信号转换为数字信号,再将数字信号发送到ad50的d/a端口。将麦克风(红色)插入语音输入插座,耳机(黑色)插入语音输出插座。运行程序。要在耳机里听到麦克风所输入的声音。五、实验程序框图开始初始化dsp初始化mcbsp与ad50进行二次通讯设置a/d通道参数打开中断等待mcbsp中断信号开始接收adc通道采样数据把接收到的数据在反馈到dac通道结束中断服务程序等待下一次中断中断服务程序实验程序:.title ex4bsp.set0;当前使用mcbsp1;mcbsp 内存映射寄存器spsa0.set 038hspsd0.set 039hdrr10.set 021hdrr20.set020hdxr10.set 023hdxr20.set022hspsa1.set 048hspsd1 .set 049hdrr11 .set041hdrr21 .set 040hdxr11 .set 043hdxr21 .set042h;mcbsp subaddressed registersspcr1.set00hspcr2.set01hrcr1.set02hrcr2.set03hxcr1.set04hxcr2.set05hsrgr1.set06hsrgr2.set07hmcr1.set08hmcr2.set09hrcera.set0ahrcerb.set0bhxcera.set0chxcerb.set0dhpcr.set0eh.if bsp = 0spsa.setspsa0spsd.setspsd0rdrr.setdrr10rdxr.setdxr10.endif.if bsp = 1spsa.setspsa1spsd.setspsd1rdrr.setdrr11rdxr.setdxr11.endifwr_sub_reg.macro val,addr;写mcbsp控制寄存器stm addr,spsanopstm val,spsdnop.endmrd_sub_reg.macro addr,acc;读mcbsp控制寄存器stm #:addr:,spsanopldm spsd,accnopnopnop.endmwaittrx .macro;等待串口中断waitr? rd_sub_reg spcr1,a and #11, a bc waitr?, aeq .endmprogreg .macro progword;与ad50二次通讯 stm #01h,rdxr waittrx stm #:progword:,rdxr waittrx .endm wait .macro stm #0008h, ar0rpt *ar0nop.endm .mmregs.global _c_int00.sect .vectorsresetbd _c_int00stm #2000h,sp.space 19*4*16brint0b recvnopnopbxint0b transnopnop.space 10*4*16;brint1b recv;nop;nop;bxint1b trans;nop;nop;.space 4*4*16.text_c_int00ld #0h,dpstm #2000h,spssbx intmssbx sxm st #2491h,swwsr st #0ffe0h,pmst st #0f007h,clkmd stm #4000h,ar1 stm #4000h,ar2 mcbsp_init;初始化mcbsp串口 rsbx cpl nop; cpl latency nop; cpl latencynop; cpl latencyld #0, dp ssbx intm ssbx sxm wr_sub_reg #0000h,spcr1wr_sub_reg #0200h,spcr2wr_sub_reg #000ch,pcrwr_sub_reg #0000h,spcr1wr_sub_reg #0000h,spcr2wr_sub_reg #0040h,rcr1;16 bitswr_sub_reg #0004h,rcr2;ignore fs after the firstwr_sub_reg #0040h,xcr1;16 bitswr_sub_reg #0004h,xcr2;ignore fs after the firstld 100,awaitandm #0ff3fh, 54h;set interrupts to come from serial ports not dma;by clearing bits 6 and 7 in dmprecstm #0,rdxrwr_sub_reg #0001h,spcr1;启动mcbsp串口wr_sub_reg #0201h,spcr2ld 100,awaitaic_initstm #0h,imrorm #030h,imrstm #0ffffh,ifr progreg 0000001100000001b ; 876543210 progreg 0000010000010000b ; 876543210;progreg 0104h;二次通讯初始化ad50;progreg 0280h;progreg 0301h;progreg 045ah;progreg 0000001100000001b ; 876543210 ;progreg 0000010000010000b ; 876543210ld rdrr,ald rdrr,astlm a,rdxrstlm a,rdxrrsbx intmnopnopnopjsnopnopnopb jsrecvldm rdrr,a;adc采样数据发送到dac输出and #0fffeh,a;and #8000h,astlm a,rdxrretetransrsbx xfrete.end六、实验思考:参考下面的这段程序,如何理解 dsp的中断向量表?.set”.vectors”reset bd_c_int00 stm #2000h,sp .space 19*4*16brint0 b recv nop nopbrint0 b trans nop nop .space 10*4*16答:中断服务程序的地址(中断向量)要装载到存储器的合适区域。一般这些向量都定位在0x0开始的程序存储器中。但有些处理器要求或者可以在其他的存储区域安装中断向量。 对于微处理器模式下的tms320c25、tms320c26、tms320c28、tms320c30、tms320c31,中断向量定位于0x0开始的地址。对于微计算机/程序引导模式下的tms320c31的中断向量定位于0x809fc1,tms320c26的中断向量定位于0xffa0。 tms320c5x复位向量定位在0x0,其他中断向量可以定位于任何2k字的程序存储器中,中断向量表的定位是与pmst寄存器的iptr位有关,有效的中断向量表的基地址是0x0,0x800,0x1000,0x1800,0x2000,0xf800。 tms320c4x的复位向量定位在四个地址之一,这四个地址由外部引脚resetloc0和resetloc1决定。tms320c4x的中断向量可存在于任何512字范围的存储器中,中断向量表的地址由中断向量表指针(ivtp)寄存器决定。另外,tms320c4x的自陷(trap)中断向量可存放在512字范围的存储器中,自陷向量表的地址由自陷向量表指针(tvtp)寄存器决定。有效的中断或者自陷向量表的基地址是0x0,0x200, 0x400,0x800,0xa00,0xc00,0xe00,0x1000,0x12000xfffffe00实验五、fir滤波器实验一、实验原理熟悉数字滤波的基本原理和实现方法二、实验设备计算机,dsp硬件仿真器,dsp实验开发平台,耳机,麦克风三、实验原理及说明该实验主要是通过ad50采集音频信号,数据通过同步串口传送给dsp,用数字滤波,对信号进行处理,然后再通过ad50对信号回放,把加滤波和不加滤波的回放声音进行比较。将麦克风(红色)插入语音输入插座,耳机(黑色)插入语音输出插座。运行程序。要在耳机里听到滤波后的声音。四、实验程序框图开 始初始化dsp初始化80阶fir滤波参数初始化mcbsp接口与ad50进行二次通讯打开中断等待mcbsp中断信号开始接收adc通道采样数据把接收到的数据经过80阶fir滤波后再反馈到dac通道结束中断服务程序等待下一次中断中断服务程序实验程序:* filename:ex10.asm * description:滤波器实验lowpass 01000hz * copyright(c) sanzhi electronic, author ly *.title ex10bsp.set0;当前使用mcbsp1;mcbsp 内存映射寄存器spsa0.set 038hspsd0.set 039hdrr10.set 021hdrr20.set020hdxr10.set 023hdxr20.set022hspsa1.set 048hspsd1 .set 049hdrr11 .set041hdrr21 .set 040hdxr11 .set 043hdxr21 .set042hspsa2 .set 034hspsd2 .set 035hdrr12 .set 031hdrr22 .set030hdxr12 .set 033hdxr22 .set032h;mcbsp subaddressed registersspcr1.set00hspcr2.set01hrcr1.set02hrcr2.set03hxcr1.set04hxcr2.set05hsrgr1.set06hsrgr2.set07hmcr1.set08hmcr2.set09hrcera.set0ahrcerb.set0bhxcera.set0chxcerb.set0dhpcr.set0eh.if bsp = 0spsa.setspsa0spsd.setspsd0rdrr.setdrr10rdxr.setdxr10imask.set0010h.endif.if bsp = 1spsa.setspsa1spsd.setspsd1rdrr.setdrr11rdxr.setdxr11imask.set0400h.endif;fin_flag.set 64h.asg ar0,fir_index_p.asg ar4,fir_data_p.asg ar5,fir_coff_pwr_sub_reg.macro val,addr;写mcbsp控制寄存器stm addr,spsanopstm val,spsdnop.endmrd_sub_reg.macro addr,acc;读mcbsp控制寄存器stm #:addr:,spsanopldm spsd,accnopnopnop.endmwaittrx .macro;等待串口中断waitr? rd_sub_reg spcr1,a and #11, a bc waitr?, aeq .endmprogreg .macro progword;与ad50二次通讯 stm #01h,rdxr waittrx stm #:progword:,rdxr waittrx .endm wait .macro stm #0008h, ar2rpt *ar2nop.endm .mmregs .global _c_int00 .sect .vectorsresetb _c_int00nopnop.space 19*4*16brint0b recvnopnopbxint0b transnopnop.space 10*4*16k_fir_bffr.set 80coff_fir_table.sect coff_firh0 .word 0 h1 .word -157 h2 .word -261 h3 .word -268 h4 .word -170 h5 .word 0 h6 .word 180 h7 .word 301 h8 .word 310 h9 .word 198 h10 .word 0 h11 .word -211 h12 .word -354 h13 .word -367 h14 .word -236 h15 .word 0 h16 .word 255 h17 .word 431 h18 .word 451 h19 .word 292 h20 .word 0 h21 .word -323 h22 .word -551 h23 .word -584 h24 .word -383 h2

温馨提示

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

评论

0/150

提交评论