WinAvr в вопросах и ответах

Обсуждаем контроллеры компании Atmel.
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: WinAvr в вопросах и ответах

Сообщение Dimon456 »

Действительно, заработало.
Какой-то капризный компилятор, cvavr в этом отношении проще.
Реклама
Аватара пользователя
ARV
Ум, честь и совесть. И скромность.
Сообщения: 18561
Зарегистрирован: Чт дек 28, 2006 08:19:56
Откуда: Новочеркасск
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение ARV »

Dimon456 писал(а):Какой-то капризный компилятор, cvavr в этом отношении проще
он не капризный, он просто не любит, когда не соблюдают правила языка Си.
если рассматривать человека снизу, покажется, что мозг у него глубоко в жопе
при взгляде на многих сверху ничего не меняется...

Мой уютный бложик... заходите!
Реклама
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: WinAvr в вопросах и ответах

Сообщение Dimon456 »

ARV писал(а):
Dimon456 писал(а):Какой-то капризный компилятор, cvavr в этом отношении проще
он не капризный, он просто не любит, когда не соблюдают правила языка Си.
И какое же правило языка СИ я нарушил?

Я объявил глобальную переменную

Код: Выделить всё

unsigned int last_millis=0; 
куда уж глобальнее?

До winavr я использовал cvavr (возьмите мой код и прогоните через cvavr и он будет работать в таком состоянии в котором есть), с тем проблем не было, не удивительно что с этим вы используете wdt_enable с wdt_reset.

Судя из этой статьи http://chipenable.ru/index.php/item/60 этот компилятор тоит еще те подводные камни.

Странно то что в одном случае

Код: Выделить всё

unsigned int last_millis=0; 
работает, в другом нет, надо

Код: Выделить всё

volatile unsigned int last_millis=0; 
.
Странный компилятор.
Аватара пользователя
scorpi_0n
Вымогатель припоя
Сообщения: 616
Зарегистрирован: Вс ноя 01, 2015 13:13:49

Re: WinAvr в вопросах и ответах

Сообщение scorpi_0n »

В данном случае следует считать странным cvavr. Статью до конца дочитайте.
Реклама
Эиком - электронные компоненты и радиодетали
Аватара пользователя
WiseLord
Друг Кота
Сообщения: 4905
Зарегистрирован: Чт апр 11, 2013 11:19:59
Откуда: Минск
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение WiseLord »

Dimon456:

Вы сами указали в настройках компилятора определённый уровень оптимизации (предположу, -O3). Тем самым дав команду компилятору уменьшать размер кода, потребление RAM и т.д. Так что это ваша задача теперь - объявлять глобальные переменные volatile, если они могут измениться в прерывании, и это всё оговорено в документации.

Ну ОК, не то чтобы указали, а просто либо не знали, либо забыли. Но, по большому счёту, какая разница?

P.S. "На пальцах", как это работает (может, где-то упрощённо, но главное - суть):

Есть глобальная переменная - где-то в RAM. Как работает обычная функция (та же main) - переменная вытаскивается из RAM в какой-то из регистров, и там с нею уже все арифметические операции производятся. По выходу из функции изменённая переменная возвращается в RAM.

Соответственно, если МК уйдёт в прерывание, в котором его обработчик внезапно поменяет в памяти эт у переменную, то функция по возврату к ней управления продолжит работать с тем значением, что сохранено в регистре. И по окончании вернёт в память значение, невзирая на то, что там уже "постарался" обработчик прерывания.

Аналогичное явление происходит в многопоточных приложениях, когда несколько потоков, работая с одной глобальной переменной фактически (за счёт оптимизации компилятором) работают каждый с временной локальной копией.

Это нормальное поведение при включенной оптимизации для большинства переменных (ведь в прерывании их не так много меняется обычно). Если такое не нужно для конкретной переменной - объявляем её volatile, после чего при любых попытках работать с ней она будет "обновляться" из памяти. На это нужны, соответственно, лишние операции и такты процессора.

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код. То есть, даже обычные глобальные переменные, которые в прерываниях не участвуют, вероятно, постоянно "синхронизированы" с RAM при работе с ними. А это уже лишнее
Реклама
Аватара пользователя
COKPOWEHEU
Говорящий с текстолитом
Сообщения: 1525
Зарегистрирован: Чт июн 10, 2010 20:11:19

