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

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

Ср окт 18, 2017 08:00:35

Пока_без_кота писал(а):Все что позже, поставляеться каким-то набором файлов, и я незнаю, как его установить.
ну если вы работаете в студии, то проблемы, конечно, могут быть. я пользуюсь Eclipse и особо не горюю...

можете попробовать, предварительно заархивировав папку с уже установленной версией avr-gcc, скачать более свежую версию и тупо перезалить содержимое папок - их названия одинаковы, файлы предыдущей версии будут затерты новыми... если не понравится - вытрете все вобще и из архива восстановите прежнюю версию. вся инсталляция заключается только в распаковке архива и правильном прописывании путей в PATH...

Добавлено after 1 minute 43 seconds:
Пока_без_кота писал(а):conflicting types for 'SendStr_P'
это скорее всего из-за того, что прототип и реализация у вас не одинаковые. небось, в прототипе-то забыли const дописать...

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

Ср окт 18, 2017 08:08:03

ARV писал(а):... небось, в прототипе-то забыли const дописать...
Бинго! Вы наверное и по фотографии много чего умеете :)))
Насчет подмены фалов, после работы попробую.

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

Ср окт 18, 2017 08:49:12

Пока_без_кота писал(а):Бинго!
ну дык легко указывать на те ошибки других, которые сам совершал не один раз...

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

Ср окт 18, 2017 18:58:45

Эта музыка будет вечной ... Теперь такая ситуация:
Все строки во флеше обьявлены вот так:
Код:
const char AT[] PROGMEM = "AT\r\n";
const char OK[] PROGMEM = "OK\r\n";
const char ATE0[] PROGMEM = "ATE0\r\n";
const char ATV0[] PROGMEM = "ATV0\r\n";

Есть функция парсинга строки:

Прототип обявлен соответственно:
Код:
char Parsing(char *string, unsigned int parsing_delay);

Имею warning: passing argument 1 of 'Parsing' discards 'const' qualifier from pointer target type [enabled by default]
Вроде все понятно, как и в предыдущий раз добавляю const в прототип, получая
Код:
char Parsing(const char *string, unsigned int parsing_delay);

и в саму функцию (код не привожу, понятно что меняеться только в "шапке").
И получаю уже другой warning: assignment discards 'const' qualifier from pointer target type [enabled by default] на строчке функции парсинга
Код:
parsing_pointer = string;

Как побороть этот порочный круг ? :oops:
П.С. Как всегда, написал, и только тогда понял как. Надо переменную обявить как
Код:
const char *volatile   parsing_pointer;

Верно ? Просто для меня это как-то нелогично, к переменной приписывать атрибут const :dont_know:

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

Ср окт 18, 2017 19:36:29

Логично.
все указатели, которые "смотрят" во flash, должны быть указателями на константу.

const char * var; надо читать задом наперед: [переменная] var - это указатель на символ-константу.

то есть не переменная константа, а указатель на константу. сам указатель вполне себе не константный.

если вам приспичит иметь константный указатель, то он должен быть записан иначе, вам уже объясняли: char * const var; - читаем задом наперед: var - это неизменяемый (т.е. константный) указатель на char

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

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

Ср окт 18, 2017 22:18:28

Спасибо, понял.
Почему вот так массив можно описать
Код:
unsigned char   buffer[20];

а вот так уже нет
Код:
#define         buffer_max   20;                     // Размерность буффера
unsigned char   buffer[buffer_max];   

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

Ср окт 18, 2017 22:40:17

Пока_без_кота писал(а):а вот так уже нет
Код:
#define         buffer_max   20;                     // Размерность буффера
unsigned char   buffer[buffer_max];   

Можно. Но у Вас ошибка в дефайне. Сделайте сами замену текста и поймёте в чём ошибка :)

Добавлено after 9 minutes 15 seconds:
Си - странный язык... чтобы понять некоторые записи, надо смотреть на них справа налево, хотя почти все читается слева направо...

Ничего странного, всё предельно просто. То, что слева от звёздочки - относится к типу на указываемый объект, всё что справа от неё - к самому указателю.

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

