0

此 STM32F7 架构概述文档的第 14 页显示了以下内存地址:

  • FLASH-ITCM(我使用的 F730 尺寸未知)
  • DTCM-RAM (64KB)
  • ITCM-RAM (16KB)

这些有什么区别?许多示例显示数据进入 DTCM。堆栈或关键函数之类的东西最适合在哪里?

在 ART 加速器上使用 Flash ITCM 接口有什么好处吗?

4

1 回答 1

1

DTCM 和 ITCM 之间的区别在于它们连接到哪个总线,DTCM 位于 D 总线上,因此用于数据,这是存储堆栈的理想位置,ITCM 位于 I 总线上,因此用于获取指令(代码),这是存储关键例程的好地方。

ART 加速器位于 Flash 和 ITCM 之间,因此不是非此即彼。通过 ITCM 将闪存用于代码是有利的,因为这样您可以获得加速,而通过 AHB 总线则不能。所有闪存都可以通过 ITCM 接口或 AHB 总线使用,具体取决于您使用的地址;0x0020 0000to0x0027 FFFF 是通过 ITCM,0x0800 0000to0x0807 FFFF通过 AHB,两组地址都指向同一个闪存区域。

于 2019-02-28T16:40:32.027 回答