DSP28335模块配置模板系列——ADC配置模板

2024-06-06 22:12

本文主要是介绍DSP28335模块配置模板系列——ADC配置模板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、配置步骤

1.使能并配置高速时钟HSPCLK、ADC校验

	EALLOW;SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;    EDIS;EALLOW;SysCtrlRegs.HISPCP.all = ADC_MODCLK;	// HSPCLK = SYSCLKOUT/(2*ADC_MODCLK)ADC_cal();EDIS;

这里ADC_MODCLK=3,所以HSPCLK时钟为150/6=25Mhz

2.配置ADC时钟并给ADC上电

AdcRegs.ADCTRL3.all = 0x00E0;
AdcRegs.ADCTRL1.bit.CPS= 0;

ADCTRL3寄存器的5-7位置1表示内部带隙与参考电路上电和其他模拟电路上电;

4-1位置0表示不对HSPCLK进行分频,0位置0表示顺序采样模式;

ADCTRL1的CPS位置0表示不对HSPCLK进行分频,具体的ADCCLK计算公式由以下给出:

ADCCLK=\frac{SYSCLK}{HISPCP*2^{ ADCTRL3[4:1]}*(CPS+1))}

所以这里的ADCCLK被配置为150/6=25Mhz

3.配置ADC模块的工作方式

SEQ_CASCSMODE_SELCONT_RUNSEQ_OVRD
双序列发生器模式顺序采样连续自动序列化模式固定长度循环模式
单序列发生器模式/级联模式并发采样启动/停止模式自然结束循环模式

这里配置ADC模块的工作模式为双序列发生器模式、顺序采样、连续自动序列化模式、自然结束循环模式:

AdcRegs.ADCTRL1.bit.SEQ_CASC = 0;
AdcRegs.ADCTRL3.bit.SMODE_SEL=0;
AdcRegs.ADCTRL1.bit.CONT_RUN = 1; 
AdcRegs.ADCTRL1.bit.SEQ_OVRD = 1; 

至于如何选择ADC模块的工作方式,需要根据实际情况选择,若采样通道不大于8个可以使用双序列发生器模式、顺序采样,这里比较重要的一点是分清楚连续自动序列化模式和启动/停止模式之间的区别。

        当选择连续自动序列化模式且选择自然结束循环模式时,序列发生器完成一个序列的转换时,转换序列将自动重复开始,且不需要等到SOC信号的到来,所以使用连续自动序列化模式时,只需要触发一次SOC信号用于启动第一个转换序列即可,之后的每个序列转换将自动进行,而不需要额外的SOC信号触发。

        当选择启动/停止模式时,序列发生器完成一个序列的转换后,状态指针停留在当前转换的状态,手动复位序列发生器后,状态指针才会重新指向初始位置,且需要等待SOC信号到来才会开始转换。

        实际应用中,如果采用软件触发SOC则需要搭配连续自动序列化模式使用,如果采用Epwm周期性触发SOC则需要搭配启动/停止模式使用。

4.配置序列发生器的最大采样通道数和采样顺序

        这里以采样A0-A7八个通道为例,按A0、A1、A2、...、A7的顺序采样:

  AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 0x7;AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0; // 采样ADCA0AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1; // 采样ADCA1AdcRegs.ADCCHSELSEQ1.bit.CONV02 = 0x2; // 采样ADCA2AdcRegs.ADCCHSELSEQ1.bit.CONV03 = 0x3; // 采样ADCA3AdcRegs.ADCCHSELSEQ2.bit.CONV04 = 0x4; // 采样ADCA4AdcRegs.ADCCHSELSEQ2.bit.CONV05 = 0x5; // 采样ADCA5AdcRegs.ADCCHSELSEQ2.bit.CONV06 = 0x6; // 采样ADCA6AdcRegs.ADCCHSELSEQ2.bit.CONV07 = 0x7; // 采样ADCA7

5.选择SOC触发方式

         对于两个序列发生器SEQ1、SEQ2,启动方式有以下几种:

SEQ1SEQ2
软件立即启动(S/W)软件立即启动(S/W)
ePWMx SOCAePWMx SOCB

以软件启动且搭配连续自动序列化模式为例:

AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;//软件启动方式

 epwm触发:

AdcRegs.ADCTRL2.bit.EPWM_SOCA_SEQ1 = 1;