Чт окт 19, 2017 06:36:11

Аlex писал(а):Ничего странного, всё предельно просто.
привыкнуть можно, конечно, но вот что прямо-таки предельно просто, не соглашусь. если левее идентификатора переменной находится две звездочки, и между ними квалификатор[ы], то уже понять, что относится к левой, а что к правой звездочке уже не так элементарно... ну да ладно, это я уже брюзжу...

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

Чт окт 19, 2017 07:34:45

Пока_без_кота писал(а):Прошу прощения, но я буквально скопировал buffer_max из дефайна в размерность буффера, и все равно ошибка "имеет место быть". Я не понимаю :dont_know:

Вы меня не поняли. Заменять нужно не buffer_max, а то, на что это меняется в программе.
Вы, по всей видимости, с трудом представляете, что такое define. На самом деле, всё очень просто. define - это обычная подмена одного текста, на другой. Не более того.
Посмотрите, что и на что заменяется :
Код:
Заменяется    Вот это      На это   
            |          |            |
            |          |            |
#define      buffer_max      20;    // Размерность буффера

и сами вручную замените у себя в программе. И сразу увидите ошибку.
Мне не хочется Вам сразу на неё указывать. Хотелось бы, чтобы Вы её сами обнаружили, дабы в дальнейшем в неё меньше вляпываться.

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

Чт окт 19, 2017 17:01:20

Я действительно не понимаю чего я не понимаю.
Я понимаю, что дефайн, это просто змена текста.
Но я не понимаю, почему, если я его определил, эта замена не хочет осуществляться. :oops:

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

Чт окт 19, 2017 17:02:48

А зачем там в дефайне лишняя точка с запятой? Это приведёт к ошибке 100%.

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

Чт окт 19, 2017 17:13:31

А зачем там в дефайне лишняя точка с запятой? Это приведёт к ошибке 100%.

Ошибка которую находит компилятор - это не ошибка вовсе :)) Так, опечатка, исправил - и нет ее :))

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

Чт окт 19, 2017 17:20:18

А зачем там в дефайне лишняя точка с запятой? Это приведёт к ошибке 100%.
А откуда вы взяли этот код? В том, что я выложил несколькими постами выше, нет этой точки с запятой...

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

Чт окт 19, 2017 17:27:03

Уберите ту, которая есть...

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

Чт окт 19, 2017 17:27:38

Спасибо, понял.
Почему вот так массив можно описать
Код:
unsigned char   buffer[20];

а вот так уже нет
Код:
#define         buffer_max   20;                     // Размерность буффера
unsigned char   buffer[buffer_max];   


хм... Это не Ваш пост?

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

Чт окт 19, 2017 17:31:28

Всем спасибо за ваше терпение!!! До меня дошло.

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

Чт окт 19, 2017 17:54:12

А зачем там в дефайне лишняя точка с запятой? Это приведёт к ошибке 100%.

Вот знал я, что кто-нибудь не выдержит и скажет :)
Совсем не дают людям подумать ... :(

Я же не зря человеку написал - замените текст вручную. Причём подробно расписал, что и на чего меняется.

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

Чт окт 19, 2017 18:29:03

Не сердитесь)) Я думаю, мне еще представиться случай подумать :))) В свое опрадание только скажу, что я воспринимал эту точку с запятой не как обязательную конструкцию языка Си, а как символ начала коментария (сказываеться опыт программирования на 3 ассемблерах, без единого ЯВУ).

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

Чт окт 19, 2017 18:40:34

точка с запятой в макросе - это еще фигня на постном масле... а вот древние версии avr-gcc подтягивали туда и комментарии в стиле // - вот где был кошмар на улицу Вязов! можете даже поискать в гугле - полно советов в строке макросов не делать комментариев или делать их в /* таком виде */... даже я такие советы давал лет несколько тому назад :)))

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

Чт окт 19, 2017 18:49:32

Спасибо за "предупредительный выстрел" :write:
Ответить