- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
BIT_BAND(帮你理解M3的位断区)
摘录的Chuzhujun的一点经验,和大家一起分享!首先追溯到51,51单片机RAM内从从20H往后到3FH是位访问区,每一个字节的每一个位也对应有从00h开始的的每一个字节的最后一位,例如20H.0对应00h,20H.1对应于01h,.....其中00h,01h中起作用的也只是最后一位,其他位都是没意义的,又如FLAG1?BIT?00H,这样的话如果Setb?FLAG1?这条语句执行,实际上市对RAM中20H这个字节的Bit0置一了,由此看来,这能ARM也是受Intel的影响和启发啊!其次:开始讲cm3的BIT_BAND,处理器存储器映射包括两个?bit-banding?区域。它们分别为?SRAM?和外设存储区域中的最低的?1MB。这些?bit-band?区域将存储器别名区的一个字映射为?bit-band?区的一个位。?请看下图:file:///C:/Documents%20and%20Settings/jishu/桌面/isp/未命名.jpg图中1M的??bit??band区域的每一个字节的每一位分别有?bit??band别名区的每一个字(四字节)对应,那么,这是不是和51的位区原理一样啊?呵呵,但是我们要知道,这里的位区可不是51里面的那么几十个字节啊,而是偌大的空间,很多人会认为,这样好浪费啊,每一个位对应一个字,那么这个字的其他剩余31个字节就等于是浪费的啊,虽然这是对的,是有点浪费,但是这样做的好处是不可估量的,想象看吧,我们这么举个例子来看看,就比如说现在忘SRAM的首地址写一个字节吧,也就是地址:0x2000?0000?,但是我们想往0x2000?0000?这个字节的bit?3写1而保证其他的位都不发生变化,我们会怎么做,当然了,这肯定都会,就是一个读-修改-写的过程嘛,首先读出来这个字节给一个temp临时字节类型变量,然后相与,然后再把temp给0x2000?0000完成位修改的操作?,这样麻烦啊,还要定义一个变量,还一不小心把别的位也改变了,岂不出问题?现在好了,我们知道0x2000?0000这个字节对应的bit?0位是对应在别名区的0x2200?0000?往后的一个字(四字节)中,那么,我现在直接像这个别名区写一个最后一位为1就可以了的一个字:(*(u32?*)?0x2200?000b)?=?1,这样一条语句就可以往0x2000?0000?这一字节的bit?3写1了,不用定义变量,不用担心会影响其他位,这样带来的好处同刚才我们认为的浪费空间的想法来比,不言而喻啦!第三:方法和思想都清楚啦,接下来就是要寻找一个有效的方法来高效的写入啦,否则要是这样写一个位都算老半天该往那一个别名区的地址里写数,那可就麻烦了,所以请大家先看一个图,我手画然后扫描上去的,不是很好看,大家将就着看吧,别因为我图画的不好就认为我人品不好啊,我可是花了半天时间扫描的呢:C:Documents?and?Settingsjishu桌面isp1.jpgCortex-M3?存储器映射有?2?个?32MB?别名区,它们被映射为两个?1MB?的?bit-band?区:?32MB?SRAM?别名区和32MB?外设别名区,我这里图示的是SRAM位区同他们的别名区所对应的关系:SRAM是从0x2000?0000?开始的,他的别名区是从0x2200?0000?开始的,这一点首先要弄清楚,0x2000?0000的每一个位对应于0x2200?0000?往后的一个一个字,如:(0x2200?0000).0对应0x2200?0000?~0x2200?0003这一个字空间,你只需要定义一个指向32位地址的指针:(u32?*)?0x2200?0000,往这个指针对应的地址中写1就是对:(0x2200?0000).0这一位置一,写0就是清零,诚然,这个别名区的一个字中,1到31位都没有用到,也就是我们先前所说的浪费空间问题,不过优点已经很明显了!依此类推,向图中的0x2000?4001的第?3位,图上是BIT?3(我这里没有将第一位写成BIT0)写1,那么由途中对应的关系,我们就应该向0x2208?0024地址往后的四个字节中写1即:???*((u32?*)0x2208?0024)=1;这怎么用公式算呢,很好算,首先我们先确定两个区的基地址,我现在要向?0x2000?4001的第三位写一,它偏移了0x2000?0000?一共是(0x2000?4001?-0x2000?0000)个字节外加3位,而图中我们可以看到,位区的每一个字节的每一个位对应别名区中四个字节,所以总的表达式是:0x2200?0000?+(0x2000?4001?-0x2000?0000)*8*4??+3*4???这样表达式就小荷才露尖尖角啦:会变的部分有两个:
您可能关注的文档
- 2011年经销商销售合同表模.doc
- 2011年考公务员必看6.doc
- 2011年考研数学终极复习夺分高招.doc
- 2011年药物经济学试题C.doc
- 2011年芜湖市国民经济和社会发展统计公报.doc
- 2011年考纲解读1.ppt
- 2011年设备部年度总结.doc
- 2011年迎新晚会策划.doc
- 2011年退管总支工作总结.doc
- 2011年遵义市中考模拟考试语文.doc
- 《产后盆底康复治疗对盆底功能障碍性疾病患者盆底神经功能的影响》教学研究课题报告.docx
- 《农业新型经营主体培育政策与农村土地经营权流转市场体系完善研究》教学研究课题报告.docx
- 2025年化工环保技术:海水提溴吸附剂制备创新成果发布.docx
- 基于生成式AI的中学物理实验数据分析与问题解决能力培养研究教学研究课题报告.docx
- 基于人工智能的教育扶贫模式创新与效果评估研究教学研究课题报告.docx
- 2025年创新:数字医疗影像三维重建技术在军事医学中的应用报告.docx
- 融合学习情感数据分析的初中生学习态度培养与课程设计研究教学研究课题报告.docx
- 基于核心素养的高中语文新教材古诗词教学创新路径研究教学研究课题报告.docx
- 2025年前沿技术:3D打印生物陶瓷材料在医疗领域的创新应用.docx
- 智能校园中人工智能驱动的学习环境自适应调整机制与教师教学评价改革教学研究课题报告.docx
最近下载
- 康明斯KTA系统说明书.docx VIP
- 24J306 窗井、设备吊装口、排水沟、集水坑图集.docx VIP
- 牙体牙髓常见疾病及其治疗 PPT.ppt VIP
- 2025-2026学年浙美版(2024)小学美术三年级上册(全册)教学设计(附目录P202) .pdf
- 《债权法教学资料》债权法复习提纲 来源.doc VIP
- 浙江维思通新材料有限公司年产 20000 吨锂电池新型材料项目环评报告.docx VIP
- 停电挂牌规定及停电操作票规定.pptx
- 政府信息公开培训课件.pptx VIP
- 2025年中级印前处理和制作员(四级)技能认定理论考试题库(含答案).docx
- 社会工作理论基础(李迎生-社会工作概论).doc VIP
文档评论(0)