- 1、本文档共26页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
PAGE1
PAGE1
5.内存与存储器结构
5.1内存概述
内存是单片机系统中用于存储数据和程序的重要部分。PIC18F46J50系列单片机拥有多种类型的内存,包括闪存(Flash)、RAM、EEPROM等。了解这些内存的特性和结构对于编写高效、可靠的嵌入式程序至关重要。
5.2闪存(Flash)
闪存是用于存储程序代码的非易失性存储器。PIC18F46J50系列单片机的闪存大小为64KB,分为多个块,每个块可以独立擦除和写入。闪存的主要特性包括:
非易失性:掉电后数据不会丢失。
可编程:可以多次擦除和写入。
高速存取:支持高速读取操作。
5.2.1闪存编程
闪存编程通常通过单片机的编程接口(如ICD或IPE)进行。在程序运行中,也可以通过内部程序实现闪存的擦除和写入操作。
代码示例:闪存编程
//定义闪存编程的相关寄存器
#defineNVMCON0x18E//非易失性存储器控制寄存器
#defineNVMADR0x18C//非易失性存储器地址寄存器
#defineNVMADRU0x18F//非易失性存储器地址寄存器高位
#defineTBLPTR0x190//表指针寄存器
#defineTABLAT0x193//表寄存器
#defineEECON10x187//EEPROM控制寄存器
//闪存编程函数
voidFlash_Write(uint32_taddress,uint16_tdata){
//禁止所有中断
INTCON=0;
//设置闪存地址
NVMADR=(uint16_t)(address0xFFFF);
NVMADRU=(uint8_t)((address16)0xFF);
//设置闪存数据
TABLAT=(uint8_t)data;
TBLPTR=(uint32_t)address;
EECON1=0x00;
//配置NVMCON寄存器
NVMCON=0x4000;//设置闪存编程模式
//写入数据
asm(disi#2);//禁止中断2个指令周期
EECON1=0x55;//写入特殊值
EECON1=0xAA;//写入特殊值
NVMCON=0x4001;//启动编程操作
//等待编程完成
while(NVMCONbits.WR==1);
//重新启用中断
INTCON=0x00FF;
}
5.3RAM
RAM是用于存储程序运行时变量和数据的易失性存储器。PIC18F46J50系列单片机的RAM大小为3936字节,分为多个银行(Bank)。每个银行的地址范围和访问方式不同,了解这些特性有助于优化内存使用。
5.3.1RAM银行切换
PIC18F46J50系列单片机的RAM分为多个银行,通过BSR寄存器进行切换。每个银行的地址范围如下:
Bank0:0x00-0x7F
Bank1:0x80-0xFF
Bank2:0x100-0x17F
Bank3:0x180-0x1FF
Bank4:0x200-0x27F
Bank5:0x280-0x2FF
Bank6:0x300-0x37F
Bank7:0x380-0x3FF
代码示例:RAM银行切换
//定义银行选择寄存器
#defineBSR0x0F
//RAM银行切换函数
voidRAM_SelectBank(uint8_tbank){
BSR=bank;//切换到指定的银行
}
//示例:在Bank1和Bank2之间切换
voidExample_RAM_BankSwitch(){
uint8_tdata1,data2;
//切换到Bank1
RAM_SelectBank(1);
data1=0x55;//写入数据
FSR0=0x80;//设置FSR0指向Bank1的地址0x80
INDF0=data1;//将数据写入Bank1的地址0x80
//切换到Bank2
RAM_SelectBank(2);
dat
您可能关注的文档
- Microchip 系列:PIC18F46J50 系列 (低功耗)_2.PIC18F46J50系列概述.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_3.低功耗特性与设计.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_4.硬件结构与引脚配置.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_6.时钟系统.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_7.电源管理.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_8.复位与低功耗模式.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_9.外设功能.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_10.ADC模块.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_11.DAC模块.docx
- Microchip 系列:PIC18F46J50 系列 (低功耗)_12.I-O端口.docx
文档评论(0)