DSP28335I2C接口应用

合集下载

主动磁悬浮轴承数模混合式PID控制器研究_郑仲桥

主动磁悬浮轴承数模混合式PID控制器研究_郑仲桥

第5期
郑仲桥等:主动磁悬浮轴承数模混合式 PID 控制器研究
51
Ki、Kd 三个参数,模拟控制器送出调理好的控制信号给功率放大 器,信号经功率放大器放大后送给执行电磁铁线圈,改变电磁力 使得转子能够保持稳定的悬浮。
GPIO32
GPIO33
数字 电位

PID
控 制 器
功 率 放 大 器
电 磁 铁
转 子
3.2 数字控制部分
由图 1 所示的系统总体硬件框图可知,数字部分是利用高速控 制芯片 TMS320F28335 通过与数字电位器之间的通信来控制 PID 参数的电路。主动磁悬浮轴承控制系统中的数字控制部分采用某 公司的 TMS320F28335 数字信号处理器为核心。该处理器是一款浮 点处理器,具有 150MHz 的高速处理能力,具备 32 位浮点处理单元, 6 个 DMA 通道支持 ADC、McBSP 和 EMIF,有多达 18 路的 PWM 输 出,其中 6 路为 TI 特有的更高精度的 PWM 输出(HRPWM),12 位 16 通道 ADC。与以往的定点 DSP 相比该器件具有精度高,成本 低、功耗小、性能高、外设集成度高、数据以及存储空间大、A/D 转换 更精确快速等优点。TMS320F28335 强大的控制和信号处理能力, 能够实现复杂的控制算法,片上整合了 Flash 存储器、快速 A/D 转换 器、增强的 CAN 模块、事件管理器、SPI 外设接口、SCI 通信接口、I2C 总线等多种外设单元,为功能复杂的控制系统设计提供了方便[6]。除 此之外,它能够快速反应中断,并自动保存关键寄存器的当前数据, 因此可在非常小的迟延下处理很多同步发生的事件。
3 控制器硬件设计
数模混合式 PID 控制器是数字控制部分与模拟控制器部分 组成,其总体方案,如图 1 所示。位移传感器采集到的位置信号经 A/D 转换后送入数字控制部分,经过预先设定的算法,将得到的 运算结果送到数字电位器,用以改变模拟 PID 控制器中的 Kp、

DSP28335 I2C接口应用

DSP28335 I2C接口应用

D S P I2C应用说明1.示例程序中几种状态第一次看i2c_eeprom示例程序,对程序中的MsgStatus信息状态切换非常懵懂,为什么要有这几个状态?状态切换顺序如何安排?一大堆的状态,让人有些摸不着头脑。

先把程序中的头文件涉及的7种状态分析一下。

//I2CMessageCommandsforI2CMSGstruct#defineI2C_MSGSTAT_INACTIVE0x0000//未激活状态:一般成功发送数据或者//接受数据后可以设置信息状态为此状态,告诉用户可进行下一次的写数据或读数据。

#defineI2C_MSGSTAT_SEND_WITHSTOP0x0010//发送带停止位数据:这是为写数据而设///的状态,写入地址和数据之后发个停止位告诉存储器数据写入完毕。

#defineI2C_MSGSTAT_WRITE_BUSY0x0011//写数据忙状态:在将待写的数据放入//缓存后,就可以使能IIC传输数据了,然后把信息状态设为该状态,意在告诉用户:数据//已经在传送过程中。

当然是否传送完毕,还需要通过查询SCD位来判断。

#defineI2C_MSGSTAT_SEND_NOSTOP0x0020//发送无停止位数据:这个状态是为了读//取数据而设的,有查阅过AT24C1024EEPROM存储器使用手册的读者知道,在读数据之前//要发送数据的地址,发完地址不能产生停止位,这是存储器硬件设计决定的。

设为这个状//态意在告诉读者,可以发送要读取的数据的地址了。

#defineI2C_MSGSTAT_SEND_NOSTOP_BUSY0x0021//发送无停止位数据忙状态:这个状态是//为了读取数据而设的,似于I2C_MSGSTAT_WRITE_BUSY,说明地址数据已经在传送过程中。

//传送是否成功,还要看ARDY的状态。

#defineI2C_MSGSTAT_RESTART0x0022//重发开始位状态:这个状态也是为读取////数据而设。

DSP28335 I2C接口应用

DSP28335 I2C接口应用

DSP I2C 应用说明1.示例程序中几种状态第一次看i2c_eeprom示例程序,对程序中的MsgStatus信息状态切换非常懵懂,为什么要有这几个状态?状态切换顺序如何安排?一大堆的状态,让人有些摸不着头脑。

先把程序中的头文件涉及的7种状态分析一下。

// I2C Message Commands for I2CMSG struct#define I2C_MSGSTAT_INACTIVE 0x0000//未激活状态:一般成功发送数据或者//接受数据后可以设置信息状态为此状态,告诉用户可进行下一次的写数据或读数据。

#define I2C_MSGSTAT_SEND_WITHSTOP 0x0010 //发送带停止位数据:这是为写数据而设///的状态,写入地址和数据之后发个停止位告诉存储器数据写入完毕。

#define I2C_MSGSTAT_WRITE_BUSY 0x0011 //写数据忙状态:在将待写的数据放入//缓存后,就可以使能IIC传输数据了,然后把信息状态设为该状态,意在告诉用户:数据//已经在传送过程中。

当然是否传送完毕,还需要通过查询SCD位来判断。

#define I2C_MSGSTAT_SEND_NOSTOP 0x0020//发送无停止位数据:这个状态是为了读//取数据而设的,有查阅过AT24C1024EEPROM存储器使用手册的读者知道,在读数据之前//要发送数据的地址,发完地址不能产生停止位,这是存储器硬件设计决定的。

设为这个状//态意在告诉读者,可以发送要读取的数据的地址了。

#define I2C_MSGSTAT_SEND_NOSTOP_BUSY 0x0021//发送无停止位数据忙状态:这个状态是//为了读取数据而设的,似于I2C_MSGSTAT_WRITE_BUSY,说明地址数据已经在传送过程中。

//传送是否成功,还要看ARDY的状态。

#define I2C_MSGSTAT_RESTART 0x0022//重发开始位状态:这个状态也是为读取////数据而设。

DSP28335 I2C寄存器中文资料及例程

DSP28335 I2C寄存器中文资料及例程

1I2C寄存器1.1.1I2C模式寄存器——I2CMDR16位寄存器,包含了I2C模块的控制部分I2C作为主机时,RM、STT、STP位于总线发送/接收数据格式和总线状态关系表1.1.2I2C中断使能寄存器——I2CIER包括I2C中断的使能与屏蔽位;1.1.3I2C状态寄存器——I2CSTR包括中断标志状态和读状态信息;1.1.4I2C中断源寄存器——I2CSRC该寄存器主要表明是哪个中断源触发了I2C中断;1.1.5I2C时钟分频寄存器——I2CPSC用于设置I2C输入时钟的分频系数,I2C模块复位时必须初始化I2CPSC;1.1.6I2C时钟宽度寄存器——I2CCLKL、I2CCLKH该寄存器决定I2C时钟的高低电平持续时间I2CCLKL 中的ICCL。

