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

 
 
> Keil c51 и sprintf
crabs
сообщение Mar 20 2012, 06:14
Сообщение #1





Группа: Новичок
Сообщений: 9
Регистрация: 1-11-11
Пользователь №: 68 081



Добрый день. Столкнулся со следующей проблемой. Есть приложение, написанное для камня Si1000 в Keil. Всё отлажено и работает без нареканий. Помимо самого приложения мне понадобился бутлодер. Был написан бутлодер, приложение было сдвинуто в памяти на 2800H байт, вместе с векторами прерываний, и тд. В бутлодере, что находится в памяти начиная с нулевого адреса стоят LJMP'ы на все прерывания, которые размещены в основной программе.
После всех манипуляций программа стала зацикливаться. Как выснилось, программу вешает вызов функции sprintf() из стандартной библиотеки. Далее, по map- файлу я узнал, что зацикливается функция putchar, и в отладчике нашел место где всё останавливается. Выглядит это так:
CODE
C:0x9629 3099FD JNB TI0(0x98.1),C:9629
C:0x962C C299 CLR TI0(0x98.1)
C:0x962E F599 MOV SBUF0(0x99),A


Висяк в первой строке. То есть sprintf пытается отправить данные через последовательный порт. В программе функции вида *printf, где вызывается putchar не используются.

Менял виды оптимизации - безрезультатно. Если приложение размещается по нулевому адресу - всё ок. Как такое может быть? cranky.gif

Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
редактор
сообщение Mar 22 2012, 10:55
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 356
Регистрация: 9-06-07
Пользователь №: 28 315



Еще вариант. В проекте, работающем с 0-го адреса, в дизассемблере посмотреть какие команды сидят по данному смещению.
C:(0x9629 - 0x2800). Точка глюка минус смещение проекта.
Более вероятным выглядит вариант с неправильным переходом.




--------------------
Хорошую систему делают из стандартных блоков нестандартно мыслящие инженеры.
Go to the top of the page
 
+Quote Post



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

 


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


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