Перейти к содержанию

Программа Виснет При Вызове Функции Gui_Init() Stm32F429 Discovery


artem2236

Рекомендуемые сообщения

Здравствуйте,

Я недавно начал использовать отладочную плату stm32f429-discovery. И есть проблема, над которой уже бьюсь больше месяца.

Пытаюсь написать простейшую прогу с выводом на встроенный индикатор каких нить кнопок и линий, используя готовые библиотеки Stemwin, скаченные с сайта stm. Однако при вызове функции инициализации GUI_Init(), программа виснет. Я вроде все подключил, все компилируется без ошибок, все делал по инструкции. Прога выглядит следующим образом.

int main(void)
{

SDRAM_Init();
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_CRC, ENABLE);  
/* REQUIRED for STemWin */


/* SDRAM initialization */

GUI_Init();
/* LTDC initialization */
LCD_Init();
LCD_LayerInit();
LTDC_Cmd(ENABLE);
LCD_SetLayer(LCD_FOREGROUND_LAYER);
LCD_Clear(LCD_COLOR_WHITE);

LCD_SetFont(&Font12x12);
LCD_DisplayStringLine(LINE(10), (uint8_t*)"What doesn't kill me");
LCD_DisplayStringLine(LINE(12), (uint8_t*)" makes me stronger");

while(1)
{
}
}

