原创 经验谈:基于MSP430单片机的虚拟I²C总线软件包 汇编语言

2019-9-28 10:47 731 3 3 分类: MCU/ 嵌入式 文集: 程序设计

阅读本刊所载的何立民教授《按平台模式设计的虚拟I2C总线软件包VIIC》(简称何文)一文后,深感可以将这一方法推广到别的单片机上,这样使用户可利用通用I/O口的模拟,随意规定虚拟I2C总线端口,扩大了虚拟I2C总线应用的灵活性。根据文中所提出的前归一化和后归一化等设计原则,本人设计了基于MSP430单片机的虚拟I2C总线软件包VIIC_M1.0。

一、VIIC_M1.0软件包的组成

  根据归一化设计的要求,主方式下虚拟I2C总线由下列10个子程序组成:

  ①  时序模拟子程序4个:

  I2C_Sta,I2C_Stop,I2C_Mack,I2C_Mnack

  ②  操作模拟子程序3个:

  I2C_Ackn, I2C_WR_Byte, I2C_RD_Byte

  ③  数据读写子程序3个:

  I2C_WR_NByte,I2C_RD_NByte,I2C_WR_Addr

  下载软件包的程序清单[3K大小]

二、应用对象

  1. MSP430单片机

  MSP430单片机为低功耗的16位单片机,有MSP430×11x、MSP430×112、MSP430×1101、MSP430×13x、MSP430×14x、MSP430×31x、MSP430×32x、 MSP430×33x等型号,每种芯片都有丰富的I/O端口。

  本设计所使用的芯片为MSP430E325。

  (1)  虚拟I2C总线所使用的I/O端口

  ①  数据线(SDA)使用的是通用端口P0中的 P0.7。该端口为输入/输出双向口,有输入寄存器(P0IN)、输出寄存器(P0OUT)及方向寄存器(P0DIR)等寄存器,通过字节指令访问。

  ②  时钟线(SCL)使用的是通用定时器/端口TP中的TP.1。该端口为输出口,有定时器/端口控制寄存器(TPCTL)、定时器/端口数据寄存器(TPD)及定时器/端口允许寄存器(TPE)等,通过字节指令访问。

  (2)  运行时所使用的时钟频率

  MSP430E325运行时用两个时钟:辅助时钟(ACLK)和主时钟(MCLK)。当采用32768kHz的晶体振荡器,并且系统时钟控制寄存器采用缺省值时,主时钟的频率为1.049MHz。

  若主时钟的频率不是1.049MHz,请适当调整程序中nop的个数。

  2. EEPROM器件

  (1)  EEPROM器件

  本例使用的EEPROM器件为24LC65(MICROCHIP)。24LC65(MICROCHIP)容量为8KB,其中的字节地址为13位,分两个字节:

  Subaddr_H为高5位地址;

  Subaddr_L为低8位地址。

  24LC65(MICROCHIP)的封装引脚如图1所示。


图1  24LC65的封装引脚

  (2)  24LC65的数据格式

  ①  当前地址写:

  S,SLA+W,A,DATA1,A,DATA2,A,…,DATAn,A,P

  ②  当前地址读:

  S,SLA+R,A,DATA1,A,DATA2,A,…,DATAn,/A,P

  ③  指定地址写:

  S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,DATA1,A,DATA2,A,…,DATAn,A,P

  ④  指定地址读:

  S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,

  S,SLA+R,A,DATA1,A,DATA2,A,…,DATAn,/A,P

  其中:

  SLA+W,SLA+R,Subaddr_H,Subaddr_L 为主控器件发出的数据

  S,A,/A,P 为主控器件发出的信息

  DATA1,DATA2,…,DATAn 为被控器件发给主控器件的数据

  A 为被控器件发给主控器件的信息

  (3)  24LC65与MSP430-325的连接

  24LC65与MSP430-325的连接如图2所示。


图2  MSP430与EEPROM 24LC65连接示意图

三、应用界面

  1. 发送N字节数据--从当前地址开始

  ;发送的数据在MTD中  ;

  ;数列格式: S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,DATA1,A,DATA2,A,…,DATAn,A,P  ;

  MOV.b #CODE,SLA ;I2C_R_R/W=0,

  ;A0=A1=A2=0

  MOV.b #N,Num_byt ;发送字节数

  CALL I2C_WR_Nbyte ;从当前地址开始写

  2. 接收N字节数据--从指定地址开始读

  ;接收的数据在MRD中   ;

  ;数列格式:S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,

  S,SLA+R,A,DATA1,A,DATA2,A,…,DATAn,/A,P

  MOV.b #CODE+SLAR/W,SLA

  ;SLAR/W=1,A0=A1=A2=0

  MOV.b #N,Num_byt ;接收字节数

  CALL #I2C_RD_Nbyte ;从当前地址开始读

  3. 接收N字节--从指定地址开始读

  ;接收的数据存放在MRD中   ;

  ;数列格式:S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,

  ; S,SLA+R,A,DATA1,A,DATA2,A,…,DATAn,/A,P   ;

  MOV.b #CODE,SLA

  ;SLAR/W=0:写,A0=A1=A2=0

  MOV.b #N,Num_byt ;接收字节数

  MOV #Subaddr,I2C_R_Addr

  ;字节地址送入暂存单元

  CALL #I2C_WR_Addr ;发送字节地址

  MOV.b #CODE+SLAR/W,SLA

  ;SLAR/W=1:读,A0=A1=A2=0

  CALL #I2C_RD_Nbyte

  4. 发送N字节--从指定地址开始写

  ;数列格式: S,SLA+W,A,Subaddr_H,A,Subaddr_L,A,DATA1,A,DATA2,A,…,DATAn,A,P

  ;

  MOV.b #CODE,SLA

  ;SLAR/W=0:写,A0=A1=A2=0

  MOV.b #N,Num_byt ;发送字节数

  MOV #Subaddr,I2C_R_Addr

  ;字节地址送入暂存单元

  CALL #I2C_WR_Addr ;发送字节地址

  CALL #WR_Nbyte

  后记:

  ①  如果使用MSP430中别的I/O端口,只需要在模拟时序子程序中改动相应的寄存器即可。本例中时钟线使用TP口,是因为它为输出口,在程序中可以节省指令。

  对于24C系列的其它芯片,由于容量不同,请特别注意其字节地址是1个字节还是2个字节。本例的24LC65字节地址就是2个字节的。

  ②  MSP430系列的单片机本人是初学使用,程序虽经初步调试通过,轻易抛出,主意在为引玉之砖,作为学习何文的一点体会。缺点和错误在所难免,望各位不吝指教。

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
3
关闭 站长推荐上一条 /3 下一条