ICCL 决定了时钟信号的低电平时间。

I2CCLKH 中的ICCH。

ICCH 决定了时钟信号的高电平时间。

主机时钟宽度计算公式:T mst=T mod∗((ICCL+d)+(ICCH+d))T mst=(IPSC+1)∗((ICCL+d)+(ICCH+d))I2C输入时钟频率其中T mod为I2C模块的时钟电平宽度,及时钟周期,d的值由IPSC决定。

1.1.7I2C从机地址寄存器——I2CSARI2C模块从机地址寄存器,当I2C模块作为主机时,该寄存器用来存储下一次要发送的从机地址。

它包含了一个7位或者10位从机地址空间,当I2C工作在非全数据模式时(I2CMDR.FDF=0),寄存器中的地址是传输的首帧数据。

如果寄存器中地址值非全零,那该地址对应一个指定的从机;如果寄存器中的地址为全零,地址就为广播地址,呼叫所有挂在总线上的从机。

如果选择7位地址模式(I2CMDR.XA=0),只有位6到位0是可用的,位9到位7写0。

1.1.8I2C模块自身地址寄存器——I2COARI2C模块使用该寄存器从所有挂在总线上的从机中找出属于自己的从机。

如果选择7位地址模式(I2CMDR.XA=0),只有位6到位0是可用的,位9到位7写0。

DSP28335的调试总结,这是一份总结很全面的资料,我在学

DSP28335的调试总结,这是一份总结很全面的资料,我在学

DSP28335的调试总结,这是一份总结很全面的资料,我在学习开发板的一些总结,希望能得到同行的帮助,愿与大家一起学习和分享1DSP的PWM信号1.1简介DSP28335共12路16位的ePWM,能进行频率和占空比控制。

ePWM的时钟TBCLK=SYSCLKOUT/(HSPCLKDIV×CLKDIV):PWM信号频率由时基周期寄存器TBPDR和时基计数器的计数模式决定。

初始化程序采用的计数模式为递增计数模式。

在递增计数模式下,时基计数器从零开始增加,直到达到周期寄存器值(TBPDR)。

然后时基计数器复位到零,再次开始增加。

PWM信号周期与频率的计算如下:1.2端口对应关系说明:JP0B的端口号按“Z”字形顺序数。

