реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> STM32F4: CCM RAM
k000858
сообщение Apr 8 2014, 08:16
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 319
Регистрация: 31-01-12
Пользователь №: 69 978



Реально ли разместить там стек?
Или компилятор сам как то размещает там данные?
в мап файле ничего не нашел по адресам этой памяти...

Код
  RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 128K
  CCMRAM (xrw) : ORIGIN = 0x10000000, LENGTH = 64K
  FLASH (rx) : ORIGIN = 0x08000000, LENGTH = 1024K


Все, что нашел в скрипте линкера по этой памяти

Код
    .bss_CCMRAM : ALIGN(4)
    {
        *(.bss.CCMRAM .bss.CCMRAM.*)
    } > CCMRAM


Компилятор GCC (в связке с эклипсой) https://launchpad.net/gcc-arm-embedded

Сообщение отредактировал k000858 - Apr 8 2014, 08:17
Go to the top of the page
 
+Quote Post
adnega
сообщение Apr 8 2014, 08:38
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702



После RESET она не работает, нужно дополнительно включать (видимо, до main).
Go to the top of the page
 
+Quote Post
scifi
сообщение Apr 8 2014, 09:12
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(adnega @ Apr 8 2014, 12:38) *
После RESET она не работает, нужно дополнительно включать (видимо, до main).

Неправда.
Go to the top of the page
 
+Quote Post
vovanse
сообщение Apr 8 2014, 10:01
Сообщение #4


Частый гость
**

Группа: Свой
Сообщений: 185
Регистрация: 14-02-06
Из: Кемерово
Пользователь №: 14 293



Цитата(scifi @ Apr 8 2014, 16:12) *
Неправда.


Почему? RCC->AHB1ENR, бит CCMDATARAMEN включает ее, reset value = 0
Go to the top of the page
 
+Quote Post
scifi
сообщение Apr 8 2014, 10:12
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата
RCC AHB1 peripheral clock register (RCC_AHB1ENR)
Address offset: 0x30
Reset value: 0x00100000
Go to the top of the page
 
+Quote Post
ViKo
сообщение Apr 8 2014, 10:18
Сообщение #6


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



У меня в STM32F303 всё работает.
http://electronix.ru/forum/index.php?showt...t&p=1247987
Go to the top of the page
 
+Quote Post
adnega
сообщение Apr 8 2014, 10:33
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702



Цитата(vovanse @ Apr 8 2014, 14:01) *
Почему? RCC->AHB1ENR, бит CCMDATARAMEN включает ее, reset value = 0

Упс. Начальное значание как раз 1 (смотрю для f407 в частности).
Значит просто записать в SP адрес конца CCM сразу после сброса или в нулевое слово таблицы векторов.
Go to the top of the page
 
+Quote Post
Impartial
сообщение Apr 8 2014, 10:36
Сообщение #8


Частый гость
**

Группа: Участник
Сообщений: 76
Регистрация: 11-06-10
Пользователь №: 57 871



Цитата
Реально ли разместить там стек?

Я размещал вручную так.
Для stm32f407 .icf файл для IAR.

CODE
/*###ICF### Section handled by ICF editor, don't touch! ****/
/*-Editor annotation file-*/
/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
/*-Specials-*/
define symbol __ICFEDIT_intvec_start__ = 0x08000000;
/*-Memory Regions-*/
define symbol __ICFEDIT_region_ROM_start__ = 0x08000000;
define symbol __ICFEDIT_region_ROM_end__ = 0x000FFFFF;
define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
define symbol __ICFEDIT_region_RAM_end__ = 0x2001BFFF;
define symbol __ICFEDIT_region_RAMCCM_start__ = 0x10000000;
define symbol __ICFEDIT_region_RAMCCM_end__ = 0x1000FFFF;

/*-Sizes-*/
define symbol __ICFEDIT_size_cstack__ = 0x1000;
define symbol __ICFEDIT_size_heap__ = 0xf000;
/**** End of ICF editor section. ###ICF###*/


define memory mem with size = 4G;
define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];

define region RAM_regionCCM = mem:[from __ICFEDIT_region_RAMCCM_start__ to __ICFEDIT_region_RAMCCM_end__];

define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };

initialize by copy { readwrite };
//initialize by copy with packing = none { section __DLIB_PERTHREAD }; // Required in a multi-threaded application
do not initialize { section .noinit };

place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };

place in ROM_region { readonly };
/*place in RAM_region { readwrite,
block CSTACK, block HEAP };*/
place in RAM_region { readwrite };
place in RAM_regionCCM {block CSTACK, block HEAP };


Сообщение отредактировал IgorKossak - Apr 8 2014, 15:26
Причина редактирования: [codebox] для длинного кода, [code] - для короткого!!!
Go to the top of the page
 
+Quote Post
Sekat
сообщение Apr 8 2014, 12:23
Сообщение #9


Участник
*

Группа: Участник
Сообщений: 61
Регистрация: 13-02-12
Пользователь №: 70 242



И не забыть, что с DMA эта область памяти не работает. Поэтому при прописывании в линкере используемой области памяти нужно сделать так, что бы буфера DMA туда не попали.
Go to the top of the page
 
+Quote Post
ViKo
сообщение Apr 8 2014, 14:49
Сообщение #10


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(Sekat @ Apr 8 2014, 15:23) *
И не забыть, что с DMA эта область памяти не работает. Поэтому при прописывании в линкере используемой области памяти нужно сделать так, что бы буфера DMA туда не попали.

А у меня в STM32F303 - работает, со свистом. Что же там такого наделали в F4xx?
Извиняюсь, это у меня обычная RAM работает по DMA. В CCMRAM не запускал.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 02:51
Рейтинг@Mail.ru


Страница сгенерированна за 0.01435 секунд с 7
ELECTRONIX ©2004-2016