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

 
 
> Размер структур, стек и куча, Максимальный размер структур, их копирование, стек и куча
kolobochishe
сообщение Dec 22 2015, 16:07
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 240
Регистрация: 14-04-10
Из: Россия, г.Челябинск
Пользователь №: 56 634



Пишем программу для нового прибора. Коллега создает вот такие структуры:
Код
typedef struct    {
    REC_HEADER Header;
    WORD NoPT;
    WORD NoPL;
    WORD NoAD;
    WORD StationID;
    WORD ModelID;
    WORD ManufactID;
    char Ident[9];
    char Descript[41];
    WORD StatTime;
    WORD NoFR;
    WORD NoRT;
    WORD NoBL;
    BYTE NoKY;
    BYTE NoPR;
    BYTE UnitsCal[7];
    float Units0dB[7];
    char KeyId[3][5];
    char KeyDescr[3][41];
    BYTE KeyGrade[3];
    float Factor[3];
    BYTE KeyTStamp[3][8];
    float KeyNom[3];
    float RPM[3];
    char KeyNotes[3][241];
    char PrId[12][9];
    char PrDescr[12][41];
    char Units[12][7];
    BYTE PrGrade[12];
    BYTE PrTStamp[12][8];
    float PrNom[12];
    float PrVal[12];
    char PrNotes[12][241];
                } RTN;


и вот в таком вот месте программа "виснет"
Код
void make_TA(void)
{
    BYTE    get_status(BYTE);

    RTN train=TRAIN; // ТУТ ЗАВИСАЕТ


Увеличил размер стека и все заработало. Был 3кБ сделал 10кБ. Правда, из SCRTACHPAD пришлось перенести в L1 из-за размера.
Контроллер Blackfin BF-548.

Теперь вопросы:
1. Как вы контролируете переполнение стека?
2. Какой размер считаете оптимальным?
3. В какой памяти его лучше располагать?
4. Как реально происходит приравнивание структур? Это спрятанное от глаз memcpy? И используется ли при этом динамическое выделение памяти?
5. Мириться ли с тем, что коллега создает такие огромные структуры или надо сменить подход? Можно ли их располагать в функции или лучше глобально?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
jcxz
сообщение Dec 23 2015, 05:45
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(kolobochishe @ Dec 22 2015, 22:07) *
1. Как вы контролируете переполнение стека?
2. Какой размер считаете оптимальным?
3. В какой памяти его лучше располагать?
4. Как реально происходит приравнивание структур? Это спрятанное от глаз memcpy? И используется ли при этом динамическое выделение памяти?
5. Мириться ли с тем, что коллега создает такие огромные структуры или надо сменить подход? Можно ли их располагать в функции или лучше глобально?

5. Коллеге за такое в embedded без внешней памяти, надо не просто по рукам бить, а ампутировать их. Лучше не данные, а коллегу расположить где-нить в вынь-программинге.
2. Оптимальных размеров стека нет, есть необходимые.
1. Контроль - заполнением шаблоном.
3. Лучше внутренней, особенно касаемо DSP с его огромными контекстами.
4. Согласно языка си: поэлементно. Распределение памяти и инициализация - вещи суть разные и почти несвязанные.

Цитата(quarter @ Dec 22 2015, 22:55) *
при вызове Си-шной функции все параметры, которые получает и возвращает функция, передаются через стек.

ложь.

Цитата(AlexandrY @ Dec 23 2015, 03:03) *
Стек он в дивайсах с реальным временем на вес золота. Ибо организуется в быстрой внутренней RAM, даже TCM RAM.

В принципе можно и во внешней памяти стек располагать, даже на устройствах где есть жёсткий реалтайм.
Всё зависит от требуемого быстродействия данной задачи ОС и архитектуры CPU.
Если архитектура такова, что при возникновении прерывания контекст сохраняется на другом стеке (как на Cortex) или вообще не сохраняется (как в ARM TDMI), то стек некоей медленной задачи расположенный во внешней ОЗУ никак не затормозит ISR, но может затормозить переключение контекста данной медленной задачи ОС.
Как обстоит дело с сохранением контекста в Блэкфинах я не знаю.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- kolobochishe   Размер структур, стек и куча   Dec 22 2015, 16:07
- - Сергей Борщ   1) Заполнением стека константой перед запуском про...   Dec 22 2015, 16:39
|- - kolobochishe   Цитата(Сергей Борщ @ Dec 22 2015, 22:39) ...   Dec 22 2015, 17:08
|- - AlexandrY   Цитата(kolobochishe @ Dec 22 2015, 19:08)...   Dec 22 2015, 21:03
||- - kolobochishe   Цитата(AlexandrY @ Dec 23 2015, 02:03) .....   Dec 23 2015, 09:08
||- - AlexandrY   Цитата(kolobochishe @ Dec 23 2015, 11:08)...   Dec 23 2015, 09:21
||- - kolobochishe   Цитата(AlexandrY @ Dec 23 2015, 14:21) Ну...   Dec 23 2015, 09:35
|- - ASN   jcxz Как-то работали с профессиональным программис...   Dec 23 2015, 11:27
|- - jcxz   Цитата(ASN @ Dec 23 2015, 17:27) Как-то р...   Dec 23 2015, 13:12
- - quarter   при вызове Си-шной функции все параметры, которые ...   Dec 22 2015, 16:55
- - psL   Цитата(kolobochishe @ Dec 22 2015, 19:07)...   Dec 23 2015, 06:44
|- - Сергей Борщ   Цитата(psL @ Dec 23 2015, 09:44) у вас в ...   Dec 23 2015, 09:10
|- - jcxz   Цитата(Сергей Борщ @ Dec 23 2015, 15:10) ...   Dec 23 2015, 09:27
|- - psL   Цитата(Сергей Борщ @ Dec 23 2015, 12:10) ...   Dec 23 2015, 09:27
- - SlavaV   Вообще конструкция тип НовыйОбъект = Объект говори...   Dec 23 2015, 06:52
|- - AlexandrY   Цитата(SlavaV @ Dec 23 2015, 08:52) PPS в...   Dec 23 2015, 06:58
|- - jcxz   Цитата(SlavaV @ Dec 23 2015, 12:52) Вообщ...   Dec 23 2015, 08:14
|- - SlavaV   Цитата(jcxz @ Dec 23 2015, 17:14) Не обяз...   Dec 23 2015, 08:29
- - sigmaN   Кажется такие вопросы решаются выработкой специфик...   Jan 9 2016, 11:21


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

 


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


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