1.3初始化程序注释void InitPwm1AB(float32f){Uint16T= 2343750/f-1.0;//系统时钟SYSCLKOUT=150MHz,TBCLK=6.6666667ns,在连续增计数模式下,f=150000000/(TBPDR+1) EALLOW;//先初始化通用输入输出口//GpioCtrlRegs.GPAPUD.bit.GPIO0 = 0;GpioCtrlRegs.GPAMUX1.bit.GPIO0 = 1;GpioCtrlRegs.GPAPUD.bit.GPIO1 = 0;GpioCtrlRegs.GPAMUX1.bit.GPIO1 = 1;EPwm1Regs.TBPHS.half.TBPHS= 0; // 在相位寄存器中设置计数器的起始计数位置//下面两条语句组合对PWM的时钟进行分频EPwm1Regs.TBCTL.bit.CLKDIV = 6;EPwm1Regs.TBCTL.bit.HSPCLKDIV = 0;EPwm1Regs.TBPRD = T; //在周期寄存器中设置计数器的计数周期//TBCTL为定时器控制寄存器EPwm1Regs.TBCTL.bit.CTRMODE= TB_COUNT_UP; //设置计数模式位为连续增计数模式,产生对称方波EPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE; // 将定时器相位使能位关闭EPwm1Regs.TBCTL.bit.PRDLD = TB_SHADOW;//映射寄存器SHADOW使能并配置映射寄存器为自动读写EPwm1Regs.TBCTL.bit.SYNCOSEL = TB_CTR_ZERO; // 定时器时钟源选择,一共有四种时钟源EPwm1Regs.CMPA.half.CMPA= 0.0001*T;// 设置EPWM1A比较值寄存器的比较值,即体现EPWM1A的占空比EPwm1Regs.CMPB= 0.0001*T;EPwm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;//A模块比较模式EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;//B模块比较模式EPwm1Regs.CMPCTL.bit.LOADAMODE= CC_CTR_ZERO; // A模块比较使能,通过写0来清除SHDWAMODE位来使能load on CTR=ZeroEPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO; // B模块比较使能,通过写0来清除SHDWBMODE位来使能load on CTR=Zero//AQCTLA为输出A比较方式控制寄存器EPwm1Regs.AQCTLA.bit.ZRO = AQ_SET; // TBCTR(计数器)计到零时使输出为反向EPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;//TBCTR(计数器)与CMPA在up 计数时相等使输出为high,这关系的输出的占空比EPwm1Regs.AQCTLB.bit.ZRO = AQ_SET;EPwm1Regs.AQCTLB.bit.CBU = AQ_CLEAR;EDIS;}2DSP的CAN通信2.1CAN2.0B协议简述TMS320F28335上有2个增强型CAN总线控制器,符合CAN2.0B协议,其总线波特率可达到1Mbps。

DSP控制器原理与应用教程 DSP2-F28335的结构原理

DSP控制器原理与应用教程 DSP2-F28335的结构原理
12
2、乘积寄存器--P
乘法的结果
存放16位或32位数据; P的输出要经移位器,移位值由PM(ST0中)决定:
PM值 000 001 010 011
移位模式 左移1位 不移 右移1位 右移2位
PM值 100 101 110 111
移位模式 右移3位 右移4位 右移5位 右移6位
13
3、累加器--ACC
PIE
(96个中断)
片上外设 CAN2.0B
I 2C SCI SPI McBSP
Data Bus(数据总线)
88*GPIO
4、片上外设
•ePWM/eCAP/eQEP
2、CPU
•ALU,R-M-W:atomic •乘法器 •AR及ARAU •FPU及控制器
3、系统控制
•时钟管理 •Watchdog •定时器*3个 •PIE(仅用45) •DMA及JTAG
C28x寄存器组
16bit TL PL AL
AR0 AR1 AR2 AR3 AR4 AR5 AR6 AR7
XT P ACC
XAR0 XAR1 XAR2 XAR3 XAR4 XAR5 XAR6 XAR7
16bit IER IFR DBGIER
ST0 ST1
SP DP 6bit
22bit PC RPC
11
Shift R/L (0-16)
32
2021/5/8
9
16/32 8/16/32 32
8/16
自寄存器
三、F28335的ARAU
Data Bus
XAR0 XAR1 XAR2 XAR3 XAR4 XAR5 XAR6 XAR7
DDPP(1(166) )
32
22

绝密,DSPF28335实用板使用教程

绝密,DSPF28335实用板使用教程

绝密,DSPF28335实⽤板使⽤教程官⽅声明YXDSP-F28335系列开发板是南京研旭开发⽣产并直接进⾏销售及提供技术服务的产品,暂时未设置任何代理商。

如有其它任何⼚商或代理使⽤“YXDSP-F28335开发套件”的名义进⾏销售,均属于假冒产品。

南京研旭对您购买及使⽤此假冒产品过程中造成的所有损失均不承担任何责任。

官⽅指定销售⽹站:/doc/98ddcdb369dc5022aaea002f.html 中⽂名称:研旭商城官⽅指定销售⽹站:/doc/98ddcdb369dc5022aaea002f.html 中⽂名称:研旭淘宝商城YXDSP-F28335开发板是研旭电⽓科技有限公司⾃主研发的,针对⾼校、研究所和中⼩企业⼩批量设计的需求⽽研发的。

该开发板可以满⾜基于所有F28335开发时的所有应⽤。

YXDSP-F28335开发套件功能强⼤,代码丰富,⽅便使⽤。

在国内,我们的产品已经成为众多的国家级科研院所、⼤学、国家重点实验室、电⼒、通讯、⼯业、医疗类公司指定的开发⼯具。

TMS320F28335型数字信号处理器是TI公司的⼀款TMS320C28X系列浮点DSP控制器。

与以往的定点DSP相⽐,该器件的精度⾼,成本低,功耗⼩,性能⾼,外设集成度⾼,数据以及程序存储量⼤,A/D转换更精确快速等。

TMS320F28335具有150MHz的⾼速处理能⼒,具备32位浮点处理单元,6个DMA通道⽀持ADC、McBSP和EMIF,有多达18路的PWM输出,其中有6路为TI特有的更⾼精度的PWM输出(HRPWM),12位16通道ADC。

得益于其浮点运算单元,⽤户可快速编写控制算法⽽⽆需在处理⼩数操作上耗费过多的时间和精⼒,从⽽简化软件开发,缩短开发周期,降低开发成本。

采⽤六层核⼼板与底板的分拆形式,在听取⼴⼤DSP⼯程师意见的基础上,以保证DSP 能稳定独⽴运⾏、外设资源充分扩展为原则,优化结构设计,注重EMC处理,⽆论在设计还是在⼯艺上,均⽤⼼完成。

基于DSP与CPLD的I2C总线接口的设计与实现

基于DSP与CPLD的I2C总线接口的设计与实现

基于DSP与CPLD的I2C总线接口的设计与实现基于DSP与CPLD的I2C总线接口的设计与实现摘要:介绍了一种使用CPLD完成DSP芯片I2C总线接口的设计和实现方案,重点叙述了I2C核的设计思想。

关键词:PWM SG3524 控制器带有I2C总线接口的器件可以十分方便地将一个或多个单片机及外围器件组成单片机系统。

尽管这种总线结构没有并行总线那样大的吞吐能力,但由于连接线和连接引脚少,因此其构成的系统价格低、器件间总线连接简单、结构紧凑,而且在总线上增加器件不影响系统的正常工作,系统修改和可扩展性好。

即使有不同时钟速度的器件连接到总线上,也能很方便地确定总线的时钟。

如今,为了提高系统的数据处理精度和处理速度,在家用电器、通讯设备及各类电子产品中已广泛应用DSP芯片。

但大多数的尚未提供I2C总线接口,本文将介绍一种基于CPLD的已实现的高速DSP的I2C总线接口方案。

图1 I2C总线接口电路结构1I2C通信协议I2C总线是一种用于IC器件之间的二线制总线。

它通过SDA(串行数据线)及SCL(串行同步时钟线)两根线在连到总线上的器件之间传送信息,通过软件寻址实现片选,减少了器件片选线的连接。

CPU不仅能通过指令将某个功能单元电路挂靠或摘离总线,还可对该单元的工作状况进行检测,从而实现对硬件系统的扩展与控制。

I2C总线接口电路结构如图1所示,I2C总线时序图如图2所示。

I2C总线根据器件的功能通过软件程序使其可工作于发送(主)或接收(从)方式。

总线上主和从(即发送和接收)的关系不是一成不变的,而是取决于数据传送的方向。

SDA和SCL均为双向I/O线,通过上拉电阻接正电源。

当总线空闲时,两根线都是高电平。

连接总线的器件的输出级必须是集电极或漏极开路的,以具有线“与”功能。

I2C总线的数据传送速率在标准工作方式下为100kbit/s,在快速方式下,最高传送速率可达400kbit/s。

在数据传送过程中,必须确认数据传送的开始和结束信号(也称启动和停止信号)。

DSP虚拟I2C总线软件包设计及应用实例(精)

DSP虚拟I2C总线软件包设计及应用实例(精)

DSP虚拟I2C总线软件包设计及应用实例摘要:实现了一种全集成可变带宽中频宽带低通滤波器,讨论分析了跨导放大器-电容(OTA—C)连续时间型滤波器的结构、设计和具体实现,使用外部可编程电路对所设计滤波器带宽进行控制,并利用ADS软件进行电路设计和仿真验证。

仿真结果表明,该滤波器带宽的可调范围为1~26 MHz,阻带抑制率大于35 dB,带内波纹小于0.5 dB,采用1.8 V电源,TSMC 0.18μm CMOS工艺库仿真,功耗小于21 mW,频响曲线接近理想状态。

关键词:Butte数字信号处理器(DSP)在各领域中的应用已日趋广泛,其中TI(TEXAS INSTRUMENT)公司的TMS320系列芯片占据了主导地位。

TMS320F206(简称F206)由于具有片内32K字的Flash,支持JTAG扫描端口的仿真调试,并支持程序的串行下载,便于开发设计及产品的软件升级,因而在中高档仪器开发中受到青睐。

DSP的处理速度虽然较高,但直接支持的I/O口线较少,控制能力相对较弱,因而与外部器件接口采用串行方式较为适合。

常用的串行接口和串行总线有UART、I2C总线,由于I2C总线提供了较完善的总线协议,且接口电路简单,因而得到广泛的应用。

目前,已有很多外围器件支持I2C接口,但多数MCU并不直接支持I2C总线,因而采用I/O口线模拟I2C的方式成为一种通用解决方案。

但由于I2C总线协议的复杂性及操作管理的特殊性,仍给此类方式的开发造成了较大不便。

好在文献中提出了一种按平台模式设计的、适用于80C51的虚拟I2C总线软件包,大大简化了80C51的I2C接口程序设计,使用户无需了解I2C总线协议的细节,即可实现相应的接口。

文献中也给出了一种用于MSP430单片机的软件包。

由于DSP尚无此类软件包,为简化DSP的此类I2C接口程序设计,本文参照文献中的设计原则,设计了一种适用于TMS320C2XX系列DSP开发的软件包。

DSP 28335

DSP 28335

DSP TMS320F28338圈子类别:运动控制 (未知) 2008-12-29 20:13:00[我要评论] [加入收藏] [加入圈子]eP WM在工业和商业设备的电力或能量转换相关系统中是最常用的接口模块,这些系统主要包括数字电机控制、开关电源控制、非中断电源供给(UP S)等其他形式的能量转换,eP WM模块起到一个DAC(数模转换)的作用。

在电机的控制中,信号通过P WM调制,控制功率器件的关断与导通,来控制输入到电机绕组中的电流,从而达到控制电机位置、速度和方向的目的。

TMS320C2000系列DSP包含两个事件管理器(E VA,E VB)用来产生P WM信号,但在TMS320F28335中做了改进,用六个独立的P WM模块代替了事件管理器,每个P WM模块可以产生两路P WM信号,而且使用更加灵活,六个P WM模块可以单独使用,也可以任意组合生成S VP WM信号。

为TMS320F28335中eP WM模块的主要结构。

P WM模块主要由计数模块,比较模块,事件评价模块,死区模块和事件中断模块组成,下面分别介绍各个子模块的具体功能:(1)Time-Base子模块。

Time-Base模块包含一个计数器、一个周期寄存器和一个相位寄存器。

计数器为16位,计数频率和计数方向可以通过相应寄存器进行设置,计数器在0和周期寄存器值之间进行计数;周期寄存器决定了P WM输出信号的周期;当几个P WM模块同步运行时,相位寄存器提供了模块之间相位相关性功能;(2)Counter-Compare子模块。

Counter-Compare模块包含两个比较寄存器(CMP A,CMPB)和两个比较逻辑。

设置两个寄存器的值,当时间基计数器和比较寄存器的值相同的时候可以产生CMP A=CTR和CMPB=CTR 事件。

(3)Action-Qualifier子模块。

Action-Qualifier模块通过评价事件来产生P WM信号。

28335的I2C数据手册翻译

28335的I2C数据手册翻译

10 位地址格式与 7 位地址格式的类似的, 但是 10 位地址格式下主机的地址 发送分两次发送,首字节数据包括:11110B, 10 位地址高两位,R/W=0(写) 。 第二个字节数据是 10 位从机地址的低 8 位,从机必须在每个字节数据后面 发送一个应答信号,一旦主机向从机发送完第二个字节数据后,主机可以写数据 或者使用循环起始信号模式改变数据流向。 更详尽的细节可以参考飞利浦公司的 I2C 总线协议。 写 1 到 XA 位选择 10 位地址模式,但是选择的时候必须确保关闭全数据格 式(FDF=0)。 2.5.3 全数据格式 在这种格式下,紧随起始信号的首字节数据字节为数据,而非从机地址。 应 答信号的发生规则与上面的格式一致。然而,这种格式下要求发送方与接收方都 要支持全数据格式,而且数据必须由始至终都是发送。 写 1 到 FDF 位选择全数据格式,全数据格式在 I2C 模块自测模式下不可以 使用。 2.5.4 循环起始信号 在每个数据帧发送结束以后主机可以发送另一个起始信号。利用这种功能, 一个主机可以在不放弃总线控制权 (不发送停止信号) 的情况下与多个从机通信。 BC 位可以选择 1 到 8 位的数据长度,循环起始信号发送可以在以上三种格式下 使用。
数据寄存器和fifo为cpu和sda暂时保存接收数据和发送数据一根外围总线使能cpu存取i2c模块寄存器和fifo一个同步时钟使得i2c输入时钟与scl上时钟同步并且同步不同主机之间的数据发送速率一个分频器对输入时钟分频后提供给i2c模块在sda与scl引脚上都有一个噪声滤波器一个仲裁机制处理i2c模块与其他主机之间的冲突中断逻辑因此中断事件可以向cpu发出中断请求fifo中断逻辑因此fifo的存取可以与数据的接收发送同步下图为28335i2c模块内部框图在非fifo模式下有四个寄存器用于数据的发送与接收

tms320f28335原理及其在电气工程中的应用

tms320f28335原理及其在电气工程中的应用

tms320f28335原理及其在电气工程中的应用TMS320F28335是一款基于32位定点数字信号处理器(DSP)的芯片,由德州仪器公司(Texas Instruments)生产。

它具有高速、高效、低功耗等优点,广泛应用于各种电气工程领域。

TMS320F28335基于C28x内核架构,拥有高达150MHz的最高工作频率,可以实现复杂的数字信号处理和控制算法,如矢量控制、PID调节、滤波、FFT等。

此外,它还拥有多种外设接口,如GPIO、CAN、SPI、I2C等,可以实现各种外部设备的连接和数据通信。

在电气工程领域中,TMS320F28335主要应用于电力电子、电机控制、光伏发电、电网无功补偿、智能电网等方面。

具体应用包括:
1. 电机控制:TMS320F28335内置了多种PWM输出模块和编码器接口,可以实现高性能的电机控制,如直接矢量控制、间接矢量控制等。

2. 电力电子:TMS320F28335可以实现各种电力电子开关器件的PWM控制,如IGBT、MOSFET、整流器等,实现电力变换、能量转换和电子调节等功能。

3. 光伏发电:TMS320F28335可以与光伏逆变器的控制器相结合,通过MPPT 算法实现对光伏电池板的最大功率追踪,提高光伏发电效率。

4. 智能电网:TMS320F28335可以与智能电网控制器相结合,实现对电网的无功补偿、电网状态监测、分布式发电控制等功能。

总之,TMS320F28335作为一款高性能的DSP芯片,具有广泛的应用前景,在电气工程领域中将有着越来越广泛的应用。

Example_2833x_Iic_led_over

Example_2833x_Iic_led_over

IIC流水灯实验1、实验目的:(1)了解IIC总线时序;(2)了解如何使用IIC总线控制PCA9557芯片来扩展IO口;2、实验设备:(1)PC 机一台;(2)XDS100v2或XDS100V3(隔离)仿真器一套;(3)SXD28335 开发板一套;3、实验步骤:(1)首先将CCS6.0 开发环境打开;看一下如下原理图:首先,我们从图中可以看到要控制IIC流水灯首先要了解PCA9557这个芯片。

(2)接着把仿真器的USB 与电脑进行连接,将仿真器的另一端JATG 端插到SXD28335开发板的JATG 针处(注意仿真器插入方向,请仔细核对防差错针的位置,JTAG接口是用来连接仿真器的。

开发板上对应的是14针的座子,不要用开发板上20针或18针的座子连接仿真器);(3)给开发板上电。

单击鼠标左键选择要调试的工程,如下图所示:然后单击图中红色的方框处的调试按钮,进行调试。

(注:此时认为兄弟你已经会设置配置文件,并将其设置为默认配置)。

(4)程序通过仿真器会加载到SXD28335开发板里。

这是会出现下面的界面。

图中1图标是用来进行与开发板进行连接的按钮;图中2是用来下载Debug文件下的.out文件的图中3是CPU软Reset;图中4是调试时恢复到程序的开始处。

图中5是全速运行;图中6是停止调试;图中7是用于单步调试的;这里。

我们直接用鼠标左键单击图标5即可,这时程序会全速运行。

(5)试验现象:8位Led灯会从左到右依次点亮。

程序解析while(1){Led_Test();}Step1:程序进入主函数进行一些常规的配置,如配置系统时钟、禁止看门狗和初始化中断向量等。

Step2:进入while(1)循环,在这个循环里执行Led_Test();void Led_Test(){Uint16 led,i;InitI2CGpio();//配置GPIO32和GPIO33为IIC总线.I2CA_Init();//配置IIC工作方式// I2CA_WriteConfig(&I2cMsgConfigOut1);//配置PCA9557芯片I2cWriteRegister(0x1C,I2C_CONFIG_REG,I2C_OUTPUT_ALL);DSP28x_usDelay(100000);for(i=0;i<8;i++){//地址 =LED_I2CADDR; 1为配置px为输出; 输出的数据是:1<<((led%7)+1)1<<((led%7)+1)//向PCA9557写数据I2cWriteRegister(0x1c,1,1<<((led%8))); //light one ledDSP28x_usDelay(2000000);DSP28x_usDelay(2000000);led++;#if 0if(led==0x07){led=0;flag=0;}elseled++;#endif}}具体的配置信息用户要参考PCA9557数据手册。

DSP28335SPI的配置

DSP28335SPI的配置

DSP28335SPI的配置
1. SPI 数据从高位发送从低位读取(所以写入SPIDAT和SPITXBUF时必须左对齐,从SPIRXBUF读数据时必须右对齐)。

2. 当SPI工作在主模式是,SPICLK引脚为通信网络提供时钟;当SPI工作在从模式下时,SPICLK引脚接收外部时钟信号。

(SPICLK时钟信号的频率不能大于CPU时钟的1/4)
3. 为改变SPI配置,应完成以下操作:
(1).清除SPI SW RESET 位(SPICCR.7),以迫使SPI进入复位状态;
(2).初始化SPI的配置包括数据格式、波特率、工作模式和引脚功能等;
(3).设置SPI SW RESET 位为1,是SPI退出复位状态;
(4).写数据到SPIDAT或SPITXBUF(这就启动了主模式通信过程);
(5).数据传输结束后(SPISTS.6=1),读取SPIRXBUF中的数据;
4. 波特率的设置:
当SPIBRR=3~127时:SPI=LSPCLK/(SPIBRR+1)。

(LSPCLK 为DSP的低速外设时钟)
当SPIBRR=0,1或2时:SPI=LSPCLK/4。

对于SPI,当(SPIBRR+1)为偶数时,SPICLK是对称的,如果为奇数且SPIBRR的值大于3,SPICLK为不对称。

CLOCK POLARITY位清零时,SPICLK的低脉冲比高脉冲长一个系统时钟,否则则短一个系统时钟。

注意:在通信进程正在进行时,不要改变SPI的设置。

DSP原理与应用2011-第五章 TMS320F28335片内外设_ad转换SCI

DSP原理与应用2011-第五章 TMS320F28335片内外设_ad转换SCI

18
一旦复位和初始化寄存器,SEQ1将等待第一个触发 事件的到来,然后开始CONV00(I1), CON01(I2), CONV02(I3) 转换,本次转换完成后,SEQ1在当前状态等 待下一个触发事件的到来,然后再开始CONV03(V1), CON04(V2), CONV05(V3)。两次转换中MAX_CONV1值都 自动装入SEQ_CNTR,如果两次转换的通道数不一致,则 应在下次转换开始之前的适当时刻修改MAX_CONV1的值。 可以通过ADCTRL2中的RST_SEQn来复位序列到预启动 状态。
2012年9月3日
13
单序列模式和级联模式对比
DSP原理与应用
2012年9月3日
14
§5.1.4 ADC电压参考
默认为使用内部电压参考,也可以使用外部电压参考,允许值为 2.048V,1.5V和1.024V。
通过ADCREFSEL寄存器选择参考源,如果选择内部参考源, ADCREFIN引脚可以连接选择的参考源、悬空或接地。 如果使用外 部2.048V的参考源,推荐使用工业级REF3020AIDBZ芯片。
Sample-and-hold (S/H) acquisition time window has separate prescale control
DSP原理与应用
2012年9月3日
6
A/DC模块框图(Block diagram of A/DC Module)
DSP原理与应用
2012年9月3日
ADCPWDN)上电参考,带隙和模拟电路。 (3)在ADC模块全部上电后,在开始第一次ADC转换之前需要增加至
少5mS的延时。
DSP原理与应用
2012年9月3日
21

DSP28335 I2C接口应用

DSP28335 I2C接口应用

DSP I2C 应用说明1.示例程序中几种状态第一次看i2c_eeprom示例程序,对程序中的MsgStatus信息状态切换非常懵懂,为什么要有这几个状态?状态切换顺序如何安排?一大堆的状态,让人有些摸不着头脑。

先把程序中的头文件涉及的7种状态分析一下。

// I2C Message Commands for I2CMSG struct#define I2C_MSGSTAT_INACTIVE 0x0000 //未激活状态:一般成功发送数据或者//接受数据后可以设置信息状态为此状态,告诉用户可进行下一次的写数据或读数据。

#define I2C_MSGSTAT_SEND_WITHSTOP 0x0010 //发送带停止位数据:这是为写数据而设///的状态,写入地址和数据之后发个停止位告诉存储器数据写入完毕。

#define I2C_MSGSTAT_WRITE_BUSY 0x0011 //写数据忙状态:在将待写的数据放入//缓存后,就可以使能IIC传输数据了,然后把信息状态设为该状态,意在告诉用户:数据//已经在传送过程中。

当然是否传送完毕,还需要通过查询SCD位来判断。

#define I2C_MSGSTAT_SEND_NOSTOP 0x0020//发送无停止位数据:这个状态是为了读//取数据而设的,有查阅过AT24C1024EEPROM存储器使用手册的读者知道,在读数据之前//要发送数据的地址,发完地址不能产生停止位,这是存储器硬件设计决定的。

设为这个状//态意在告诉读者,可以发送要读取的数据的地址了。

#define I2C_MSGSTAT_SEND_NOSTOP_BUSY 0x0021//发送无停止位数据忙状态:这个状态是//为了读取数据而设的,似于I2C_MSGSTAT_WRITE_BUSY,说明地址数据已经在传送过程中。

//传送是否成功,还要看ARDY的状态。

#define I2C_MSGSTAT_RESTART 0x0022//重发开始位状态:这个状态也是为读取////数据而设。

dsp课程设计28335摘要

dsp课程设计28335摘要

dsp课程设计28335摘要一、教学目标本课程的教学目标分为三个维度:知识目标、技能目标和情感态度价值观目标。

1.知识目标:通过本课程的学习,学生需要掌握DSP28335的基本结构、工作原理和编程方法,理解其在中断、定时器、ADC和PWM等方面的应用。

2.技能目标:学生能够运用DSP28335进行实际项目的开发和调试,具备使用相关开发工具和软件的能力。

3.情感态度价值观目标:培养学生对嵌入式系统的兴趣,使其认识到DSP在现代科技领域的重要性和广泛应用,激发学生的创新精神和团队合作意识。

在制定教学目标时,充分分析了课程性质、学生特点和教学要求,确保目标具有可衡量性和具体性,以便于学生和教师了解课程的预期成果。

二、教学内容根据课程目标,本课程的教学内容主要包括以下几个部分:1.DSP28335的基本结构:学生需要了解DSP28335的内部结构,包括CPU、内存、外围接口等。

2.DSP28335的工作原理:学生需要学习DSP28335的启动、中断、事件管理等方面的知识。

3.DSP28335的编程方法:学生需要掌握DSP28335的编程语言和编程技巧,包括C语言和汇编语言。

4.DSP28335的应用案例:学生需要学习DSP28335在实时控制、信号处理等领域的应用实例。

教学内容按照教材的章节顺序进行安排,确保内容的科学性和系统性。

三、教学方法为了达到课程目标,本课程将采用多种教学方法,包括:1.讲授法:教师通过讲解DSP28335的基本概念和原理,使学生掌握相关知识。

2.讨论法:学生分组讨论实际案例,培养学生的思考能力和团队合作意识。

3.案例分析法:分析DSP28335在实际项目中的应用,帮助学生理解理论知识。

4.实验法:学生动手进行实验,巩固所学知识,提高实际操作能力。

通过多样化的教学方法,激发学生的学习兴趣和主动性,提高教学质量。

四、教学资源为了支持教学内容和教学方法的实施,本课程将准备以下教学资源:1.教材:选用《DSP28335原理与应用》作为主教材,辅助以相关参考书籍。

TMS320F28335笔记-I2C串行总线

TMS320F28335笔记-I2C串行总线

I2C串行总线I2C总线只有两根双向信号线。

一根是数据线SDA,另一根是时钟线SCL。

I2C总线通过上拉电阻接正电源。

当总线空闲时,两根线均为高电平。

连到总线上的任一器件输出的低电平,都将使总线的信号变低,即各器件的SDA及SCL都是线“与”关系。

每个接到I2C总线上的器件都有唯一的地址。

主机与其它器件间的数据传送可以是由主机发送数据到其它器件,这时主机即为发送器。

由总线上接收数据的器件则为接收器。

I2C总线的数据传送一、数据位的有效性规定I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许变化。

二、起始和终止信号SCL线为高电平期间,SDA线由高电平向低电平的变化表示起始信号;SCL线为高电平期间,SDA线由低电平向高电平的变化表示终止信号。

起始和终止信号都是由主机发出的,在起始信号产生后,总线就处于被占用的状态;在终止信号产生后,总线就处于空闲状态。

连接到I2C总线上的器件,若具有I2C总线的硬件接口,则很容易检测到起始和终止信号。

三、数据传送格式(1)字节传送与应答每一个字节必须保证是8位长度。

数据传送时,先传送最高位(MSB),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有9位)。