Т.е. прога заходит в функцию GUI_init() и не выходит((

Прошелся по шагам - виснет в цикле while в функции _DMA_Fill (выделено красным внизу) (где точнее - выяснить не получается, потому что по шагам очень очень долго идти).

static void _DMA_Fill(int LayerIndex, void * pDst, int xSize, int ySize, int OffLine, U32 ColorIndex) {
 U32 PixelFormat;

 PixelFormat = _GetPixelformat(LayerIndex);
 DMA2D->CR	  = 0x00030000UL | (1 << 9);		 // Register to memory and TCIE
 DMA2D->OCOLR   = ColorIndex;					  // Color to be used
 DMA2D->OMAR	= (U32)pDst;					   // Destination address
 DMA2D->OOR	 = OffLine;						 // Destination line offset
 DMA2D->OPFCCR  = PixelFormat;					 // Defines the number of pixels to be transfered
 DMA2D->NLR	 = (U32)(xSize << 16) | (U16)ySize; // Size configuration of area to be transfered
 DMA2D->CR	 |= 1;							   // Start operation
 //
 // Wait until transfer is done
 //
 while (DMA2D->CR & DMA2D_CR_START) {
//__WFI();										// Sleep until next interrupt
 }
}

ставлю брэйкпоинты в функциях-обработчиках прерываний - ни в одну из них даже не заходит.

может кто сталкивался с такой проблемой? help

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

/** \brief  Wait For Interrupt

   Wait For Interrupt is a hint instruction that suspends execution
   until one of a number of events occurs.
*/
#define __WFI                             __wfi

Ожидается прерывание. Которое скорей всего и не разрешено и не сконфигурировано.

Вопрос - где взят исходник с которого копируете ?

Там и ищите какие прерывания DMA2D используются...

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

/** \brief Wait For Interrupt

Wait For Interrupt is a hint instruction that suspends execution
until one of a number of events occurs.
*/
#define __WFI __wfi

Ожидается прерывание. Которое скорей всего и не разрешено и не сконфигурировано.

Вопрос - где взят исходник с которого копируете ?

Там и ищите какие прерывания DMA2D используются...

исходник скачен с сайта stm. файл называется GUIDRV_stm32f429i_discovery
Ссылка на комментарий
Поделиться на другие сайты

Особенности хранения литиевых аккумуляторов и батареек

Потеря емкости аккумулятора напрямую зависит от условий хранения и эксплуатации. При неправильном хранении даже самый лучший литиевый источник тока с превосходными характеристиками может не оправдать ожиданий. Технология, основанная на рекомендациях таких известных производителей литиевых источников тока, как компании FANSO и EVE Energy, поможет организовать правильный процесс хранения батареек и аккумуляторов. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Я так понимаю что перепиливаете STM32F429I-Discovery_Demo из поставки F429 дискавери , путем выпиливания.

Или что-то свое ляпаем ?

Если второе - оставьте эту затею , это не для новичков .

Там прикручена ось и простыми телодвижениями свое не сляпать.

Да и первое не так просто - надо понимать что выпиливаем.

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Я так понимаю что перепиливаете STM32F429I-Discovery_Demo из поставки F429 дискавери , путем выпиливания.

Или что-то свое ляпаем ?

Если второе - оставьте эту затею , это не для новичков .

Там прикручена ось и простыми телодвижениями свое не сляпать.

Да и первое не так просто - надо понимать что выпиливаем.

Не совсем. Вообще я создал свой проект, вытаскивая не достающие файлы из STM32F429I-Discovery_Demo. Но без RTOS. Мне RTOS пока не нужен. У меня уже получилось сделать какие то элементарные вещи при помощи скаченных библиотек с того же сайта (LCD_init). Причем библиотека LCD инициализировалась без проблем и я спокойно на экран вывожу слова и фигуры, а при инициализации GUI вот такая вот хрень выскакивает.
Ссылка на комментарий
Поделиться на другие сайты

GUI без RTOS работать не будет . Это осознаем?

Поясняю - GUI это графический интерфейс пользователя оси ...

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

GUI без RTOS работать не будет . Это осознаем?

Поясняю - GUI это графический интерфейс пользователя оси ...

Вот я тоже об этом думал. но когда я задал такой вопрос на форуме непосредственно на официальном сайте stm - мне ответили, что gui может работать без rtos. Поэтому теперь я совсем запутался уже. Т.е. все таки gui без RTOS не работает??
Ссылка на комментарий
Поделиться на другие сайты

Упс, да верно. Есть возможность конфигурации с однозадачной системой .

Читайте http://www.st.com/st.../DM00089670.pdf

В хэдере GUIConf.h


/*********************************************************************
*
*       Multi tasking support
*/
#ifdef OS_SUPPORT
#define GUI_OS                    (1)  // Compile with multitasking support
#else
#define GUI_OS                    (0)
#endif

Так же в том документе что ссылка выше :

3.1.3 GUI_X.c or GUI_X_OS.c • GUI_X.c for single task execution: “Single task” means that the project uses STemWin only from within one single task. The main purpose is to supply STemWin with a timing base. OS_TimeMS needs to be incremented each ms. • GUI_X_OS.c for multitask execution: If STemWin is used in a multitasking system, this file contains additional routines required for synchronizing tasks (for this purpose, the file GUI_X_FreeRTOS.c can be used as a template).

То есть заменяем в менагере проекта GUI_X_FreeRTOS.c на GUI_X.c , оба в папке OS EMWIn

Это пока все что нарыл .

Надеюсь понятно что теперь необходимо вручную вызывать средства гуя для прорисовки ?

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

Упс, да верно. Есть возможность конфигурации с однозадачной системой .

Читайте http://www.st.com/st.../DM00089670.pdf

В хэдере GUIConf.h


/*********************************************************************
*
* Multi tasking support
*/
#ifdef OS_SUPPORT
#define GUI_OS (1) // Compile with multitasking support
#else
#define GUI_OS (0)
#endif

Так же в том документе что ссылка выше :

3.1.3 GUI_X.c or GUI_X_OS.c • GUI_X.c for single task execution: “Single task” means that the project uses STemWin only from within one single task. The main purpose is to supply STemWin with a timing base. OS_TimeMS needs to be incremented each ms. • GUI_X_OS.c for multitask execution: If STemWin is used in a multitasking system, this file contains additional routines required for synchronizing tasks (for this purpose, the file GUI_X_FreeRTOS.c can be used as a template).

То есть заменяем в менагере проекта GUI_X_FreeRTOS.c на GUI_X.c , оба в папке OS EMWIn

Это пока все что нарыл .

Надеюсь понятно что теперь необходимо вручную вызывать средства гуя для прорисовки ?

я все эти материалы с сайта уже по несколько раз прочитал. все делал по инструкциям.... тока проблема от этого все равно не решилась((( заходит в gui_init и не выходит от туда((
Ссылка на комментарий
Поделиться на другие сайты

Тогда жди когда лень не будет . И кидай свой проект в архиве.

Только крайне желательно в Keil . Кокос ставить никакого желания нет, в IAR своих глюков достаточно.

Ссылка на комментарий
Поделиться на другие сайты

Тогда жди когда лень не будет . И кидай свой проект в архиве.

Только крайне желательно в Keil . Кокос ставить никакого желания нет, в IAR своих глюков достаточно.

ок. заранее огромное спасибо. я как раз в keil и работаю. Загружаю по частым - слишком большой файл

Тогда жди когда лень не будет . И кидай свой проект в архиве.

Только крайне желательно в Keil . Кокос ставить никакого желания нет, в IAR своих глюков достаточно.

ок. заранее огромное спасибо. я как раз в keil и работаю. Загружаю по частым - слишком большой файл

Example_2_LCD.part01.rar

Example_2_LCD.part02.rar

Example_2_LCD.part03.rar

Ссылка на комментарий
Поделиться на другие сайты

У меня ваш проект при отладке улетает в default handler.

То есть попадаем на непрописанный вектор ...

Что то явно напутано в структуре проекта и версиях файлов.

Попробуйте создать проект без визарда Keil ...

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

Вообщем так . Я все правильно говорил что ЭТОТ GUI работать без RTOS не будет .

Не сама stemWin, а именно то что с SPL и идет с stm32f429i discoveri.

Дело в том что драйвер GUIDRV_stm32f429i_discovery и сама либа заточены под ось .

Осталось дело за малым - переписать дрова и либу. :crazy:

Мне этим заниматься совершенно не радужно.

Теперь понятно почему примеров с гуем без оси нету в сети. :crazy:

Советую оставить это пустое занятие.

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

Но не все так печально.

Качай примеры с куба на stm32f429i_discovery . STM32Cube_FW_F4_V1.4.0

Там есть без оси . Все компилируется и прошивается .

На первых порах не надо создавать проект в визарде .

Зависимости там дикие , нарушать структуру папок чревато.

Просто скопируй целиком папку STemWin_HelloWorld что в \STM32Cube_FW_F4_V1.4.0\Projects\STM32F429I-Discovery\Applications\STemWin\

В ту же директорию.

Переименуй ее.

Переименуй файлы *.uvopt и *.uvproj под свои .

А дальше читай мануал на stemwin . Он рядышком в STM32Cube_FW_F4_V1.4.0\Middlewares\ST\STemWin\Documentation\

Удачи...

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

Но не все так печально.

Качай примеры с куба на stm32f429i_discovery . STM32Cube_FW_F4_V1.4.0

Там есть без оси . Все компилируется и прошивается .

На первых порах не надо создавать проект в визарде .

Зависимости там дикие , нарушать структуру папок чревато.

Просто скопируй целиком папку STemWin_HelloWorld что в \STM32F429\STM32Cube_FW_F4_V1.4.0\Projects\STM32F429I-Discovery\Applications\STemWin\

В ту же директорию.

Переименуй ее.

Переименуй файлы *.uvopt и *.uvproj под свои .

А дальше читай мануал на stemwin . Он рядышком в STM32Cube_FW_F4_V1.4.0\Middlewares\ST\STemWin\Documentation\

Удачи...

буду пробовать) огромное спасибо))
Ссылка на комментарий
Поделиться на другие сайты

Если сделаешь все как я выше описывал . Можешь прямо копипастить примеры из дока в BASIC_HelloWorld.c .

Вставляя их в MainTask ()

Не забывая подключать хэдеры если стандартные функции С используются....

Ссылка на комментарий
Поделиться на другие сайты

Если сделаешь все как я выше описывал . Можешь прямо копипастить примеры из дока в BASIC_HelloWorld.c .

Вставляя их в MainTask ()

Не забывая подключать хэдеры если стандартные функции С используются....

все заработало. большое спасибо))
Ссылка на комментарий
Поделиться на другие сайты

Увы не все .

Landscape ориентация не доступна.

Фокус почему-то фиксируется на первом тыкнутом виджете.

7636ab0952e7.jpg

Изменено пользователем dosikus
Ссылка на комментарий
Поделиться на другие сайты

  • 1 месяц спустя...
  • 1 год спустя...

Здравствуйте, знатоки STM32.

Очень прошу помочь разобраться, как правильно заполнить область, используя DMA2D Register to memory и внутреннюю память микроконтроллера. Контроллер, кстати, STM32F429IIT, экран 800х480 подключен по RGB24.

Не предусмотрел в своей схеме SDRAM, поэтому и мучаюсь.

Вот кусок кода

static void _DMA_Fill(void * pDst, int xSize, int ySize, int OffLine, uint32_t ColorIndex) {
DMA2D->CR	 = 0x00030000UL | (1 << 9);		 // Register to memory and TCIE
DMA2D->OCOLR = ColorIndex;					 // Color to be used
DMA2D->OMAR = (uint32_t)pDst;					 // Destination address
DMA2D->OOR	 = OffLine;						 // Destination line offset
DMA2D->OPFCCR = 4;					 // Defines the number of pixels to be transfered
DMA2D->NLR	 = ((uint32_t)xSize << 16) | ySize; // Size configuration of area to be transfered
DMA2D->CR	 |= 1;							 // Start operation
//
// Wait until transfer is done
//
while (DMA2D->CR & DMA2D_CR_START) {}
}
uint32_t aBufferResult[5000];
int main (void)

{
	 SystemInit();
 HAL_Init();
	 SystemClock_Config();
 DMA2D_Config();
 Screen_Init();
	 _DMA_Fill(aBufferResult+10, 50, 1, 0, 0x1F0A);
	 _DMA_Fill(aBufferResult+150, 30, 2, 0, 0x1C01);
 _DMA_Fill(aBufferResult+300, 5, 20, 0, 0xF0F0);
	 while(1) {}
}

Спасибо всем, кто откликнется

post-0-0-57080900-1471877274_thumb.jpg

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Спасибо.  Всё понял. А вот предупреждения за выход предела питания не в одной инструкции не встречал. Спасибо.
    • Правильно, 1в это еще понятно.  И то, слишком большая разница входного и выходного напряжения получается, нерационально. Поэтому в свой лабораторник я запихнул сразу несколько блоков питания с отдельными выключателями (благо место позволяло - корпус от маленького компа-кубика Acer ). 1. этот линейник (ставил два D1047 в параллель + выравнивающие резисторы). Кстати, сразу рекомендую поменять родные переменники что шли в наборе на многооборотные, для более плавной регулировки. Трансформатор-бублик со средним выводом 2х23в, обдув родным громадным вентилятором что был в корпусе компа. И того 3А без напряга (при выходном напряжении 12в), больше просто не тянет трансформатор. В качестве выпрямителя ставил двойной диод Шоттки прикрученый к металлическому корпусу, холодный. Входную емкость увеличил до 4х2200мкФ. 2. Отдельный Импульсник нв 8А со своим отдельным питанием (реально тестировал на 4А). 3. Двухполярник +/- 12v  для ОУ со своим трансформатором. Для экспериментов с ОУ. 4. Отдельная зарядка 5в 2а с USB выходом (использовал родное гнездо корпуса).  Отдельные вольтамперметры для блоков. И еще есть место, можно еще что-то добавить.  Поэтому кому нужны большие токи особенно при малых напряжениях на выходе - оставляйте место в корпусе для импульсного стабилизатора, и даже можно использовать один и тот же трансформатор. Это лучше чем требовать от линейного блока питания лишние амперы, тем более без дополнительного вентилятора обдува. Кстати, в китайском наборе идет стабилизатор 24в для вентилятора, но большинство комповых вентиляторов либо 12в. Мне для этого все равно пришлось питать вентилятор отдельно.
    • Понятно теперь, буду настраивать.  Одна непонятка ещё. На фильтре присутствует переключатель фазы, сколько раз этот тумблер не щёлкал, разницы особой не заметил. Только бас из одного угла перемещался в другой и всё   Вот вопрос: как на выходе усилителя определить фазу (+/-)? Не у колонок, а именно у выхода усилителя, т.к. к нему подключён ещё один фильтр 2 порядка и скорее всего «+» с «-» возможно поменялись. Хочу подключить всё в правильной полярности и не дро#ить этот переключатель фазы. 
    • Вот фото некоторых моих работ, небольшие поделки для местного производителя https://postimg.cc/gallery/4h72K81. Ранее доводилось ремонтировать оборудование гораздо серьезней. Программы на ПЛК кстати тоже сам писал.   На фото по ссылке, в ящике с УПП, установлен как раз тот самый бп, и те самые реле омрон. Там все работало, не один ящик был собран. Но после случился тот самый случай. Меняли блок, реле, без толку. Единственное что могло поменяться, так это завод изготовитель реле, партии приходили то с Тайваня, то с какой то европейской страны. По артикулу тот же, но головы и розетки друг к другу не совсем подходили.   В общих чертах, как работает обычный ИБП я представляю, выпрямить, сгладить, шим регулирование, трансформация высоких частот, сглаживание и фильтрация на выходе. Что такое ШИМ я тоже представляю, используется так же в частотниках, в выходах ПЛК для управления скажем драйверами, которые управляют в свою очередь пропорциональными гидроклаппанами или приводами. Про светодиоды, чем они питаются и их ВАХ то же в курсах. Про работу ибп со стаб. тока, у которого при изменении нагрузки меняется напряжение а ток стабилизируется на одном уровне, и про аварийный режим холостого хода тоже слыхал. Институтов не заканчивал, углубленно в ИБП не вникал. Был случай, который я описал, и есть вопросы, которые я уже задал.
    • Полный ноль, может, и не особо нужен. Но, если надо, например, один вольт и для этого требуется что-то колхозить на скорую руку (имея при этом на столе типа "универсальный источник"), то это как-то странно, согласитесь. Ну а "проблема масштабируемости" - это проблема не блока, а того, кто покупает Жигули с целью возить железобетонные плиты на стройку. 
    • Под "проблемой схемы" (правильнее надо было сказать - "недостатком схемы") я понимаю только то, что приходится учитывать допустимые напряжение питания ОУ, далеко не во всех схемах БП есть такое (например в таком же популярном ПиДБП из соседней ветки).  Но если соблюсти и уважить требования автора, и использовать рекомендуемые детали (и не подделки), то и работать будет нормально (не случайно этот БП такой популярный, что его клонировали в Поднебесной). А что касается "подводных камней", то на забугорном форуме посвященному этому блоку, некоторые из них расписывались, там уже под сотню страниц обсуждения https://www.electronics-lab.com/community/index.php?/topic/29563-0-30v-stabilized-power-supply/ У меня этот блок питания работает нормально, но я почти все детали что шли в наборе, заменил на б.у. и оригинальные (ОУ, транзисторы, даже резисторы). Что касается "1000в и 100а", пусть те кто этого хотят - пусть и дальше хотят, может в следующей жизни и дождутся..  Честно говоря, я не понимаю требований "регулировки ну прямо от нуля" для линейного лабораторного блока питания с входным напряжением 30+ в. Если нужно напряжение, скажем 1,5в, что мешает например, запитать схему от батарейки? Иначе нужно еще добавлять в схему переключение обмоток.
    • Я не совсем понимаю формулировку "проблема схемы". Линейный блок питания с характеристиками 0-30В, 0-2А и определенной величиной пульсаций, с точной регулировкой. Соответствует? Соответствует. Можно еще посмотреть как оно выдерживает плавающее сетевое напряжение и КЗ. Но почему-то у многих я вижу претензии в стиле "плохо масштабируется до 1000В - 100А". Наверное, такая задача и не ставилась и для этого можно использовать что-нибудь другое. Автор, например, очень доволен тем, что напряжение регулируется от нуля вольт, а не от напряжения стабилитрона как аналоги (то есть от 5 или сколько там у них было) - то есть это достижение на то время. ТЕС-41, который на 30В и 5А в раз в двадцать больше по размеру. И я не думаю, что он при этом в двадцать раз лучше - это уже совсем специфические задачи нужно решать и специфические вещи запитывать.
  • Похожий контент

×
×
  • Создать...