AiBOM
首页 > 文章 > STM32F103ZET6 > STM32f103ZET6 学习资料 (连载3 存储器和总线构架 )
为您找到相关搜索
STMICROELECTRONICS  STM32F103ZET6  芯片, 微控制器, 32位, ARM CORTEXM3, 72MHZ, 144-LQFP
意法半导体(ST)公司成立于1987年,是意大利SGS半导体公司和法国汤姆逊半导体合并后的新企业,1998年5月,SGS-THOMSON Microelectronics将公司名称改为意法半导体有限公司。从成立之初至今,ST的增长速度超过了半导体工业的整体增长速度。自1999年起,ST始终是世界十大半导体公司之一。整个集团共有员工近50,000名,拥有16个先进的研发机构、39个设计和应用中心、15主要制造厂,并在36个国家设有78个销售办事处。 ST公司位于瑞士日内瓦,同时也是欧洲区以及新兴市场的总部;公司的美国总部设在德克萨斯州达拉斯市的卡罗顿;亚太区总部设在新加坡;日本的业务则以东京为总部;大中国区总部设在上海,负责香港、大陆和台湾三个地区的业务。 意法半导体是业内半导体产品线最广的厂商之一,其主要产品有:分立二极管与晶体管,复杂的片上系统(SoC)器件,包括参考设计、应用软件、制造工具与规范的完整的平台解决方案等3000多种产品。意法半导体是各工业领域的主要供应商,拥有多种的先进技术、知识产权(IP)资源与世界级制造工艺。 半导体产品大体上可分为两类:专用产品和标准产品。专用产品从半导体制造商以及用户和第三方整合了数量众多的专有IP,这些使其区别于市场上的其他产品,例如: 片上系统(SoC)产品,定制与半定制电路,专用标准产品(ASSP),如:无线应用处理器、机顶盒芯片及汽车IC,微控制器,智能卡IC,专用存储器,专用分立器件等,一旦客户在应用中使用了专用产品,如果不修改硬件和软件设计,通常就不能进行产品替换。 相反,标准产品是实现某种特定的常用功能的器件,这些器件一般由几个供应商提供。通常,制造商推出的标准产品可以被其他制造商的同类产品所取代,供应商间的差别主要在于成本与客户服务上。然而,一旦应用设计被冻结,标准器件在性能优化方面也将变成唯一的器件。标准产品包括:分立器件,如晶体管、二极管与晶闸管,功率晶体管,如MOSFET、Bipolar与IGBT,模拟电路构建模块,如运算放大器、比较器、稳压器与电压参考电路,标准逻辑功能与接口,众多存储器产品,如标准或串行NOR闪存、NAND闪存、EPROM/EEPROM及非易失性RAM,射频分立器件及IC。
查看详情
微控制器是将微型计算机的主要部分集成在一个芯片上的单芯片微型计算机。微控制器诞生于20世纪70年代中期,经过20多年的发展,其成本越来越低,而性能越来越强大,这使其应用已经无处不在,遍及各个领域。例如电机控制、条码阅读器/扫描器、消费类电子、游戏设备、电话、HVAC、楼宇安全与门禁控制、工业控制与自动化和白色家电(洗衣机、微波炉)等。
查看详情
热门推荐
元器件的Datasheet PDF数据手册如何阅读?如何快速掌握产品引脚图及功能等关键信息?
元器件的Datasheet PDF数据手册如何阅读?如何快速掌握产品引脚图及功能等关键信息?
基于STC15w408AS的电子时钟的设计
基于STC15w408AS的电子时钟的设计

STM32f103ZET6 学习资料 (连载3 存储器和总线构架 )

小硬件一个 2019-12-30 03:10 8345次阅读 STM32F103ZET6 STM32 微控制器
在小容量、中容量和 大容量产品中,主系统由以下部分构成:
四个驱动单元:
Cortex™-M3内核DCode总线(D-bus),和系统总线(S-bus)
─ 通用DMA1和通用DMA2
四个被动单元
─ 内部SRAM
─ 内部闪存存储器
─ FSMC
─ AHB到APB的桥(AHB2APBx),它连接所有的APB设备
这些都是通过一个多级的AHB总线构架相互连接的。

