ImageVerifierCode 换一换
你正在下载:

DSP_C.doc

[预览]
格式:DOC , 页数:9 ,大小:14.73KB ,
资源ID:3180166      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3180166.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(DSP_C.doc)为本站会员(11****ws)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

DSP_C.doc

1、#include “DSP2833x_Device.h“ / DSP2833x Headerfile Include File#include “DSP2833x_Examples.h“ / DSP2833x Examples Include File#if (CPU_FRQ_150MHZ) / Default - 150 MHz SYSCLKOUT#define ADC_MODCLK 0x3 / HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 150/(2*3) = 25.0 MHz#endif#if (CPU_FRQ_100MHZ)#define ADC_MODCLK

2、 0x2 / HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 100/(2*2) = 25.0 MHz#endif#define ADC_CKPS 0x1 / ADC module clock = HSPCLK/2*ADC_CKPS = 25.0MHz/(1*2) = 12.5MHz#define ADC_SHCLK 0xf / S/H width in ADC module periods = 16 ADC clocks#define AVG 1000 / Average sample limit#define ZOFFSET 0x00 / Average Zero o

3、ffset#define BUF_SIZE 160 / Sample buffer sizeUint16 j = 0,ADC_END = 0; / ADC finish flag#pragma DATA_SECTION(ADC_Result,“DMARAML4“);volatile float ADC_Result160;#pragma DATA_SECTION(DMABuf1,“DMARAML4“);volatile Uint16 DMABuf1160;volatile Uint16 *DMADest;volatile Uint16 *DMASource;interrupt void loc

4、al_DINTCH1_ISR(void);void main(void)Uint16 i;/ Step 1. Initialize System Control:/ PLL, WatchDog, enable Peripheral Clocks/ This example function is found in the DSP2833x_SysCtrl.c file.InitSysCtrl();/ Specific clock setting for this example:EALLOW;SysCtrlRegs.HISPCP.all = ADC_MODCLK; / HSPCLK = SYS

5、CLKOUT/ADC_MODCLKEDIS;/ Step 2. Initialize GPIO:/ This example function is found in the DSP2833x_Gpio.c file and/ illustrates how to set the GPIO to its default state./ InitGpio(); / Skipped for this example/ Step 3. Clear all interrupts and initialize PIE vector table:/ Disable CPU interruptsDINT;/

6、 Initialize the PIE control registers to their default state./ The default state is all PIE interrupts disabled and flags/ are cleared./ This function is found in the DSP2833x_PieCtrl.c file.InitPieCtrl();/ Disable CPU interrupts and clear all CPU interrupt flags:IER = 0x0000;IFR = 0x0000;/ Initiali

7、ze the PIE vector table with pointers to the shell Interrupt/ Service Routines (ISR)./ This will populate the entire table, even if the interrupt/ is not used in this example. This is useful for debug purposes./ The shell ISR routines are found in DSP2833x_DefaultIsr.c./ This function is found in DS

8、P2833x_PieVect.c.InitPieVectTable();/ Interrupts that are used in this example are re-mapped to/ ISR functions found within this file.EALLOW; / Allow access to EALLOW protected registersPieVectTable.DINTCH1= EDIS; / Disable access to EALLOW protected registersIER = M_INT7 ; /Enable INT7 (7.1 DMA Ch1

9、)EnableInterrupts();/ Step 4. Initialize all the Device Peripherals:/ This function is found in DSP2833x_InitPeripherals.c/ InitPeripherals(); / Not required for this exampleInitAdc(); / For this example, init the ADC/ Specific ADC setup for this example:AdcRegs.ADCTRL1.bit.ACQ_PS = ADC_SHCLK;AdcReg

10、s.ADCTRL3.bit.ADCCLKPS = ADC_CKPS;AdcRegs.ADCTRL1.bit.SEQ_CASC = 1; / 0 Non-Cascaded Mode; 1 Cascaded ModeAdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0x1;AdcRegs.ADCTRL2.bit.RST_SEQ1 = 0x1;AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0;AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1;AdcRegs.ADCCHSELSEQ1.bit.CONV02 = 0x2;AdcReg

11、s.ADCCHSELSEQ1.bit.CONV03 = 0x3;AdcRegs.ADCCHSELSEQ2.bit.CONV04 = 0x4;AdcRegs.ADCCHSELSEQ2.bit.CONV05 = 0x5;AdcRegs.ADCCHSELSEQ2.bit.CONV06 = 0x6;AdcRegs.ADCCHSELSEQ2.bit.CONV07 = 0x7;AdcRegs.ADCCHSELSEQ3.bit.CONV08 = 0x8;AdcRegs.ADCCHSELSEQ3.bit.CONV09 = 0x9;AdcRegs.ADCCHSELSEQ3.bit.CONV10 = 0xA;Ad

12、cRegs.ADCCHSELSEQ3.bit.CONV11 = 0xB;AdcRegs.ADCCHSELSEQ4.bit.CONV12 = 0xC;AdcRegs.ADCCHSELSEQ4.bit.CONV13 = 0xD;AdcRegs.ADCCHSELSEQ4.bit.CONV14 = 0xE;AdcRegs.ADCCHSELSEQ4.bit.CONV15 = 0xF;AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 15; / Set up ADC to perform 4 conversions for every SOC/Step 5. User specific

13、 code, enable interrupts:/ Initialize DMA DMAInitialize();/ Clear Tablefor (i=0; iBUF_SIZE; i+)DMABuf1i = 0xffff;/ Configure DMA ChannelDMADest = /Point DMA destination to the beginning of the arrayDMASource = /Point DMA source to ADC result register baseDMACH1AddrConfig(DMADest,DMASource);DMACH1Bur

14、stConfig(15,1,10);DMACH1TransferConfig(9,-15,(-150 + 1);DMACH1WrapConfig(100,100,100,100); /Dont use wrap functionDMACH1ModeConfig(DMA_SEQ1INT,PERINT_ENABLE,ONESHOT_DISABLE,CONT_DISABLE,SYNC_DISABLE,SYNC_SRC,OVRFLOW_DISABLE,SIXTEEN_BIT,CHINT_END,CHINT_ENABLE); StartDMACH1();/ Start SEQ1AdcRegs.ADCTR

15、L2.bit.SOC_SEQ1 = 0x1;for(i=0;i10;i+)for(j=0;j1000;j+)AdcRegs.ADCTRL2.bit.SOC_SEQ1 = 1; /Normally ADC will be tied to ePWM, or timed routine /For this example will re-start manually / Waiting ADC finishwhile(!ADC_END);/ Translate DMABuf to ADC_Resultfor (i=0; iBUF_SIZE; i+)ADC_Resulti = (float)DMABuf1i * 3.0 / 4096.0;asm (“ ESTOP0“);for(;);/ INT7.1interrupt void local_DINTCH1_ISR(void) / DMA Channel 1/ To receive more interrupts from this PIE group, acknowledge this interrupt PieCtrlRegs.PIEACK.all = PIEACK_GROUP7;ADC_END = 1;

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。