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

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> WinAVR2007 & AVR Studio 4.13, возможно глупый вопрос, но очень важный
Сергей Борщ
сообщение Jan 19 2008, 10:07
Сообщение #16


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 19 2008, 04:26) *
А как можно посмотреть какие функции включены в программу? 1,7к многовато (я думаю) )для кода:
Ну, приведенного кода тут байтов на 50, а вот внутри этих функций может быть сколько угодно. Посмотреть, какие функции включены, можно, поставив галочки генерации листинга и .map-файла. А потом долго медитировать над этими файлами.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 21 2008, 22:09
Сообщение #17


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
Посмотреть, какие функции включены, можно, поставив галочки генерации листинга и .map-файла.

Поставил, посмотрел. Хочу знать мнение того кто смотрит на них не первый раз. Прикрепляю.
Прикрепленный файл  default.rar ( 7.21 килобайт ) Кол-во скачиваний: 91


Далее.
Цитата
Судя по симптомам, не выдерживаете паузу от подачи питания до первой команды. Вставьте задержку миллисекунд 50-200 перед инициализацией.

Добавил задержку. ничего не изменилось. Менял опции оптимизации - нет результата. Но причина определена верно. Если физически (RESETом) сбросить конроллер при включенном LCD - все становится на свои места, программа нормально отображает обе строки. А по сему, как ввести эту задержку? Что только не делал... от delay_ms до for(i=1600;i>0;i--). Ничего не помогает. Ну точно оптимизиорует, ка как наверняка узнать? И что делать?

Сообщение отредактировал smk - Jan 21 2008, 22:14


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 21 2008, 23:25
Сообщение #18


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 22 2008, 00:09) *
Добавил задержку. ничего не изменилось..
Если физически (RESETом) сбросить конроллер при включенном LCD - все становится на свои места, программа нормально отображает обе строки.
А может и не задержка виновата. Дисплей в каком режиме используется (8 или 4 битном)?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 21 2008, 23:34
Сообщение #19


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
Дисплей в каком режиме используется (8 или 4 битном)?

4-х битном.


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 22 2008, 08:23
Сообщение #20


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 22 2008, 01:34) *
4-х битном.
Глянул исходник - там совершенно неправильно сделана инициализация. Ошибок там минимум три -
1) После первых двух команд читать busy flag бессмысленно, надо делать задержки. Если память не изменяет - 200 и 50 мс.
2)LCD_FUNCTION_DEFAULT должен писаться четыре раза.
3)LCD_FUNCTION_DEFAULT первые 3 раза должен писаться в один проход независимо от режима - 8 или 4 битного, а не двумя тетрадами как в вашей реализации.
Поищите здесь по форуму, тема обсасывалась множество раз. В обсуждениях выкладывали даташит на контроллер, в котором описан алгоритм инициализации. Несколько исходников было в форуме по AVR в ветке "исходники программ и библиотек". .map гляну чуть позже.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 22 2008, 09:22
Сообщение #21


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
Глянул исходник - там совершенно неправильно сделана инициализация. Ошибок там минимум три -
1) После первых двух команд читать busy flag бессмысленно, надо делать задержки. Если память не изменяет - 200 и 50 мс.
2)LCD_FUNCTION_DEFAULT должен писаться четыре раза.
3)LCD_FUNCTION_DEFAULT первые 3 раза должен писаться в один проход независимо от режима - 8 или 4 битного, а не двумя тетрадами как в вашей реализации.

Исправил. Все заработало. Даже не понадобилось делать задержку в начале программы. Огромное спасибо за подсказки и помощь!

Теперь, если можно, еще одна проблема у меня появилась. Ставил AVR Studio 4.13 на комп, кге уже установлен WinAVR2007. При инсталляции обнаружилась вот такая ощибка:
Error 1723: There is a problem with this Windows Installer package. A DLL required for this install to complete could not be run. Contact your support personnel or package vendor.

Система: Win2000 5.00.2195 SP4; 2 x PIII 1266 MHz AT/AT

Кто-нибудь знает какие пути устранения проблемы есть? Очень нужно иметь два рабочих места, так чтоб проект, начатый на одном компе можно было продолжать писать и симулировать на другом и т.п. Очень надо! Заранее благодарен!


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 22 2008, 19:24
Сообщение #22


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
There is a problem with this Windows Installer package.

ОС не обновлшялась, если я установлю Windows Installer 3.1.4000.2435 есть ли шанс, что проблема решится?


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 23 2008, 19:56
Сообщение #23


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
.map гляну чуть позже.

Не хочу навязываться, но всеж как со временем? Оч хочется довести до ума ситуацию. Заранее благодарю!


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 23 2008, 22:15
Сообщение #24


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 23 2008, 21:56) *
Оч хочется довести до ума ситуацию.
Ой. Извиняюсь. Давайте смотреть .map вместе:
Код
.text           0x00000000      0x6a2  <- Итого во флеш попадает 1698 байт.
.vectors       0x00000000       0x26<- Вектора. Ненаказуемо. Заняты все.
.progmem.data  0x00000026       0x88 lcd.o <- 136 байт констант. Судя по следующей строке - знакогенератор
                0x00000026                LcdCustomChar