6.配置ADC中断 

        根据需要可以选择是否配置ADC中断,这里需要在采样完成A7后发送中断申请,所以禁止SEQ1发送中断申请,允许SEQ2发送中断申请,配置步骤如下:

	EALLOW;  PieVectTable.ADCINT = &adc_isr;    //配置adc中断服务函数地址EDIS;    PieCtrlRegs.PIEIER1.bit.INTx6 = 1;    //开启INT1.6中断IER |= M_INT1;                     // 开启第一组中断EINT;         ERTM; AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0; //禁用SEQ1发送中断申请AdcRegs.ADCTRL2.bit.INT_ENA_SEQ2 = 1; //允许SEQ2发送中断申请AdcRegs.ADCTRL2.bit.INT_MOD_SEQ2 = 0; //每个SEQ2序列转换完成后发送一次中断申请

中断服务函数为:

interrupt void  adc_isr(void)
{sampleTable[0] = (AdcRegs.ADCRESULT0) >> 4;sampleTable[1] = (AdcRegs.ADCRESULT1) >> 4;sampleTable[2] = (AdcRegs.ADCRESULT2) >> 4;sampleTable[3] = (AdcRegs.ADCRESULT3) >> 4;sampleTable[4] = (AdcRegs.ADCRESULT4) >> 4;sampleTable[5] = (AdcRegs.ADCRESULT5) >> 4;sampleTable[6] = (AdcRegs.ADCRESULT6) >> 4;sampleTable[7] = (AdcRegs.ADCRESULT7) >> 4;AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;for(i = 0; i < 8; i++){I[i] = (float)sampleTable[i] * 3.0 / 4095.0;}
}

 

二、配置模板

1.采集A0-A7通道,选择顺序采样模式、双序列发生器模式、连续自动序列化模式、自然结束循环模式,配置ADC时钟为25Mhz,软件触发SOC方式,且每次在完成A7转换后进入一次中断服务函数读取结果寄存器的值,完整的配置模板如下:

void InitAdc()
{EALLOW;SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;    EDIS;EALLOW;SysCtrlRegs.HISPCP.all = ADC_MODCLK;	// HSPCLK = SYSCLKOUT/(2*ADC_MODCLK)ADC_cal();EDIS;AdcRegs.ADCTRL3.all = 0x00E0;AdcRegs.ADCTRL1.bit.CPS= 0;AdcRegs.ADCTRL1.bit.SEQ_CASC = 0;AdcRegs.ADCTRL3.bit.SMODE_SEL=0;AdcRegs.ADCTRL1.bit.CONT_RUN = 1; AdcRegs.ADCTRL1.bit.SEQ_OVRD = 1;AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 0x7;AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0; // 采样ADCA0AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1; // 采样ADCA1AdcRegs.ADCCHSELSEQ1.bit.CONV02 = 0x2; // 采样ADCA2AdcRegs.ADCCHSELSEQ1.bit.CONV03 = 0x3; // 采样ADCA3AdcRegs.ADCCHSELSEQ2.bit.CONV04 = 0x4; // 采样ADCA4AdcRegs.ADCCHSELSEQ2.bit.CONV05 = 0x5; // 采样ADCA5AdcRegs.ADCCHSELSEQ2.bit.CONV06 = 0x6; // 采样ADCA6AdcRegs.ADCCHSELSEQ2.bit.CONV07 = 0x7; // 采样ADCA7AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;//软件启动方式EALLOW;  PieVectTable.ADCINT = &adc_isr;    //配置adc中断服务函数地址EDIS;    PieCtrlRegs.PIEIER1.bit.INTx6 = 1;    //开启INT1.6中断IER |= M_INT1;                     // 开启第一组中断EINT;         ERTM; AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0; //禁用SEQ1发送中断申请AdcRegs.ADCTRL2.bit.INT_ENA_SEQ2 = 1; //允许SEQ2发送中断申请AdcRegs.ADCTRL2.bit.INT_MOD_SEQ2 = 0; //每个SEQ2序列转换完成后发送一次中断申请
}
interrupt void  adc_isr(void)
{sampleTable[0] = (AdcRegs.ADCRESULT0) >> 4;sampleTable[1] = (AdcRegs.ADCRESULT1) >> 4;sampleTable[2] = (AdcRegs.ADCRESULT2) >> 4;sampleTable[3] = (AdcRegs.ADCRESULT3) >> 4;sampleTable[4] = (AdcRegs.ADCRESULT4) >> 4;sampleTable[5] = (AdcRegs.ADCRESULT5) >> 4;sampleTable[6] = (AdcRegs.ADCRESULT6) >> 4;sampleTable[7] = (AdcRegs.ADCRESULT7) >> 4;AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;for(i = 0; i < 8; i++){I[i] = (float)sampleTable[i] * 3.0 / 4095.0;}
}

