Кто любит RISC в жизни, заходим, не стесняемся.
Ответить

STM32 на keil с нуля. Помогите пожалйста

Вт ноя 17, 2015 23:46:51

Подскажите пожалуйста, нашёл в интернете на первый взгляд очень хороший цикл статей по STM32 на keil, но у меня ничего не получается с самого первого шага - создания пустого проекта. Все выполнено согласно статье, но в результате огромное количество ошибок.
Почему так?
И как вообще лучше подойти к изучению этого вопроса? "С" не знаю - сначала его изучать по Кернигану и Ричи или с необходимой частью "С" разберусь по ходу? (есть хорошая статья на коте:http://radiokot.ru/articles/56/ но она по работе с CooCox, а мне нужен именно keil)
Вложения
1.jpg
(244.31 KiB) Скачиваний: 863

Re: STM32 на keil с нуля. Помогите пожалйста

Ср ноя 18, 2015 05:30:45

через это наверное каждый проходит))) сам бился над этим больше мес. понимание придет с опытом.
http://radiokot.ru/forum/viewtopic.php?f=59&t=67578 читайте с самого начала, мне помогло.
http://easyelectronics.ru/rabota-s-stm32f10x-standard-peripherals-library.html

Re: STM32 на keil с нуля. Помогите пожалйста

Чт ноя 19, 2015 19:09:57

Спасибо)

Re: STM32 на keil с нуля. Помогите пожалйста

Вс мар 06, 2016 20:19:21

Добрый день. Не могу понять поведение KEIL. В начале программы пытаюсь в RAM инициализировать три переменных. RAM начинается с адреса 0x20000000. По идее, исходя из скаттер файла, кейл должен положить эти переменные начиная с вышеприведенного адреса. Но в самом начале идет какой-то мусор и соответственно эти константы он кладет после. При считывании адреса переменной, адрес начинается как положено с 0х20000000
http://img.radiokot.ru/files/113953/vk3vby3gm.png

Re: STM32 на keil с нуля. Помогите пожалйста

Пн мар 07, 2016 08:59:37

Как вообще в KEILе инициализировать именованные переменные в RAM? Всю голову сломал.

____AREA my_var, DATA, READWRITE
blala DCD 1000

Не прокатывает. В начале RAM нет этой переменной

Re: STM32 на keil с нуля. Помогите пожалйста

Пн мар 07, 2016 10:37:30

Попробую подсказать.
1) Скажите, где располагается таблица прерываний в вашем процессоре?
2) int Foo = 11234;

Re: STM32 на keil с нуля. Помогите пожалйста

Пн мар 07, 2016 16:55:25

Таблица прерываний в начале флеша, вестимо, по адресу 0х08000000

Re: STM32 на keil с нуля. Помогите пожалйста

Пн мар 07, 2016 17:51:14

А если посмотреть файл листинга, там же есть адреса переменных?

Re: STM32 на keil с нуля. Помогите пожалйста

Пн мар 07, 2016 19:03:49

Файл листинга.
Изображение
Не могу понять, почему переменные с нулевого адреса? И почему unused? Как-то надо инициализировать ?

Re: STM32 на keil с нуля. Помогите пожалйста

Вт мар 08, 2016 02:09:58

relocatable symbols
иницированы 0х0, asdf 0x4;
не использованы нигде , поэтому unused.

Re: STM32 на keil с нуля. Помогите пожалйста

Вт мар 08, 2016 07:26:47

Так как всё-таки поместить именованную переменную в ОЗУ с помощью конструкции:

AREA mydata, DATA, READWRITE
blabla DCD 1000

Что-то надо добавить?

Re: STM32 на keil с нуля. Помогите пожалйста

Вт мар 08, 2016 18:26:54

Никто не знает или не хочет рассказать?

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 10:33:14

Kolbaskin_Kirov писал(а):Никто не знает или не хочет рассказать?

В скрипте компоновщика для этой секции нужно назначить адрес загрузки (load address, должен быть в энергонезависимой памяти) и адрес исполнения (execution address, должен быть в оперативной памяти). Затем, перед переходом к основной программе, необходимо скопировать данные инициализации из энергонезависимой памяти в оперативную. Еще наверное можно поместить переменные в стандартную секцию (.data называется, если не ошибаюсь). Тога можно будет воспользоваться имеющимся алгоритмом инициализации, который выполняется в __main. В общем начни читать про load и execution адреса, там потихоньку до остального дойдешь.

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 14:07:12

Вот скаттер файл
Изображение

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 14:13:33

Ну хорошо, стандартный скрипт вроде бы подходит, осталось скопировать данные.

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 14:48:16

При объявлении переменных в RW области они лежат в конце прошивки и в RAM не переписываются. Как сделать, чтобы они там были? Можно и вручную переписать, а как сделать автоматом?

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 15:05:45

В энергонезависимой памяти лежат их начальные значения, сами они должны находиться в оперативной памяти, то есть blabla должен указывать на область 0x20000000 - 0x20001000.

Kolbaskin_Kirov писал(а):Можно и вручную переписать, а как сделать автоматом?

Ну я же все написал! Может всё же стоить НАЧАТЬ копать в указанном направлении, а не ждать, пока всё разжуют? В общем еще раз говорю. Можно попробовать вызвать __main из стандартной библиотеки, тем более, что её все равно так или иначе нужно вызывать. Если она определяет секции для копирования по атрибуту RW, то должно получиться. Если же она находит секцию для копирования по имени, например .data, то тогда необходимо назвать свою секцию этим же именем (вместо mydata), чтобы она её скопировала.

Если я ошибаюсь, и __main работает как-нибудь по-другому, то придется САМОМУ писать код, который будет САМ копировать данные. В любом случае, копирование будет происходить в коде, иначе НИКАК нельзя. Разве что только указать для секции mydata load address равным execution address, но это будет работать только при заливке ПО отладчиком, до первого выключения питания.

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 15:09:26

Подключить к проекту startup файл и библиотеку CMSIS ?

Re: STM32 на keil с нуля. Помогите пожалйста

Ср мар 09, 2016 15:44:00

Нет, "C Run-Time Library". Она сама подключится, если в коде импортировать и вызвать __main. В стандартных startup уже есть вызов __main, так что можно или использовать стандартный startup, или подсмотреть, как в нем вызывается __main и сделать так же в своем.

Re: STM32 на keil с нуля. Помогите пожалйста

Сб мар 12, 2016 12:59:29

С предыдущим вопросом разобрался. Теперь с прерываниями, вернее с выходом из него. В programming reference manual (ядро М0) написано, что при возникновении прерывания в стек автоматически сохраняются регистры r0-r3,r12,LR,PC и xPSR. Причем в регистр LR сохраняется некая константа EXC_RETURN, которая говорит, что это не обычная подпрограмма, а именно прерывание. С этим все ясно, не ясно другое: выход из прерывания возможен двумя командами - POP и BX.
1. Как использовать инструкцию POP для окончания прерывания? Что писать в reglist: регистры, которые сохраняются автоматически писать надо или нет? Добавлять ли в реглист РС?
2. По инструкции BX. Причем после ВХ надо указать регистр, в котором лежит адрес возврата. Непонятно что происходит дальше? Дальше выгружается стек и РС? Если так, то непонятно что происходит: адрес возврата есть в РС и адрес возврата в инструкции ВХ.
Ответить