由于某种原因从机不对主机寻址信号应答时(如从机正在进行实时性的处理工作而无法接收总线上的数据),它必须将数据线置于高电平,而由主机产生一个终止信号以结束总线的数据传送。

如果从机对主机进行了应答,但在数据传送一段时间后无法继续接收更多的数据时,从机可以通过对无法接收的第一个数据字节的“非应答”通知主机,主机则应发出终止信号以结束数据的继续传送。

当主机接收数据时,它收到最后一个数据字节后,必须向从机发出一个结束传送的信号。

这个信号是由对从机的“非应答”来实现的。

然后,从机释放SDA线,以允许主机产生终止信号。

(2)数据帧格式I2C总线上传送的数据信号是广义的,既包括地址信号,又包括真正的数据信号。

DSP实验五、TMS320F28335-串口通信实验

DSP实验五、TMS320F28335-串口通信实验

TMS320F28335串口通信实验实验目的:掌握TMS320F28335串口的使用;实现功能:1、与电脑232 接口通讯,波特率9600 8N1;2、电脑发送数据,开发板原数据返回;基础知识:TMS320F28335的3个功能相同的SCIA、SCIB、SCIC模块,都可以看做是UART串口;每个串口各有一个接收器、一个发送器。

接收器和发送器各有一个16级深度的FIFO,他们都还有自己的使能和中断位。