STM32单片机系统架构

STM32单片机系统架构

Icode总线: 总线连接内核与flash,因为单片机的程序指令都存储在flash里面,程序在运行的时候需要在flash芯片里面读取指令,所以Icode总线也成为指令总线,用来读取运行的指令。
Dcode总线:dcode总线也就是数据总线与闪存存储器的数据接口相连接常量加载与调试仿真。此处常量的是指定义的全局变量。程序在运行期间一直存活的变量。
系统总线 :此总线连接Cortex™-M3内核的系统总线(外设总线)到总线矩阵,总线矩阵协调着内核和DMA间 的访问。
DMA总线: 此总线将DMA的AHB主控接口与总线矩阵相联,总线矩阵协调着CPU的DCode和DMA到 SRAM、闪存和外设的访问
总线矩阵 :总线矩阵协调内核系统总线和DMA主控总线之间的访问仲裁,

仲裁利用轮换算法。(轮换在cpu里面有着至关重要的用途,轮换使内核资源合理的分配,才会使ICODE,DCODE,DMA,进行不阻塞通讯,还是很牛逼的)


在互联型产品中,总线矩阵包含5个驱动部件(CPU的DCode、系统总线、以太网DMA、DMA1总线和 DMA2总线)和3个从部件(闪存存储器接口(FLITF)、SRAM和AHB2APB桥)。在其它产品中总线 矩阵包含4个驱动部件(CPU的DCode、系统总线、DMA1总线和DMA2总线)和4个被动部件(闪存 存储器接口(FLITF)、SRAM、FSMC和AHB2APB桥)。 AHB外设通过总线矩阵与系统总线相连,允许DMA访问。

AHB/APB桥(APB) 两个AHB/APB桥在AHB和2个APB总线间提供同步连接。

APB1操作速度限于36MHz。(APB1总线的最高速度位APB2总线速度的一半)例如挂在APB1上的
APB2操 作于全速(高72MHz)。 表1有关连接到每个桥的不同外设的地址映射请参考 。在每一次复位以后,所有除SRAM和 FLITF以外的外设都被关闭,在使用一个外设之前,必须设置寄存器RCC_AHBENR来打开该外 设的时钟。
注意:

当对 APB 寄存器进行 8 位或者 16 位访问时,该访问会被自动转换成 32 位的访问:桥会自动将 8 位 或者 32 位的数据扩展以配合 32 位的向量。为啥呢?因为stm32使32位单片机。


程序存储器、数据存储器、寄存器和输入输出端口被组织在同一个4GB(2的32次方)的线性地址空间内。 数据字节以小端格式(小端格式:低字节在低地址,高字节在高地址,大端模式:高字节在低地址,低字节在高地址)存放在存储器中。一个字里的低地址字节被认为是该字的低有效字 节,而高地址字节是高有效字节。
可访问的存储器空间被分成8个主要块,每个块为512MB (8*512M=4G),所以把整个存储器4G空间平均分了8份。一些没有被外设等设备使用的空间,暂时把他作为默认,预留。
部分外设寄存器的地址
部分外设寄存器的地址
如图所示:ADC3的起始地址位 从 0x40013C00 到 0x40013FFF 则ADC3外设使用掉了0x40013FFF - 0x40013C00 = 0x3ff 个字节地址 那一个寄存器占用32位 也就是 4个字节。目前ADC3寄存器的位置用到了偏移基地址最大 0x4C 。此时基地址位0x40013C00,则对应adc3的第一个寄存器的位置偏移为0,第二个寄存器偏移就是0x04.........直到最大位0x4c.
其余的都为预留。
部分外设寄存器的地址参考实例
参考文档中的举例
STM32F10xxx内置64K字节的静态SRAM。它可以以字节、半字(16位)或全字(32位)访问。 SRAM的起始地址是0x2000 0000 (我认为此处的静态SRAM,用来存储程序中的静态变量。欢迎讨论)
闪存读取 闪存的指令和数据访问是通过AHB总线完成的。预取模块是用于通过ICode总线读取指令的。仲 裁是作用在闪存接口,并且DCode总线上的数据访问优先。 读访问可以有以下配置选项:
● 等待时间:可以随时更改的用于读取操作的等待状态的数量。
● 预取缓冲区(2个64位):在每一次复位以后被自动打开,由于每个缓冲区的大小(64位)与闪 存的带宽相同,因此只通过需一次读闪存的操作即可更新整个缓冲区的内容。由于预取缓 冲区的存在,CPU可以工作在更高的主频。CPU每次取指多为32位的字,取一条指令 时,下一条指令已经在缓冲区中等待。

