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

 
 
> Использование asm библиотек в Си
scout
сообщение Oct 15 2009, 07:57
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 120
Регистрация: 4-01-06
Из: Москва
Пользователь №: 12 837



Ситуация такова.
Имеется "библиотека" написанная на асме.
Библиотека довольно большая, используется давно и уже отлажена.
Сегментирования кода и данных нет, тоесть все привязанно к абсолютным адресам.
Написана на mpasm, причем не мной.

Очень хотелось бы использовать ее совмесно с С компилятором. Как с наименьшими телодвижениями
это сделать? Беглый просмотр доки на aсм Иара и Хайтека определил различия с mpasm. Может проще
оформить все в виде настоящей библиотеки используя среду, где она была рождена, т.е Mplab?

Вторая задача состоит в выборе компилятора. Много работал с Иаром, все нравится, но
он поддерживает только PIC18 - не универсально(возможно придется еще работать с PIC16).
Хотя макроассемблер Иара мне больше понравился, чем Хайтека,
да и отладчик там имхо приятней, чем в MPLAB. Также нет информации насчет безглючности, оптимальности
и тд. Вроде как Хайтек все хвалят, про Иар ничего не слышал...

Есть еще одна непонятка. Как я понимаю С компилятор при вызове подпрограммы на асме не знает
какие регистры могут похерится(STATUS, BSR, FSR и тд), соответственно не заботится о их сохранении.
Получается что мне придется ковырять чужую библиотеку и дописывать сохранение контекста чтобы ее можно было полноценно использовать в С?


--------------------
То, что неясно, следует выяснить. То, что трудно творить, следует делать с великой настойчивостью.
Конфуций
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
scout
сообщение Oct 15 2009, 18:03
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 120
Регистрация: 4-01-06
Из: Москва
Пользователь №: 12 837



На Си переписывать муторно и потом отлавливать глюки... Решил все же оформить в виде ассемблерного модуля, переменные которые выделялись директивой CBLOCK заменю на секции, пусть линкер поработает. Ну и придется в ручную парсить исходник смотреть где там регистры могут меняться...
Или же можно родить библиотеку средствами MPLAB и цеплять ее потом к компилеру? Помогите внести ясность в данный вопрос!

Остается открытым также вопрос о выборе компилятора. IAR али HITECH?


--------------------
То, что неясно, следует выяснить. То, что трудно творить, следует делать с великой настойчивостью.
Конфуций
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Oct 15 2009, 19:39
Сообщение #3


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Цитата
Ну и придется в ручную парсить исходник смотреть где там регистры могут меняться...
Или же можно родить библиотеку средствами MPLAB и цеплять ее потом к компилеру?

Нужно привести в соответствие calling conventions в Вашей библиотеке с соглашениями принятыми в данном компиляторе. Сложно это или нет - решать Вам, универсальностей тут нет. Приведите пример на пару-тройку функций с достаточно большим кол-вом параметров. Есть еще путь - скопипастить потихоньку весь текст в инлайновый ассемблер. В любом случае, самый универсальный путь - это через таблицу вызовов + некоторые действия по согласованию использования регистров

Цитата
IAR али HITECH?

Есть еще SDCC
Go to the top of the page
 
+Quote Post



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

 


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


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