空灵回声 发表于 2025-10-20 19:47

MCU中Flash"零等待"机制解析

<h1>MCU中Flash&quot;零等待&quot;机制解析</h1>
<h2>一、基本定义</h2>
<p>Flash&quot;零等待&quot;(Zero-Wait, ZW)指MCU内核以‌<strong>零等待周期</strong>‌从Flash存储器直接取指令的运行模式。与之相对的是&quot;非零等待&quot;(Non-Zero-Wait, NZW)模式,此时取指需插入等待周期。</p>
<h2>二、技术原理</h2>
<ol>
<li>
<p>‌<strong>速度匹配问题</strong>‌<br />
Flash存储器的读取速度通常低于CPU运行频率,导致时钟不同步。零等待通过硬件优化(如ART加速器)消除速度差异,使CPU无需插入等待周期即可连续取指。</p>
</li>
<li>
<p>‌<strong>区域划分特性</strong>‌</p>
<ul>
<li>ZW区位于Flash前部(如APM32F427的0x0800 0000-0x0803 FFFF,256KB)</li>
<li>NZW区位于Flash后部,访问需插入1-7个等待周期</li>
</ul>
</li>
</ol>
<p><img src="data/attachment/forum/202510/20/194659vhnn77h70hocom77.jpg" alt="flash等待周期.jpg" title="flash等待周期.jpg" /></p>
<h2>三、实现方式</h2>
<ol>
<li>‌<strong>硬件加速技术</strong>‌<br />
如STM32的ART加速器通过预取指令缓存实现零等待,而APM32F425/427 系列的“零等待”是通过灵活配置SRAM映射到前256KB的flash实现零等待。</li>
<li>‌<strong>功耗管理机制</strong>‌<br />
Flash可通过寄存器配置切换功耗模式,高功耗模式支持零等待,低功耗模式需等待稳定时间。</li>
</ol>
<h2>四、性能影响</h2>
<table>
<thead>
<tr>
<th>指标</th>
<th>零等待(ZW)</th>
<th>非零等待(NZW)</th>
</tr>
</thead>
<tbody>
<tr>
<td>取指延迟</td>
<td>0周期</td>
<td>1-7周期</td>
</tr>
<tr>
<td>执行效率</td>
<td>100% CPU利用率</td>
<td>降低约30%</td>
</tr>
<tr>
<td>典型应用</td>
<td>实时性要求高的代码</td>
<td>非关键代码/数据存储</td>
</tr>
</tbody>
</table>
<h2>五、开发注意事项</h2>
<ol>
<li>‌<strong>代码布局优化</strong>‌<br />
将时间敏感代码(如中断处理、DSP算法)编译到ZW区,普通功能代码可放置于NZW区4。</li>
<li>‌<strong>型号差异</strong>‌<br />
不同MCU的ZW区大小不同(如STM32F410全Flash支持零等待,而APM32仅前256KB支持)。</li>
<li>‌<strong>功耗权衡</strong>‌<br />
零等待通常需要更高功耗,低功耗场景需合理分配代码区域。</li>
</ol>

抒情黎明 发表于 2025-10-20 23:58

在普通的MCU中,把程序放到SRAM里面是不是也是单指令周期的执行效率?

观星者宁静 发表于 2025-10-22 09:26

零等待的重点应用还是实时性。

霜咬回响 发表于 2025-10-22 14:32

这个零等待和在sram中运行,是不是一回事啊?

星云狂想曲 发表于 2025-10-22 16:35

把关键函数放到SRAM里面是不是就可以解决这个问题
页: [1]
查看完整版本: MCU中Flash"零等待"机制解析