2.采集A0-A7通道,选择顺序采样模式、双序列发生器模式、启动/停止模式、配置ADC时钟为25Mhz,Epwm触发SOC方式,且每次在完成A7转换后进入一次中断服务函数读取结果寄存器的值,完整的配置模板如下:

void EPWM6_SOCA_Init(Unit16 tbprd,Unit16 cmpa,Unit cmpb)
{EALLOW;SysCtrlRegs.PCLKCR0.bit.TBCLKSYNC = 0;   SysCtrlRegs.PCLKCR1.bit.EPWM6ENCLK = 1;  EDIS;EPwm6Regs.TBCTL.bit.SYNCOSEL = TB_SYNC_DISABLE;  EPwm6Regs.TBCTL.bit.PHSEN = TB_DISABLE;EPwm6Regs.TBPHS.half.TBPHS = 0;EPwm6Regs.TBCTR = 0x0000;                  EPwm6Regs.TBPRD = tbprd;EPwm6Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP;   EPwm6Regs.TBCTL.bit.HSPCLKDIV=TB_DIV1; EPwm6Regs.TBCTL.bit.CLKDIV=TB_DIV1;    EPwm6Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;EPwm6Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;EPwm6Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;EPwm6Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;EPwm6Regs.CMPA.half.CMPA = cmpa;    EPwm6Regs.CMPB = cmpb;   EPwm6Regs.ETSEL.bit.SOCAEN = 1;  //使能EPwm6SOCA信号产生EPwm1Regs.ETSEL.bit.SOCASEL = 2;  //当TBCTR=TBPRD时产生SOCA信号      EPwm1Regs.ETPS.bit.SOCAPRD = 1;   //在第一个事件来到时产生SOCA信号	 EALLOW;SysCtrlRegs.PCLKCR0.bit.TBCLKSYNC = 1;         EDIS; 
}
void InitAdc()
{EALLOW;SysCtrlRegs.PCLKCR0.bit.ADCENCLK = 1;    EDIS;EALLOW;SysCtrlRegs.HISPCP.all = ADC_MODCLK;	// HSPCLK = SYSCLKOUT/(2*ADC_MODCLK)ADC_cal();EDIS;AdcRegs.ADCTRL3.all = 0x00E0;AdcRegs.ADCTRL1.bit.CPS= 0;AdcRegs.ADCTRL1.bit.SEQ_CASC = 0;AdcRegs.ADCTRL3.bit.SMODE_SEL=0;AdcRegs.ADCTRL1.bit.CONT_RUN = 0; //启动/停止模式AdcRegs.ADCMAXCONV.bit.MAX_CONV1 = 0x7;AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0; // 采样ADCA0AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1; // 采样ADCA1AdcRegs.ADCCHSELSEQ1.bit.CONV02 = 0x2; // 采样ADCA2AdcRegs.ADCCHSELSEQ1.bit.CONV03 = 0x3; // 采样ADCA3AdcRegs.ADCCHSELSEQ2.bit.CONV04 = 0x4; // 采样ADCA4AdcRegs.ADCCHSELSEQ2.bit.CONV05 = 0x5; // 采样ADCA5AdcRegs.ADCCHSELSEQ2.bit.CONV06 = 0x6; // 采样ADCA6AdcRegs.ADCCHSELSEQ2.bit.CONV07 = 0x7; // 采样ADCA7AdcRegs.ADCTRL2.bit.EPWM_SOCA_SEQ1 = 1;//EPWM_SOCA启动方式EALLOW;  PieVectTable.ADCINT = &adc_isr;    //配置adc中断服务函数地址EDIS;    PieCtrlRegs.PIEIER1.bit.INTx6 = 1;    //开启INT1.6中断IER |= M_INT1;                     // 开启第一组中断EINT;         ERTM; AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 0; //禁用SEQ1发送中断申请AdcRegs.ADCTRL2.bit.INT_ENA_SEQ2 = 1; //允许SEQ2发送中断申请AdcRegs.ADCTRL2.bit.INT_MOD_SEQ2 = 0; //每个SEQ2序列转换完成后发送一次中断申请
}
interrupt void  adc_isr(void)
{AdcRegs.ADCTRL2.bit.RST_SEQ1 = 1; //初始化状态指针位置sampleTable[0] = (AdcRegs.ADCRESULT0) >> 4;sampleTable[1] = (AdcRegs.ADCRESULT1) >> 4;sampleTable[2] = (AdcRegs.ADCRESULT2) >> 4;sampleTable[3] = (AdcRegs.ADCRESULT3) >> 4;sampleTable[4] = (AdcRegs.ADCRESULT4) >> 4;sampleTable[5] = (AdcRegs.ADCRESULT5) >> 4;sampleTable[6] = (AdcRegs.ADCRESULT6) >> 4;sampleTable[7] = (AdcRegs.ADCRESULT7) >> 4;AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;for(i = 0; i < 8; i++){I[i] = (float)sampleTable[i] * 3.0 / 4095.0;}
}