Re: WinAvr в вопросах и ответах

Сообщение COKPOWEHEU »

Можно было бы рассказать еще об атомарности и зачем она нужна, но подождем пока человек наступит на очередные грабли и прибежит жаловаться на неправильные компиляторы. Документацию ведь для дураков пишут.
Реклама
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: WinAvr в вопросах и ответах

Сообщение Dimon456 »

Интересует такой вопрос.
В своем девайсе я использую BOOTLOADER, размер 2кБайта.
Значит в atmega8 у меня осталось памяти где то 6кБайт.

Как в Makefile ограничить этот размер, что бы не 8кБайт было а, 6кБат?
Аватара пользователя
Jack_A
Друг Кота
Сообщения: 6312
Зарегистрирован: Вт апр 24, 2007 07:45:40
Откуда: Minsk

Re: WinAvr в вопросах и ответах

Сообщение Jack_A »

Я думаю, просто надо грамотно писать программу, и оно само получится. А если размер скомпилированной проги вылезет за 6кб - чем поможет makefile ? "Утопчет" байты кода или отрежет "ненужные", по его мнению ? Полученный hex всегда можно посмотреть текстовым редактором, и если он вылез за размер, то это видно, и его не надо заливать в МК.
Изображение
Dimon456
Мудрый кот
Сообщения: 1849
Зарегистрирован: Вс дек 25, 2016 08:34:54

Re: WinAvr в вопросах и ответах

Сообщение Dimon456 »

Jack_A писал(а):А если размер скомпилированной проги вылезет за 6кб - чем поможет makefile ? "Утопчет" байты кода или отрежет "ненужные", по его мнению ?
Если размер проги вылазит за пределы, компилятор предупреждает об этом.
В данном случае если 8меги не хватит, есть 168 и 328меги.
Просто думал, что makefile есть способ сказать что не 8кБ а 6кБ всего.
Аватара пользователя
s_black
Мучитель микросхем
Сообщения: 411
Зарегистрирован: Вс авг 10, 2008 19:35:49
Откуда: Евпатория
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение s_black »

Может уже было - искать по ветке долго...
Установил на новый ноутбук (Win7) WinAVR20100110. При открытии нотепейджем исходника русские комментарии читаются как крякозяблики. На старом ноутбуке (WinXP) всё было нормально. Подскажите путь решения проблемы. Спасибо!
watchmaker
Поставщик валерьянки для Кота
Сообщения: 2183
Зарегистрирован: Вс ноя 15, 2009 23:13:59
Откуда: Харьков
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение watchmaker »

Перекодировать все файлы любой доступной программой в win-1251 (или даже в utf-8) и попробовать снова.
Иногда мой питомец уходит в такую спячку, что разбудить его можно только щелчком по первой ноге...
Аватара пользователя
FreshMan
Друг Кота
Сообщения: 6296
Зарегистрирован: Пн ноя 22, 2010 00:57:15
Откуда: Ukraine

Re: WinAvr в вопросах и ответах

Сообщение FreshMan »

WiseLord писал(а):Dimon456:
P.S. "На пальцах", как это работает (может, где-то упрощённо, но главное - суть):

Есть глобальная переменная - где-то в RAM. Как работает обычная функция (та же main) - переменная вытаскивается из RAM в какой-то из регистров, и там с нею уже все арифметические операции производятся. По выходу из функции изменённая переменная возвращается в RAM.

Соответственно, если МК уйдёт в прерывание, в котором его обработчик внезапно поменяет в памяти эт у переменную, то функция по возврату к ней управления продолжит работать с тем значением, что сохранено в регистре. И по окончании вернёт в память значение, невзирая на то, что там уже "постарался" обработчик прерывания.

Аналогичное явление происходит в многопоточных приложениях, когда несколько потоков, работая с одной глобальной переменной фактически (за счёт оптимизации компилятором) работают каждый с временной локальной копией.

