pic单片机EEPROM怎么编写程序?

pic单片机EEPROM怎么编写程序?,第1张

在你的C文件里引用EEPROM函数的头文件,eeprom_routines.h

然后在程序中使用

voideeprom_write(unsignedcharaddr,unsignedcharvalue)

unsignedchareeprom_read(unsignedcharaddr)

这两个函数了。

这两个函数一个读一个写。比如你想写0x10到地址为0x55的EEPROM,

就写:eeprom_write(0x55,0x10)

同理,如果想读取0x55地址处的值,

就写:ee_value=eeprom_read(0x55)

如果编译时编译器提示找不到eeprom_routines.h,可以在

X:\ProgramFiles\HI-TECHSoftware\PICC\9.81\include 目录下找,然后复制到自己项目文件夹下。

对了,我用的是MPLabIDE,编译器使用的是PICC。

接上ICD2,然后选debugger,中的select tools中的 MPLAB ICD2,连接上ICD2后,选择debugger菜单中的Read就能把程序读进来。

在VIEW菜单中的Program Memory就能看到程序。读到的是没有宏指令的汇编语句

INDF 和 FSR两个寄存器构成了一个间接寻址的作用。

FSR有点像C语言中的指针,INDF是一个虚拟的寄存器,对它 *** 作其实是对FSR锁指向的内存单元 *** 作。

简单的说,当20h这个数赋给了FSR,那么就是FSR作为指针指向了内存中地址为20h的这个单元(以下就用<20h>来表示这个单元,以区别十六进制的20h这个数值),此时INDF就被映射到<20h>。

从头说起:

1:W被赋值20h这个数;2:FSR被赋值和W寄存器相同的数20H,此时FSR指向了<20h>;3:此时W寄存器因为没被改变过,所以其数值依然是十六进制的20h那么MOVWF 20H其实就是把W里的数据赋值给<20h>这个内存单元 也就是 <20h>= 20H;

4:重点来了 INCF INDF,让INDF自加1。前面说了对INDF *** 作其实就是对FSR所指向的单元 *** 作,也就等同于 INCF <20h>(真正程序里不能这么写的,因为<20h>这杨写法是错误的) 类似C与语言中的<20h>++

5:FSR自加1,FSR内部的值等于21h所以FSR指向了<21h>这个内存单元。

6:<20h>单元的数值高4位和低4位转换一下数据。所以 <20h>= 02h

7:把<20h>的内容赋值给W寄存器,所以w = 02h

8:FSR此时 等于21h ,把21h和W的02h做与运算,结构 0 赋值给FSR。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11258005.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存