This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

[参考译文] TMS320F280025C-Q1:DMA 传输数据不会传输到 GS0 RAM

Guru**** 2124260 points
请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

https://e2e.ti.com/support/microcontrollers/c2000-microcontrollers-group/c2000/f/c2000-microcontrollers-forum/997315/tms320f280025c-q1-dma-transfer-data-not-to-gs0-ram

器件型号:TMS320F280025C-Q1

您好、支持团队、

GS0 RAM 中有2K*16,但这对我们的应用来说还不够

我尝试改用 RAMLS4567:

28002x_launchxl_demo_flash_lnk.cmd:

Fullscreen
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
SECTIONS
{
codestart : > BEGIN, ALIGN(8)
.text : >> FLASH_BANK0_SEC2 | FLASH_BANK0_SEC3 | FLASH_BANK0_SEC4 | FLASH_BANK0_SEC5, ALIGN(8)
.cinit : > FLASH_BANK0_SEC1, ALIGN(8)
.switch : > FLASH_BANK0_SEC1, ALIGN(8)
.reset : > RESET, TYPE = DSECT /* not used, */
.stack : > RAMM1
.init_array : > FLASH_BANK0_SEC1, ALIGN(8)
.bss : > RAMLS4567
.bss:output : > RAMLS4567
.bss:cio : > RAMGS0
.const : > FLASH_BANK0_SEC6_7, ALIGN(8)
.data : > RAMLS4567
.sysmem : > RAMLS4567
ramgs0 : > RAMGS0
ramgs1 : > RAMLS4567
/* Allocate IQ math areas: */
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Fullscreen
1
2
#pragma DATA_SECTION(u16AdcMeasCurrentByDma, "ramgs1"); /* map the data to memory */
static volatile u16 u16AdcMeasCurrentByDma[ADC_NO_SYNC_PER_1MS]; /* array for current measurement */
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

并且 DMA 中断后的 u16AdcCurrentByDma 中的数据全部为0

DMA 能否访问 RAMLS4567?

我是否可以通过任何方法来增加 DMA 的 RAM 面积?

此致、

问题

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    Quy、

    在 F280025中、DMA 不能访问 LS4-LS7RAM。 因此、DMA 无法配置为将内容传输到 LS4-LS7RAM。

    在此器件中、DMA 只能访问 GS0RAM。 您不能增加对其它 RAM 位置的 DMA 访问。

    此致、

    曼诺伊