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

 
 
 
Reply to this topicStart new topic
> Взаимодействие компилятора и ассемблера, Keil RealView и его-же Asm
sonycman
сообщение Feb 2 2007, 20:43
Сообщение #1


Любитель
*****

Группа: Свой
Сообщений: 1 864
Регистрация: 20-08-06
Из: Тольятти
Пользователь №: 19 695



Что-то не пойму, как поступить sad.gif
Ситуация такая:
Есть функция Delay(unsigned long delay), которая написана на асме и использует регистры R0 и R1. R0 - так как в нём передаётся параметр, а R1 дополнительно.
Вызывается она из программы на C.
Так вот - стоит ли сохранять и восстанавливать по выходу регистр R1? Вдруг компилятор хранит в нём какие-то данные, а я его затру?

Ещё до конца не понятно, для чего используется директива PRESERVE8.
Она даёт знать линкеру, что код сохраняет выравнивание стёка по границе 8 байт.
А для каких целей необходимо такое выравнивание?

Сообщение отредактировал sonycman - Feb 2 2007, 20:50
Go to the top of the page
 
+Quote Post
beer_warrior
сообщение Feb 2 2007, 21:10
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 065
Регистрация: 8-10-05
Из: Kiev, UA
Пользователь №: 9 380



Цитата
Так вот - стоит ли сохранять и восстанавливать по выходу регистр R1? Вдруг компилятор хранит в нём какие-то данные, а я его затру?

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


--------------------
Вони шукають те, чого нема,
Щоб довести, що його не існує.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 2 2007, 21:47
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата
Тогда все что используетсяна входе в стек, на выходе вытолкнуть.

Фу, как грубо sad.gif
Цитата(DASM @ Feb 2 2007, 20:40) *
Еще была такая штука кажется ARM Procedure Call Standard называлась, APCS - весьма доходчиво все расписано

Вот имено.Точнее ATPCS -
Advanced RISC Machines Ltd ARM/Thumb Procedure Call Standard.
Сие есть официальный документ. Лежит на армовском сайте.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
sonycman
сообщение Feb 2 2007, 23:12
Сообщение #4


Любитель
*****

Группа: Свой
Сообщений: 1 864
Регистрация: 20-08-06
Из: Тольятти
Пользователь №: 19 695



Ага, нашёл этот ATPCS:
A subroutine must preserve the contents of the registers r4-r8, r10, r11 and SP...
Значит, содержимое регистров R0-R3 можно не сохранять. Понятно.
Спасибо smile.gif
Go to the top of the page
 
+Quote Post
Stanislav
сообщение Feb 3 2007, 03:06
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 4 363
Регистрация: 13-05-05
Из: Москва
Пользователь №: 4 987



Цитата(zltigo @ Feb 2 2007, 21:47) *
Цитата(DASM @ Feb 2 2007, 20:40) *

Еще была такая штука кажется ARM Procedure Call Standard называлась, APCS - весьма доходчиво все расписано
Вот имено.Точнее ATPCS -
Advanced RISC Machines Ltd ARM/Thumb Procedure Call Standard.
Сие есть официальный документ. Лежит на армовском сайте.
Более того, добавлю (может, и запоздало), что в ран-тайм модели и соглашениях любого компилятора чётко прописаны принципы вызова процедур, и все действия и ограничения, необходимые для их корректной реализации на АСМе.
В частности, для Кейла вполне достаточно ознакомиться с его компиляторным хелпом, без поиска неких вычурных документов.


--------------------
Самонадеянность слепа. Сомнения - спутник разума. (с)
Go to the top of the page
 
+Quote Post
beer_warrior
сообщение Feb 3 2007, 03:58
Сообщение #6


Профессионал
*****

Группа: Свой
Сообщений: 1 065
Регистрация: 8-10-05
Из: Kiev, UA
Пользователь №: 9 380



Цитата
Более того, добавлю (может, и запоздало), что в ран-тайм модели и соглашениях любого компилятора чётко прописаны принципы вызова процедур

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


--------------------
Вони шукають те, чого нема,
Щоб довести, що його не існує.
Go to the top of the page
 
+Quote Post
Stanislav
сообщение Feb 3 2007, 04:16
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 4 363
Регистрация: 13-05-05
Из: Москва
Пользователь №: 4 987



Цитата(beer_warrior @ Feb 3 2007, 03:58) *
Цитата
Более того, добавлю (может, и запоздало), что в ран-тайм модели и соглашениях любого компилятора чётко прописаны принципы вызова процедур

Вот то-то и оно соглашениях компилятора. Заточат его под Кейл, а потом наследники будут иметь секс, почему программа вылетает. Тем более, когда цена вопроса пару тактов.
Во-первых, не пару тактов (или Вам пояснить, сколько времени занимает сохранение и восстановление регистров в ARMе?). Думаю, что разработчики компиляторов в данном вопросе постарались соответствовать требованию потребителя их продукта - возможности реализовать короткие быстрые процедуры на АСМе (для этого, собссно, он - АСМ - нынче и нужен).
Во-вторых, никто не заставляет Вас соответствовать в точности соглашениям. Ежели хотите сделать код универсальным - компилер даёт Вам эту возможность. Только будьте добры смириться при этом с неизбежными накладными расходами.
В-третьих, ежели Вы собрались перетащить проЭкт на другой компилер, на мешает ознакомиться с новыми соглашениями. Может так статься, что они во многом пересекаются со старыми. smile.gif
PS. Тем более, что ARM сам некий стандарт прописал...


--------------------
Самонадеянность слепа. Сомнения - спутник разума. (с)
Go to the top of the page
 
+Quote Post
sonycman
сообщение Feb 3 2007, 04:56
Сообщение #8


Любитель
*****

Группа: Свой
Сообщений: 1 864
Регистрация: 20-08-06
Из: Тольятти
Пользователь №: 19 695



Вот что мне не нравится в хвалёном RealView, так это отсутствие квалификаторов функций __ram и __thumb/__arm.
Ну последние ещё можно использовать через #pragma, а вот для ram функций приходится отводить отдельный файл и прописывать для него адреса. Не пойму, чем неугодило простое __ram?

ЗЫ: хорошо хоть __irq оставили smile.gif
Go to the top of the page
 
+Quote Post
zltigo
сообщение Feb 3 2007, 05:36
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(beer_warrior @ Feb 3 2007, 02:58) *
Заточат его под Кейл, а потом наследники будут иметь секс, почему программа вылетает.

1. Соглашения, как ни странно соблюдаются smile.gif
2. Предупредить "наследников" очень лекго - контроль чем компилится и
#pragma error "PLEASE CHECK Procedure Call"
Цитата
Тем более, когда цена вопроса пару тактов.

Станислав ответил.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 19th July 2025 - 23:11
Рейтинг@Mail.ru


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