.text.main     0x000000e6       0x40 123.o   <- собственно main(), 64 байта
-------- дальше идут функции дисплея, которые вызываются из main или прерываний -------
.text.lcdInitHW              0x00000126       0x1a lcd.o
.text.lcdBusyWait           0x00000140       0x5c lcd.o
.text.lcdControlWrite      0x0000019c       0x64 lcd.o
.text.lcdControlRead      0x00000200       0x4e lcd.o
.text.lcdDataWrite         0x0000024e       0x64 lcd.o
.text.lcdGotoXY             0x000002b2       0x1a lcd.o
.text.lcdLoadCustomChar     0x000002cc       0x52 lcd.o
.text.lcdPrintData             0x0000031e       0x2a lcd.o
.text.lcdInit                     0x00000348       0x6e lcd.o
                                  ---------------------- итого 656 байт -----------------
а дальше ваши прерывания для таймера - 5 раз по 0x5A байт (450 байт)
.text.__vector_8           0x0000045e       0x5a timer.o
.text.__vector_6           0x00000538       0x5a timer.o
.text.__vector_7            0x00000592       0x5a timer.o
.text.__vector_5            0x000005ec       0x5a timer.o
.text.__vector_3            0x00000646       0x5a timer.o
и пара по 166 + 128 байт
.text.__vector_9            0x000003b8       0xa6 timer.o
.text.__vector_4             0x000004b8       0x80 timer.o
Мелкие секции я опустил. По имени секции в первой колонке вы можете узнать имя функции, по адресам из второй колонки можно в листинге найти получившийся код.

Зря вы решили читать флаг BUSY. Без него код получается значительно меньше.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 23 2008, 22:25
Сообщение #25


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
По имени секции в первой колонке вы можете узнать имя функции, по адресам из второй колонки можно в листинге найти получившийся код.

Спасибо! А вывод всеж какой делаем? Все хорошо или что-то не так? Я вот чуток дописал код. вывожу на LCD немножко текста и цифирки (счетчик цикла) так код стал 5к. Не верю что это нормально.

Цитата
Зря вы решили читать флаг BUSY.

Это не я. Это AVRlib.


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 24 2008, 10:27
Сообщение #26


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 24 2008, 00:25) *
Спасибо! А вывод всеж какой делаем? Все хорошо или что-то не так?
Ну раз работает - значит хорошо. Вы находитесь на стадии, когда использование чужих библиотек ускоряет процесс разработки. Когда вы упретесь в нехватку памяти или скорости - перейдете на следующий уровень, когда библиотеки пишутся под себя с минимумом универсальности и максимумом эффективности.
Цитата(smk @ Jan 24 2008, 00:25) *
Я вот чуток дописал код. вывожу на LCD немножко текста и цифирки (счетчик цикла) так код стал 5к. Не верю что это нормально.
Ну тогда берите исходник библиотеки и выкидывайте из него все лишнее. Я, например, так и не понял зачем у вас в прерываниях таймера вызов функций по указателю. Вы собираетесь подменять обработчики "на лету"? Все обработчики?
Цитата(smk @ Jan 24 2008, 00:25) *
Это не я. Это AVRlib.
А голова у кого? wink.gif


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 24 2008, 10:46
Сообщение #27


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
А голова у кого?

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

К этому и стремлюсь. Для этого стараюсь разобраться как пишут другие, научится писать в WinAVR без ошибок в синтаксисе, понять как устроен проект, какие опции существуют... вот где почитать про сообщения об ошибках на русском?


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 24 2008, 11:37
Сообщение #28


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(smk @ Jan 24 2008, 12:46) *
понять как устроен проект, какие опции существуют...
WinAVR\DOC\gcc, WinAVR\DOC\binutils\ld.html\index.html#Top, WinAVR\DOC\avr-libc\avr-libc-user-manual\index.html, WinAVR\DOC\avr-libc\avr-libc-user-manual\FAQ.html

Цитата(smk @ Jan 24 2008, 12:46) *
вот где почитать про сообщения об ошибках на русском?
http://translate.google.com/translate_t?langpair=en|ru?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
smk
сообщение Jan 24 2008, 20:43
Сообщение #29


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



Цитата
WinAVR\DOC\gcc, WinAVR\DOC\binutils\ld.html\index.html#Top, WinAVR\DOC\avr-libc\avr-libc-user-manual\index.html, WinAVR\DOC\avr-libc\avr-libc-user-manual\FAQ.html

Читаю конечно. Описание стандартных функций нашел в книге Шпака... вобщем, учусь! Ждите еще вопросов, они наверняка появятся! Спасибо за ответы и потраченное на меня время!


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 3rd August 2025 - 13:00
Рейтинг@Mail.ru


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