若要使SCI模块工作,DSP需要做如下设置:◆使用GPIOMUX寄存器将对于的GPIO设置为SCIx功能;◆将sysclkout经过低速预定标器之后输出低速时钟LSPCLK供给SCIx;◆使能SCIx相关时钟,即PCLKCR寄存器中的SCIxENCLK置1;◆通信格式、波特率、需要用到FIFO的情况,可以使能FIFO、使能中断等;实现步骤:1、初始化串口IO引进为串口功能;开发板串口连接图,如上图,XRnW为SCITXDA、GPIO35复用引脚;XZCS0n为SCIRXDA、GPIO36复用引脚;2、设置串口相关寄存器、波特率等;3、设置串口中断接收函数;4、设置串口查询发送函数;遇到的问题:1、中断发生后,要记得清PIEACK中断响应寄存器,否则只中断一次,以后再也不进入中断了,串口中断在读数据后会自动清中断标志。

每个外设中断响应后,一定要对PIEACK的相关位进行软件复位,否则同组内的其他中断都不会被响应。

2、了解SCI功能应参考《MS320x2833x, 2823x Serial Communications Interface (SCI)》3、串口端口IO设置成内部上拉、Rx端还应设为异步输入;具体SCI部分程序如下:/** ======= sci_uart ========*** Created on: 2017年9月19日* Author: liu*/#include"DSP2833x_Device.h"// DSP2833x Header File#include"DSP2833x_Examples.h"// DSP2833x Examples Include File#include"sci_uart.h"__interrupt void sciaRxIsr(void);/** ======== sci_uart_init ========*/void SCIA_uart_init(void){//GPIO35、36复用功能选择EALLOW;GpioCtrlRegs.GPBMUX1.bit.GPIO35 = 1 ; //SCIA_TXDAGpioCtrlRegs.GPBMUX1.bit.GPIO36 = 1 ; //SCIA_RXDAGpioCtrlRegs.GPBPUD.bit.GPIO35 = 0; // Enable pull-up for GPIO29 (SCITXDA)GpioCtrlRegs.GPBPUD.bit.GPIO36 = 0; // Enable pull-up for GPIO28 (SCIRXDA)//定义管脚为异步输入GpioCtrlRegs.GPBDIR.bit.GPIO36 = 0 ;//输入GpioCtrlRegs.GPBQSEL1.bit.GPIO36 = 3;//异步输入EDIS;//基本通信参数设置// Note: Clocks were turned on to the SCIA peripheral// in the InitSysCtrl() functionSciaRegs.SCICCR.all =0x0007; // 1 stop bit, No loopback// No parity,8 char bits,// async mode, idle-line protocolSciaRegs.SCICTL1.all =0x0003; // enable TX, RX, internal SCICLK,// Disable RX ERR, SLEEP, TXWAKESciaRegs.SCICTL2.all =0x0003;SciaRegs.SCICTL2.bit.TXINTENA =0; //查询发送SciaRegs.SCICTL2.bit.RXBKINTENA =1;//中断接收SciaRegs.SCIHBAUD=488>>8;// 9600 135MHz@LSPCLK = 33.75MHz /(9600*8)-1=4394 150MHz@LSPCLK = 37.5MHz /(9600*8)-1=488SciaRegs.SCILBAUD=488;SciaRegs.SCICTL1.all =0x0023; // Relinquish SCI from Reset// Initialize the SCI FIFO 禁止FIFO功能SciaRegs.SCIFFTX.bit.SCIFFENA = 0 ; //禁止SCI FIFO功能EALLOW;// This is needed to write to EALLOW protected registersPieVectTable.SCIRXINTA = &sciaRxIsr;EDIS;// This is needed to disable write to EALLOW protected registersPieCtrlRegs.PIEIER9.bit.INTx1=1;// PIE Group 9, int1IER |= M_INT9;// Enable CPU INTEINT;}void SCIA_UART_Send_Byte( unsigned char Dat){while(SciaRegs.SCICTL2.bit.TXRDY !=1);//等待SCIRXBUF准备好才写入下一个所要发送的数据SciaRegs.SCITXBUF = Dat;}//SCIA串口中断接收处理函数__interrupt void sciaRxIsr(void){if(SciaRegs.SCIRXST.bit.RXRDY == 1){SCIA_UART_Send_Byte( SciaRegs.SCIRXBUF.bit.RXDT );}PieCtrlRegs.PIEACK.all=PIEACK_GROUP9;}。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