● 半周期:用于功耗优化


启动配置
启动配置
启动配置
了解过DSP,FPGA的朋友们应该最熟悉这个启动配置了。
在系统复位后,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。用户可以通过设置BOOT1 和BOOT0引脚的状态,来选择在复位后的启动模式。 在从待机模式退出时,BOOT引脚的值将被被重新锁存;因此,在待机模式下BOOT引脚应保持 为需要的启动配置。在启动延迟之后,CPU从地址0x0000 0000获取堆栈顶的地址,并从启动 存储器的0x0000 0004指示的地址开始执行代码。 因为固定的存储器映像,代码区始终从地址0x0000 0000开始(通过ICode和DCode总线访问), 而数据区(SRAM)始终从地址0x2000 0000开始(通过系统总线访问)。Cortex-M3的CPU始终从 ICode总线获取复位向量,即启动仅适合于从代码区开始(典型地从Flash启动)。STM32F10xxx 微控制器实现了一个特殊的机制,系统可以不仅仅从Flash存储器或系统存储器启动,还可以从 内置SRAM启动。 根据选定的启动模式,主闪存存储器、系统存储器或SRAM可以按照以下方式访问:
● 从主闪存存储器启动:主闪存存储器被映射到启动空间(0x0000 0000),但仍然能够在它原 有的地址(0x0800 0000)访问它,即闪存存储器的内容可以在两个地址区域访问,0x0000 0000或0x0800 0000。
● 从系统存储器启动:系统存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的 地址(互联型产品原有地址为0x1FFF B000,其它产品原有地址为0x1FFF F000)访问它。

● 从内置SRAM启动:只能在0x2000 0000开始的地址区访问SRAM


注 意 : 当 从 内 置 SRAM 启动,在应用程序的初始化代码中,必须使用 NVIC 的异常表和偏移寄存器,从 新映射向量表之 SRAM 中。

内嵌的自举程序 内嵌的自举程序存放在系统存储区,由ST在生产线上写入,用于通过可用的串行接口对闪存存 储器进行重新编程:


● 对于小容量、中容量和大容量的产品而言,可以通过USART1接口启用自举程序。进一步的 细节请查询AN2606。

● 对于互联型产品而言,可以通过以下某个接口启用自举程序:USART1、USART2(重映像 的)、CAN2(重映像的)或USB OTG全速接口的设备模式(通过设备固件更新DFU协议)。 USART接口依靠内部8MHz振荡器(HSI)运行。CAN和USB OTG接口只能当外部有一个 8MHz、14.7456MHz或25MHz时钟(HSE)时运行