这篇关于DSP28335模块配置模板系列——ADC配置模板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1037372

相关文章

C++的模板(八):子系统

平常所见的大部分模板代码,模板所传的参数类型,到了模板里面,或实例化为对象,或嵌入模板内部结构中,或在模板内又派生了子类。不管怎样,最终他们在模板内,直接或间接,都实例化成对象了。 但这不是唯一的用法。试想一下。如果在模板内限制调用参数类型的构造函数会发生什么?参数类的对象在模板内无法构造。他们只能从模板的成员函数传入。模板不保存这些对象或者只保存他们的指针。因为构造函数被分离,这些指针在模板外

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

IDEA配置Tomcat远程调试

因为不想把本地的Tomcat配置改乱或者多人开发项目想测试,本文主要是记录一下,IDEA使用Tomcat远程调试的配置过程,免得一段时间不去配置到时候忘记(毕竟这次是因为忘了,所以才打算记录的…) 首先在catalina.sh添加以下内容 JAVA_OPTS="-Dcom.sun.management.jmxremote=-Dcom.sun.management.jmxremote.port

记录AS混淆代码模板

开启混淆得先在build.gradle文件中把 minifyEnabled false改成true,以及shrinkResources true//去除无用的resource文件 这些是写在proguard-rules.pro文件内的 指定代码的压缩级别 -optimizationpasses 5 包明不混合大小写 -dontusemixedcaseclassnames 不去忽略非公共

iptables(7)扩展模块state

简介         前面文章我们已经介绍了一些扩展模块,如iprange、string、time、connlimit、limit,还有扩展匹配条件如--tcp-flags、icmp。这篇文章我们介绍state扩展模块  state          在 iptables 的上下文中,--state 选项并不是直接关联于一个扩展模块,而是与 iptables 的 state 匹配机制相关,特

Steam邮件推送内容有哪些?配置教程详解!

Steam邮件推送功能是否安全?如何个性化邮件推送内容? Steam作为全球最大的数字游戏分发平台之一,不仅提供了海量的游戏资源,还通过邮件推送为用户提供最新的游戏信息、促销活动和个性化推荐。AokSend将详细介绍Steam邮件推送的主要内容。 Steam邮件推送:促销优惠 每当平台举办大型促销活动,如夏季促销、冬季促销、黑色星期五等,用户都会收到邮件通知。这些邮件详细列出了打折游戏、

JavaWeb系列二十: jQuery的DOM操作 下

jQuery的DOM操作 CSS-DOM操作多选框案例页面加载完毕触发方法作业布置jQuery获取选中复选框的值jQuery控制checkbox被选中jQuery控制(全选/全不选/反选)jQuery动态添加删除用户 CSS-DOM操作 获取和设置元素的样式属性: css()获取和设置元素透明度: opacity属性获取和设置元素高度, 宽度: height(), widt

python 在pycharm下能导入外面的模块,到terminal下就不能导入

项目结构如下,在ic2ctw.py 中导入util,在pycharm下不报错,但是到terminal下运行报错  File "deal_data/ic2ctw.py", line 3, in <module>     import util 解决方案: 暂时方案:在终端下:export PYTHONPATH=/Users/fujingling/PycharmProjects/PSENe

微信小程序开发必知必会:文件结构和基本配置

一、微信小程序基本文件结构 1.  project.config.json:项目的基本配置文件,包括项目名称、appid、项目目录、页面文件夹等。     {"setting": {"urlCheck": false,"es6": true,"postcss": true,"nodeModulesPath": "D:\\\\node_modules"},"appid": "wxd678e