DSP I2C 应用说明1.示例程序中几种状态第一次看i2c_eeprom示例程序,对程序中的MsgStatus信息状态切换非常懵懂,为什么要有这几个状态?状态切换顺序如何安排?一大堆的状态,让人有些摸不着头脑。

先把程序中的头文件涉及的7种状态分析一下。

// I2C Message Commands for I2CMSG struct#define I2C_MSGSTAT_INACTIVE 0x0000 //未激活状态:一般成功发送数据或者//接受数据后可以设置信息状态为此状态,告诉用户可进行下一次的写数据或读数据。

#define I2C_MSGSTAT_SEND_WITHSTOP 0x0010 //发送带停止位数据:这是为写数据而设///的状态,写入地址和数据之后发个停止位告诉存储器数据写入完毕。

#define I2C_MSGSTAT_WRITE_BUSY 0x0011 //写数据忙状态:在将待写的数据放入//缓存后,就可以使能IIC传输数据了,然后把信息状态设为该状态,意在告诉用户:数据//已经在传送过程中。

当然是否传送完毕,还需要通过查询SCD位来判断。

#define I2C_MSGSTAT_SEND_NOSTOP 0x0020//发送无停止位数据:这个状态是为了读//取数据而设的,有查阅过AT24C1024EEPROM存储器使用手册的读者知道,在读数据之前//要发送数据的地址,发完地址不能产生停止位,这是存储器硬件设计决定的。