温馨提示:本文由网友投稿,经网站编辑整理发布,转载请注明出处和本文链接,如有侵犯您的权益,请及时与我们联系,我们将核实情况后进行相关处理!
相关推荐
STM32F302简介
STM32F302简介
STM32F302是ARM集团旗下的一款芯片(属于Cortex-M3)。 首先,让我们先来了解一下ARM的发展史
STM32F302 / STM32 / ARM 3296
STM32F401的RCC时钟配置
STM32F401的RCC时钟配置
需要使用STM32F401的大内存特性,买了1批STM32F401CCU6. QFN48封装的。随便翻了一下PDF,第一感觉和F103的48脚封装差不太多,于是将F103的板子改了个QFN48的封装就打样了。。。
STM32F401 / STM32 2341
使用STM32内部Flash额外的空间来存储数据
使用STM32内部Flash额外的空间来存储数据
STM32 芯片内部的 FLASH 存储器,主要用于存储我们代码。如果内部FLASH存储完我们的代码还有剩余的空间,那么这些剩余的空间我们就可以利用起来,存储一些需要掉电保存的数据。
STM32103ZET6 / STM32 / FLASH 1947
基于STC15w408AS的电子时钟的设计
基于STC15w408AS的电子时钟的设计
DIY电子时钟的详细制作:显示时间+日期+温度;能自动调节亮度;能调节时间+闹铃。
STC15W408AS / 微控制器 1453
单片机控制大功率LED灯(解读)
单片机控制大功率LED灯(解读)
N沟道增强型MOSFET,在电路中像NPN三极管工作在饱和状态一样充当开关,单片机端口输出高电平时,G S间加正向电压大于开启电压,沟道导通,D S 间电压很小(0.45v),3个串联LED上的压降不足,灯灭。反之,端口为低电平时,LED灯亮。
微控制器 / 2N7000 / LM117 883
STM32单片机上电后时钟的默认配置过程
STM32单片机上电后时钟的默认配置过程
问题一:对系统时钟的设置的相关函数,在main函数中找不到,那在哪里?还是说根本没有对系统时钟进行配置?问题二:既然用了外部晶振做系统时钟,那为什么没看到启动外部晶振的操作?问题三:串口的时钟源是什么?串口时钟源跟系统时钟的关系?问题四:程序中串口时钟源是怎样实现对波特率的关系的?
STM32 540
利用单片机快速实现家庭智能控制平台
利用单片机快速实现家庭智能控制平台
一提到智能家庭,大家可能首先想到的是各种大佬级公司搞的牛逼产品,或者说是创新产品。想想就觉得很复杂,有的用工控机,有的用树莓派,还有的用arduino,不管用什么,都绕不过服务器进行控制,比如yeelink平台,腾讯的智能硬件平台等等。其实,真实实现起来,并没有想想中这么复杂,我们甚至只用一个小的单片机就能实现。
微控制器 / 开发板 416
原创:打造最简STM32F0 USB开发板
原创:打造最简STM32F0 USB开发板
想学STM32,不知道从哪开始的有木有? 想学ARM单片机,嫌买开发板、调试器费钱的有木有? 买了STM32开发板没有资料不会玩,放在那里吃灰的有木有? 买了开发板,照着例子跑通了几个程序,依然一头雾水的有木有?
STM32F072 / STM32 656
STM32F103ZET6资料_引脚图以及功能_和封装图型号主要特点介绍
STM32F103ZET6资料_引脚图以及功能_和封装图型号主要特点介绍
STM32F103ZET6 基于Arm®的高密度性能线32位MCU,具有256至512KB闪存,USB,CAN,11个计时器,3个ADC,13个通信接口,这里包含常见系列型号STM32F103xC, STM32F103xD,STM32F103xE一些特征和相似引脚图,主要介绍STM32F103ZET6为主。
STM32F103ZET6 6345
STM32F042开发板学习实践
STM32F042开发板学习实践
基于ST推出STM32CubeMx图形化的工具软件,便于图形化配置硬件自动生成初始化代码,keil点亮LED的实践,其实开发板到手时,芯片已经有烧写程序,装好驱动,接上USB线LED灯就能闪亮了,另外还可以通过云端mbed开发程序,这又是一大变革,与时俱进。
STM32F042 / STM32 1560
关注

关注采芯网

回复型号,查元件信息

采芯网 FindIC 用户意见反馈
问题类型
网站页面问题或建议
数据问题或错误
元器件采购询价
其他
意见建议
联系方式
反馈和联系