Обсуждаем контроллеры компании Atmel.
Ответить

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

Вс дек 25, 2016 17:22:31

Действительно, заработало.
Какой-то капризный компилятор, cvavr в этом отношении проще.

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

Вс дек 25, 2016 19:18:25

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

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

Вс дек 25, 2016 20:20:21

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;
.
Странный компилятор.

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

Вс дек 25, 2016 20:36:14

В данном случае следует считать странным cvavr. Статью до конца дочитайте.

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

Вс дек 25, 2016 21:38:11

Dimon456:

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

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

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

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

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

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

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

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код. То есть, даже обычные глобальные переменные, которые в прерываниях не участвуют, вероятно, постоянно "синхронизированы" с RAM при работе с ними. А это уже лишнее

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

Вс дек 25, 2016 22:51:03

Можно было бы рассказать еще об атомарности и зачем она нужна, но подождем пока человек наступит на очередные грабли и прибежит жаловаться на неправильные компиляторы. Документацию ведь для дураков пишут.

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

Пн дек 26, 2016 17:07:57

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

Как в Makefile ограничить этот размер, что бы не 8кБайт было а, 6кБат?

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

Пн дек 26, 2016 17:15:15

Я думаю, просто надо грамотно писать программу, и оно само получится. А если размер скомпилированной проги вылезет за 6кб - чем поможет makefile ? "Утопчет" байты кода или отрежет "ненужные", по его мнению ? Полученный hex всегда можно посмотреть текстовым редактором, и если он вылез за размер, то это видно, и его не надо заливать в МК.

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

Вт дек 27, 2016 07:37:50

Jack_A писал(а):А если размер скомпилированной проги вылезет за 6кб - чем поможет makefile ? "Утопчет" байты кода или отрежет "ненужные", по его мнению ?
Если размер проги вылазит за пределы, компилятор предупреждает об этом.
В данном случае если 8меги не хватит, есть 168 и 328меги.
Просто думал, что makefile есть способ сказать что не 8кБ а 6кБ всего.

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

Пн янв 16, 2017 18:34:44

Может уже было - искать по ветке долго...
Установил на новый ноутбук (Win7) WinAVR20100110. При открытии нотепейджем исходника русские комментарии читаются как крякозяблики. На старом ноутбуке (WinXP) всё было нормально. Подскажите путь решения проблемы. Спасибо!

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

Пн янв 16, 2017 20:41:55

Перекодировать все файлы любой доступной программой в win-1251 (или даже в utf-8) и попробовать снова.

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

Вт янв 17, 2017 23:48:20

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

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

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

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

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

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код. То есть, даже обычные глобальные переменные, которые в прерываниях не участвуют, вероятно, постоянно "синхронизированы" с RAM при работе с ними. А это уже лишнее


и где только ты все это вычитал ? :)

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

Вс фев 12, 2017 03:06:36

То что CVAVR так делает даже не с volatile переменными может говорить лишь о том, что он генерирует не самый оптимальный код.

Так одно время делал и WinAVR, в последних сборках перестал.

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

Вс фев 12, 2017 05:33:32

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

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

Вс фев 12, 2017 05:59:32

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

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

Следует добавить, что volatile не дает атомарности и при работе с многобайтными переменными, в некоторых случаях, нужно запрещать прерывания.

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

Вт фев 21, 2017 01:19:26

Следует добавить, что volatile не дает атомарности и при работе с многобайтными переменными

Интересно. В Яве кстати аналогично.

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

Пт июн 09, 2017 23:52:51

Привет, в winAWR как можно изменить тип контроллера? Исходник под 164 ую атмегу, мне нужно откомпелировать его под 16 ую.

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

Сб июн 10, 2017 19:16:16

Скорее всего придётся редактировать сами исходники - у "старых" атмег (8, 16, 32) регистры расположены не так, как у более новых. А если всё совпадает - искать в Makefile параметр target и подставлять туда идентификатор контроллера.

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

Сб июн 10, 2017 20:35:44

правил. Вроде запустилось железо. Но на всякий случай хочу уточнить. В исходниках где ни будь прописано какие фьюзы нужно выставить?

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

Вс июн 11, 2017 19:12:09

Нет, это выставляется отдельно при прошивке, например в ponyprog или в avrdude-gui.
Ответить