设为这个状//态意在告诉读者,可以发送要读取的数据的地址了。

#define I2C_MSGSTAT_SEND_NOSTOP_BUSY 0x0021//发送无停止位数据忙状态:这个状态是//为了读取数据而设的,似于I2C_MSGSTAT_WRITE_BUSY,说明地址数据已经在传送过程中。

//传送是否成功,还要看ARDY的状态。

#define I2C_MSGSTAT_RESTART 0x0022//重发开始位状态:这个状态也是为读取////数据而设。

我们知道,读取存储器数据主要分两个步骤:第一,发送START位+设备地址//+数据地址+无停止位。

第二,再发START位+设备地址,紧接着存储器发送数据到IIC接收//缓存器(I2CDRR),接收到设定好的数据数量(I2CCNT值)时输出停止位STOP.//值得注意的是:理论上写完数据就能马上读取数据,但事实上EEPROM存储器仍需要一////定延时来存储数据,约有2ms左右。

通过示波器可以观察到,写完数据后,并不能马上//成功读取数据,也就是说读数据的第一步骤要重复好几次(总线为50K时,大约要重复//8次)才能成功。

#define I2C_MSGSTAT_READ_BUSY 0x0023//读取数据忙状态:这个状态是为读取数//据而设。

在读数据的第二步骤中,发完START位+设备地址后,就设为这一状态。

意在说//明IIC开始等待接收固定数量(I2CCNT值)的数据。

可以通过查询ARDY位判断。

//头文件中的其他定义应该没什么大问题了!2.AT24C1024 EEPROM读写数据格式(2)单字节写入:START -> 发送从设备地址(写控制码R/W=0) -> 处理Ack -> 发送字节地址 -> 处理Ack [-> 发送1字节数据 -> 处理Ack] -> STOP。

如下图:(3)按页写入:START -> 发送从设备地址(写控制码R/W=0) -> 处理Ack -> 发送字节地址 -> 处理Ack [-> 发送1字节数据 -> 处理Ack-> 发送第2字节数据 -> 处理Ack-> 发送第3字节数据 -> 处理Ack……直到发完X字节] -> STOP。

如下图。

注意,连续写入的数据字节数不能超过每页所能容下的总量。

如果写入的数据超过一页的长度,将发生回卷,即从EEPROM的0地址处进行数据覆盖。

比如,AT24C1024有512页,每页最大容纳256字节。

超过这个长度,地址指针将从每页首地址重新开始。

(4)随机单字节读取:第一步:发START -> 发送从设备地址(写控制码R/W=0) -> 处理Ack -> 发送字节地址高位 -> 处理Ack -> 发送字节地址低位 -> 处理Ack ->第二步:发START -> 发送器件地址(读控制码R/W=1) -> 处理Ack -> 接收1字节数据 -> STOP。

(5)随机连续读取:在随机单字节读取操作的STOP信号发送之前,加入若干个[-> 发送Ack -> 接收1字节数据] 即可实现。

(6)当前位置单字节读取:START -> 发送从设备地址(读控制码) -> 处理Ack -> 发送字节地址 -> 处理Ack -> 接收1字节数据 -> STOP。

当前指的是之前进行过读取操作但是没有发送STOP信号,EEPROM芯片内部指针所在的位置即为当前位置。

(7)当前位置连续读取:在当前位置单节读取操作的STOP信号发送之前,加入若干个 [-> 发送Ack -> 接收1字节数据] 即可实现。

备注:部分内容引用百度文库中的《I2C读写流程》文档3.主程序说明及流程图详细的注释可以参见程序附录,,这里主要解释一下设备地址取0x50的缘由。

从AT24C1024的数据手册可知,设备地址为。

而在程序中设置的地址是0x50,即0B0101 0000。

看似不妥,其实,这个例子中设备地址采用7位地址模式,这样只取0x50的低7位作为设备地址的高七位,设备地址的最低位R/W则由寄存器I2CMDR中的TRX位决定。

这样读数据时设备地址为0B1010 0001,写数据时设备地址改为0B1010 0000。

通过示波器可以验证这些数据。

问题1:每次检测到SCD中断时,也就是顺利发完指定数量的数据或者接收指定数量的数据了,理论上I2caRegs.I2CCNT==0,但是本人设了几个中断点去观察该寄存器的值,发现总是不为零。

通过观察I2caRegs.I2CFFTX.bit.TXFFST和I2caRegs.I2CFFRX.bit.RXFFST,可以发现这两个寄存器为零时,I2caRegs.I2CCNT也不为零。

由此可知,I2CCNT不能实时反映发送/接收存储器中数据的数量,不过可以用TXFFST/RXFFST来代替。

图1 主程序流程图,图2为写数据程序流程图,图3为读数据程序流程图,图4为中断函数流程图。

图2写数据程序流程图图3读数据程序流程图4.程序附录//可以用以下代码替换示例程序Example_280xI2c_eeprom.c中的代码,再进行调试。

