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

 
 
> STM32 Ассемблер. Идеи и приёмы написания, Правила хорошего тона и макросы
allsettingsdone
сообщение Jan 15 2014, 22:50
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 32
Регистрация: 22-01-13
Пользователь №: 75 284



По ассемблеру для арм документации и разного рода примеров гораздо меньше для С. Начал осваивать и возникли сомнения, правильный ли подход частого использования макросов и где та грань, свыше которой не стоит заморачиваться с написанием кода. В ассемблера я не силён, в основном по-любительски пишу на С. Но вот раз начал осваивать асм, сделал несколько элементарных макросов для битовых операций, настройки и использования портов. Вопрос в том правильно ли это делать и использовать таким образом (когда в коде используются много макросов), или может быть есть более рациональный способ, как лучше писать на асме для арм. Вот примерчик:
STM32F100RB.
И что конкретно делает команда bfi R1,R2,#$Pin,#4 ?
Определение макросов:
Код
;--------------------------------------
;Start_GPIO_Conf $Port,$PinRange - начало настройки порта, где $Port - имя порта (GPIOA,..), $PinRange - верхняя/нижняя тетрада порта (GPIO_CR_H/GPIO_CR_L)
        macro
        Start_GPIO_Conf $Port,$PinRange
        mov32            R0,#$Port        ;загружаем в регистр "R0" имя порта (его код) из памяти
        ldr             R1,[R0,#$PinRange];загружаем в регистр "R1" значение по адресу из памяти "R0 + #GPIO_CR_H(0x00)" или "R0 + #GPIO_CR_H(0x04)"
        mend
;--------------------------------------
;GPIO_Conf          $Pin,$Mode - настройка ножек выбраного порта, где $Pin - номер ножки (CNF_Pin_0,..), $Mode - режим ножки (GPIO_OUT_50_PP,..)
        macro
        PinConfig         $Pin,$Mode
        movs             R2,#$Mode
        bfi             R1,R2,#$Pin,#4
        mend
;--------------------------------------
;End_GPIO_Conf      $Port,$PinRange - конец настройки порта, где $Port - имя порта (GPIOA,..), $PinRange - верхняя/нижняя тетрада порта (GPIO_CR_H/GPIO_CR_L)
        macro
        End_GPIO_Conf     $Port,$PinRange
        str             R1,[R0,#$PinRange];загружаем в память по адресу "R0 + #GPIO_CR_H(0x00)" или "R0 + #GPIO_CR_H(0x04)" значение "R1"
        mend
;--------------------------------------
;SetBit_GPIO    $Port,$Pin
        macro
        SetBit_GPIO        $Port,$Pin
        mov32            R0,#($Port + GPIO_BSRR)
        mov32            R1,#$Pin
        str                R1,[R0]
        mend
;--------------------------------------
;ResetBit_GPIO    $Port,$Pin
        macro
        ResetBit_GPIO    $Port,$Pin
        mov32            R0,#($Port + GPIO_BRR)
        mov32            R1,#$Pin
        str                R1,[R0]
        mend
;--------------------------------------

Использование в программе:
Код
;--------------------------------------
            Start_GPIO_Conf GPIOC,GPIO_CR_H
        PinConfig         CNF_Pin_9,GPIO_OUT_50_PP
        PinConfig         CNF_Pin_8,GPIO_OUT_50_PP
        End_GPIO_Conf     GPIOC,GPIO_CR_H
;--------------------------------------
        SetBit_GPIO        GPIOC,PIN9
        SetBit_GPIO        GPIOC,PIN8
;--------------------------------------


Пробный проект в Keil 5 прикреплен:

Сообщение отредактировал allsettingsdone - Jan 15 2014, 22:55
Прикрепленные файлы
Прикрепленный файл  test11_ASM.7z ( 93.49 килобайт ) Кол-во скачиваний: 28
 
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Golikov A.
сообщение Jan 16 2014, 13:55
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 4 256
Регистрация: 17-02-06
Пользователь №: 14 454



Так вам про это и долдонят битый часsm.gif

Когда начинаешь писать программу, допустим в кеил, вы выбираете процессор под который будите писать, и прилинковываете огромный хедер с описанием регистров. Результатом является что вы пишите

UART -> DR = Data;

а в ассемблере берется адрес + смещение этого регистра как константа, и в нее пихается содержимое регистра отвечающего за data.

Меняем процессор, меняем данные, меняем уарт, нажимаем откомпилировать код и все поехали дальше.

В вашем же случаем крепко садимся на задницу, и очень четко вспоминая какие регистры есть, каких нет. И по всему тексту пошли проверять константы, смешения.

Может утрированно, но смысл именно такой. Ассемблерный код чтобы он был эффективный должен быть крайне порезан.

в С мы можем себе позволить
Data = (int)126/24*432/12.5;

но после компиляции в адрес даты будут пихать константу, и если допустим конструкция
TimeInHour = Tic/CPU_FREQ * 60 * 60; - понятно

то в асме будет деленный регистр в котором лежат данные Tic на константу, значение который фиг разгадаешь глядя на нее...
2.1428571428571428571428571428571e-5
а по уму должно быть не деление а умножение на
46 666.666666666666666666666666667
для клока 168 МГц.

И вот как по 46 667 через год вспомнит чего вы хотели, зачем и почему это должно изменится при смене клока.... sm.gif?



Go to the top of the page
 
+Quote Post
jcxz
сообщение Jan 16 2014, 17:10
Сообщение #3


Гуру
******

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



Цитата(Golikov A. @ Jan 16 2014, 19:55) *
в С мы можем себе позволить
Data = (int)126/24*432/12.5;
но после компиляции в адрес даты будут пихать константу, и если допустим конструкция
TimeInHour = Tic/CPU_FREQ * 60 * 60; - понятно
то в асме будет деленный регистр в котором лежат данные Tic на константу, значение который фиг разгадаешь глядя на нее...
2.1428571428571428571428571428571e-5

Вы не правы. Все современные ассемблеры точно так же умеют вычислять значения константных выражений. И даже 10 лет назад уже умели.
И даже более того - средства макроязыка в ассемблерах как правило более мощные чем препроцессор си.
Мне часто очень не хватает макро-возможностей асма в си, когда вспоминаю что мог позволить себе в асме... crying.gif
Но си скован стандартом, а ассемблер - нет.
Хотя я совсем не поддерживаю ТС в его утопическом стремлении к чистому ассемблеру - жизнь его научит и отрезвит (в лице работодателя например) twak.gif
(если он конечно будет профессионально заниматься программированием, а не как любитель).

PS: Кстати - совсем не согласен с тем кто тут писал что ассемблер ARM - сложный. Из всех асмов что я когда-либо изучал, этот - самый простой.
Достаточно хотя-бы взглянуть на асм TI DSP 5000-ного семейства. rolleyes.gif
Go to the top of the page
 
+Quote Post
mantech
сообщение Jan 17 2014, 17:25
Сообщение #4


Гуру
******

Группа: Участник
Сообщений: 2 219
Регистрация: 16-08-12
Из: Киров
Пользователь №: 73 143



Цитата(jcxz @ Jan 16 2014, 21:10) *
Хотя я совсем не поддерживаю ТС в его утопическом стремлении к чистому ассемблеру - жизнь его научит и отрезвит (в лице работодателя например)
(если он конечно будет профессионально заниматься программированием, а не как любитель).


Если ТС уж так хочет сравнить си и асм, то пусть попробует написать поддержку файловой системы через УСБ флешку biggrin.gif И потом еще попробует перенести все это счастье на другой проц... А мы посмотрим, сколь лет ему на это понадобится wacko.gif

ЗЫ. Мы все стремимся, используя более высокоуровневые языки, облегчить себе жизнь, потому что у заказчиков требования тоже растут неплохо. Если 5-10 лет назад им было достаточно настройки устройства через простейшую менюшку с кнопками вниз\вверх, то теперь подавай удаленный доступ, желательно через инет, обновление прошивки по 1 тычку кнопки и т.д. Идите в ногу со временем, а не занимайтесь глупостями в виде чистого асма!
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- allsettingsdone   STM32 Ассемблер. Идеи и приёмы написания   Jan 15 2014, 22:50
- - Golikov A.   Все зависит от того чего вы хотите в итоге. Если ...   Jan 16 2014, 01:58
- - allsettingsdone   Встраивать асемблеровский код в проект на С я не п...   Jan 16 2014, 05:38
|- - scifi   Цитата(allsettingsdone @ Jan 16 2014, 09...   Jan 16 2014, 06:46
- - Golikov A.   Поддерживаю. Весь проект на ассемблере - это долго...   Jan 16 2014, 07:10
- - Сергей Борщ   Цитата(allsettingsdone @ Jan 16 2014, 00...   Jan 16 2014, 07:40
|- - SII   Цитата(Сергей Борщ @ Jan 16 2014, 11:40) ...   Jan 17 2014, 20:47
|- - _Pasha   Цитата(SII @ Jan 18 2014, 00:47) Между Си...   Jan 17 2014, 21:09
|- - SII   Цитата(_Pasha @ Jan 18 2014, 01:09) Псевд...   Jan 18 2014, 06:37
|- - _Pasha   Цитата(SII @ Jan 18 2014, 10:37) Псевдоко...   Jan 18 2014, 08:04
- - Ozelot   Топикстартер задал конкретный вопрос в надежде пол...   Jan 16 2014, 07:50
- - allsettingsdone   Как раз читаю одну из этих книг. Что касается С, т...   Jan 16 2014, 08:18
|- - scifi   Цитата(allsettingsdone @ Jan 16 2014, 12...   Jan 16 2014, 09:42
|- - jcxz   Цитата(allsettingsdone @ Jan 16 2014, 14...   Jan 16 2014, 11:08
- - MALLOY2   Цитатано когда пишешь на С, то не всегда очевидно ...   Jan 16 2014, 09:57
- - Golikov A.   ассемблер очевиднее С, только для ОЧЕНЬ маленьких ...   Jan 16 2014, 10:23
- - allsettingsdone   Ладно, а что по поводу таких вещей: Кодmov32 R0,...   Jan 16 2014, 10:56
|- - scifi   Цитата(allsettingsdone @ Jan 16 2014, 14...   Jan 16 2014, 11:05
|- - Сергей Борщ   Цитата(allsettingsdone @ Jan 16 2014, 12...   Jan 16 2014, 12:16
|- - allsettingsdone   Цитата(Сергей Борщ @ Jan 16 2014, 14:16) ...   Jan 16 2014, 13:34
|- - Сергей Борщ   Цитата(allsettingsdone @ Jan 16 2014, 15...   Jan 16 2014, 15:02
- - SasaVitebsk   1. Для некоторых процессоров ассемблер достаточно ...   Jan 16 2014, 11:19
|- - scifi   Цитата(mantech @ Jan 17 2014, 21:25) ЗЫ. ...   Jan 17 2014, 18:27
- - Golikov A.   ага или на асм ДСПешника со сдвоенным АЛУ, помню...   Jan 16 2014, 18:00
|- - jcxz   Цитата(Golikov A. @ Jan 17 2014, 00:00) п...   Jan 16 2014, 18:57
- - _Pasha   Я бы если бы так упорно писал бы на ассемблере(бы)...   Jan 16 2014, 19:01
- - Golikov A.   вам видать плохой компилятор достался ну или у вас...   Jan 17 2014, 07:13
|- - _Pasha   Цитата(Golikov A. @ Jan 17 2014, 11:13) а...   Jan 17 2014, 08:09
|- - SasaVitebsk   Цитата(_Pasha @ Jan 17 2014, 12:09) Подоз...   Jan 17 2014, 10:24
|- - Сергей Борщ   Цитата(_Pasha @ Jan 17 2014, 10:09) Подоз...   Jan 17 2014, 10:54
- - Golikov A.   не я про другое. иногда интерпритатор работает ме...   Jan 17 2014, 10:11
|- - _Pasha   Цитата(Golikov A. @ Jan 17 2014, 14:11) и...   Jan 17 2014, 17:00
|- - Golikov A.   Цитата(_Pasha @ Jan 17 2014, 21:00) Надо ...   Jan 17 2014, 20:10
- - Golikov A.   напишите виндус ан ассемблере, а потом рассказывай...   Jan 18 2014, 06:27
- - megabuks   Добрый день Что-бы не плодить темы. Помогите старт...   Jun 8 2014, 03:38
- - jcxz   Возьмите любой cstartup.asm (или как он там называ...   Jun 8 2014, 05:03


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

 


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


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