Это нормальное поведение при включенной оптимизации для большинства переменных (ведь в прерывании их не так много меняется обычно). Если такое не нужно для конкретной переменной - объявляем её volatile, после чего при любых попытках работать с ней она будет "обновляться" из памяти. На это нужны, соответственно, лишние операции и такты процессора.

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код. То есть, даже обычные глобальные переменные, которые в прерываниях не участвуют, вероятно, постоянно "синхронизированы" с RAM при работе с ними. А это уже лишнее
и где только ты все это вычитал ? :)
Tell Me The Truth
watchmaker
Поставщик валерьянки для Кота
Сообщения: 2183
Зарегистрирован: Вс ноя 15, 2009 23:13:59
Откуда: Харьков
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение watchmaker »

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код.
Так одно время делал и WinAVR, в последних сборках перестал.
Иногда мой питомец уходит в такую спячку, что разбудить его можно только щелчком по первой ноге...
Аватара пользователя
ARV
Ум, честь и совесть. И скромность.
Сообщения: 18561
Зарегистрирован: Чт дек 28, 2006 08:19:56
Откуда: Новочеркасск
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение ARV »

watchmaker писал(а):Так одно время делал и WinAVR, в последних сборках перестал.
если последними считать все, начиная с 2010 года, то да.
если рассматривать человека снизу, покажется, что мозг у него глубоко в жопе
при взгляде на многих сверху ничего не меняется...

Мой уютный бложик... заходите!
Аватара пользователя
Z_h_e
Собутыльник Кота
Сообщения: 2708
Зарегистрирован: Сб май 14, 2011 21:16:04
Откуда: г. Чайковский

Re: WinAvr в вопросах и ответах

Сообщение Z_h_e »

WiseLord писал(а):Есть глобальная переменная - где-то в RAM. Как работает обычная функция (та же main) - переменная вытаскивается из RAM в какой-то из регистров, и там с нею уже все арифметические операции производятся. По выходу из функции изменённая переменная возвращается в RAM.

Соответственно, если МК уйдёт в прерывание, в котором его обработчик внезапно поменяет в памяти эт у переменную, то функция по возврату к ней управления продолжит работать с тем значением, что сохранено в регистре. И по окончании вернёт в память значение, невзирая на то, что там уже "постарался" обработчик прерывания.
Следует добавить, что volatile не дает атомарности и при работе с многобайтными переменными, в некоторых случаях, нужно запрещать прерывания.
Изображение
Добро всегда побеждает зло. Поэтому кто победил - тот и добрый.
watchmaker
Поставщик валерьянки для Кота
Сообщения: 2183
Зарегистрирован: Вс ноя 15, 2009 23:13:59
Откуда: Харьков
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение watchmaker »

Следует добавить, что volatile не дает атомарности и при работе с многобайтными переменными
Интересно. В Яве кстати аналогично.
Иногда мой питомец уходит в такую спячку, что разбудить его можно только щелчком по первой ноге...
ruslansh
Встал на лапы
Сообщения: 105
Зарегистрирован: Пн окт 03, 2011 19:59:52

Re: WinAvr в вопросах и ответах

Сообщение ruslansh »

Привет, в winAWR как можно изменить тип контроллера? Исходник под 164 ую атмегу, мне нужно откомпелировать его под 16 ую.
watchmaker
Поставщик валерьянки для Кота
Сообщения: 2183
Зарегистрирован: Вс ноя 15, 2009 23:13:59
Откуда: Харьков
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение watchmaker »

Скорее всего придётся редактировать сами исходники - у "старых" атмег (8, 16, 32) регистры расположены не так, как у более новых. А если всё совпадает - искать в Makefile параметр target и подставлять туда идентификатор контроллера.
Иногда мой питомец уходит в такую спячку, что разбудить его можно только щелчком по первой ноге...
ruslansh
Встал на лапы
Сообщения: 105
Зарегистрирован: Пн окт 03, 2011 19:59:52

Re: WinAvr в вопросах и ответах

Сообщение ruslansh »

правил. Вроде запустилось железо. Но на всякий случай хочу уточнить. В исходниках где ни будь прописано какие фьюзы нужно выставить?
watchmaker
Поставщик валерьянки для Кота
Сообщения: 2183
Зарегистрирован: Вс ноя 15, 2009 23:13:59
Откуда: Харьков
Контактная информация:

Re: WinAvr в вопросах и ответах

Сообщение watchmaker »

Нет, это выставляется отдельно при прошивке, например в ponyprog или в avrdude-gui.
Иногда мой питомец уходит в такую спячку, что разбудить его можно только щелчком по первой ноге...
Ответить

Вернуться в «AVR»