// //该程序跟原始程序没多大区别,主要改变为:引入几个统计变量,改变发送数据长度为2字节// // TI File $Revision: /main/5 $// Checkin $Date: April 4, 2007 17:18:36 $//###########################################################################//// FILE: Example_280xI2c_eeprom.c//// TITLE: DSP280x I2C EEPROM Example//// ASSUMPTIONS://// This program requires the DSP280x header files.//// This program requires an external I2C EEPROM connected to// the I2C bus at address 0x50.//// As supplied, this project is configured for "boot to SARAM"// operation. The 280x Boot Mode table is shown below.// For information on configuring the boot mode of an eZdsp,// please refer to the documentation included with the eZdsp,//// Boot GPIO18 GPIO29 GPIO34// Mode SPICLKA SCITXDA// SCITXB// -------------------------------------// Flash 1 1 1// SCI-A 1 1 0// SPI-A 1 0 1// I2C-A 1 0 0// ECAN-A 0 1 1// SARAM 0 1 0 <- "boot to SARAM"// OTP 0 0 1// I/0 0 0 0//// DESCRIPTION://// This program will write 1-14 words to EEPROM and read them back.// The data written and the EEPROM address written to are contained// in the message structure, I2cMsgOut1. The data read back will be// contained in the message structure I2cMsgIn1.// --------------------------------------------------------------// CODE MODIFICATIONS ARE REQUIRED FOR 60 MHZ DEVICES (In// DSP280x_Examples.h in the common/include/ directory, set// #define CPU_FRQ_60MHZ to 1, and #define CPU_FRQ_100MHZ to 0).// --------------------------------------------------------------// This program will work with the on-board I2C EEPROM supplied on// the F280x eZdsp.//////###########################################################################// Original Author: D.F.//// $TI Release: DSP280x Header Files V1.60 $// $Release Date: December 3, 2007 $//############################################################################include "DSP280x_Device.h" // DSP280x Headerfile Include File#include "DSP280x_Examples.h" // DSP280x Examples Include File// Note: I2C Macros used in this example can be found in the// DSP280x_I2C_defines.h file// Prototype statements for functions found within this file.void I2CA_Init(void);Uint16 I2CA_WriteData(struct I2CMSG *msg);Uint16 I2CA_ReadData(struct I2CMSG *msg);interrupt void i2c_int1a_isr(void);void pass(void);void fail(void);#define I2C_SLAVE_ADDR 0x50 //EEPROM地址#define I2C_NUMBYTES 2 //为方便示波器观察,设置发送2字节的数据#define I2C_EEPROM_HIGH_ADDR 0x11 //数据的写入地址高位#define I2C_EEPROM_LOW_ADDR 0x0F //数据的写入地址低位// Global variables//全局变量// Two bytes will be used for the outgoing address,//有2个字节是地址// thus only setup 14 bytes maximum//最多只能设置14字节数据struct I2CMSG I2cMsgOut1={I2C_MSGSTAT_SEND_WITHSTOP,//初始状态为:发送带停止位数据 I2C_SLAVE_ADDR,I2C_NUMBYTES,I2C_EEPROM_HIGH_ADDR,I2C_EEPROM_LOW_ADDR,0xff, // Msg Byte 010x3F, // Msg Byte 020x56, // Msg Byte 030x78, // Msg Byte 040x9A, // Msg Byte 050xBC, // Msg Byte 060xDE, // Msg Byte 070xF0, // Msg Byte 080x11, // Msg Byte 090x10, // Msg Byte 100x11, // Msg Byte 110x12, // Msg Byte 120x13, // Msg Byte 130x12, // Msg Byte 14};struct I2CMSG I2cMsgIn1={ I2C_MSGSTAT_SEND_NOSTOP,I2C_SLAVE_ADDR,I2C_NUMBYTES,I2C_EEPROM_HIGH_ADDR,I2C_EEPROM_LOW_ADDR};struct I2CMSG *CurrentMsgPtr; // Used in interrupts Uint16 PassCount;Uint16 FailCount;Uint16 ARDY_ISRC_NACK_number=0; //统计ARDY中断源引起的中断中NACK次数Uint16 SCD_ISRC_number=0; //统计SCD中断源引起的中断次数Uint16 ARDY_ISRC_number=0; //统计ARDY中断源引起的中断次数Uint16 all_ISRC_number=0; //统计所有中断源引起的中断次数Uint16 Write_load_num=0; //统计写数据函数调用次数Uint16 Read_load_num1=0; //统计读数据函数调用次数1第一步骤Uint16 Read_load_num2=0; //统计读数据函数调用次数2第二步骤void main(void){Uint16 Error;Uint16 i;CurrentMsgPtr = &I2cMsgOut1;// Step 1. Initialize System Control:// PLL, WatchDog, enable Peripheral Clocks// This example function is found in the DSP280x_SysCtrl.c file.InitSysCtrl();// Step 2. Initalize GPIO:// This example function is found in the DSP280x_Gpio.c file and// illustrates how to set the GPIO to it's default state.// InitGpio();// Setup only the GP I/O only for I2C functionalityInitI2CGpio();// Step 3. Clear all interrupts and initialize PIE vector table:// Disable CPU interruptsDINT;// Initialize 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 DSP280x_PieCtrl.c file.InitPieCtrl();// Disable CPU interrupts and clear all CPU interrupt flags:IER = 0x0000;IFR = 0x0000;// Initialize 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 DSP280x_DefaultIsr.c.// This function is found in DSP280x_PieVect.c.InitPieVectTable();// Interrupts that are used in this example are re-mapped to// ISR functions found within this file.EALLOW; // This is needed to write to EALLOW protected registersPieVectTable.I2CINT1A = &i2c_int1a_isr;EDIS; // This is needed to disable write to EALLOW protected registers// Step 4. Initialize all the Device Peripherals:// This function is found in DSP280x_InitPeripherals.c// InitPeripherals(); // Not required for this exampleI2CA_Init();// Step 5. User specific code// Clear CountersPassCount = 0;FailCount = 0;// Clear incoming message bufferfor (i = 0; i < I2C_MAX_BUFFER_SIZE; i++){I2cMsgIn1.MsgBuffer[i] = 0x0000;}// Enable interrupts required for this example// Enable I2C interrupt 1 in the PIE: Group 8 interrupt 1PieCtrlRegs.PIEIER8.bit.INTx1 = 1;// Enable CPU INT8 which is connected to PIE group 8IER |= M_INT8;EINT;// Application loopfor(;;){//////////////////////////////////// Write data to EEPROM section ////////////////////////////////////// Check the outgoing message to see if it should be sent.// In this example it is initialized to send with a stop bit.if(I2cMsgOut1.MsgStatus == I2C_MSGSTAT_SEND_WITHSTOP){ Write_load_num++;Error = I2CA_WriteData(&I2cMsgOut1);// If communication is correctly initiated, set msg status to busy//如果通信已经正确初始化,设置msg状态为’忙‘,并// and update CurrentMsgPtr for the interrupt service routine. //更新作为中断服务路径的指针CurrentMsgPtr。

相关文档
最新文档