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

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

Пн июн 12, 2017 05:57:26

Прошу прощения, вы меня не правильно поняли. Я в курсе что фьюзы выставляются при прошивке. Вопрос в том - можно ли по исходнику узнать какие фьюзы нужно выставить?

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

Пн июн 12, 2017 08:23:28

Только анализируя что используется. Например, если в ATmega8/48/... используется таймер 2 в асинхронном режиме, наверняка там должен висеть часовой кварц, а это значит что тактирование ядра будет не от него же, а от встроенного RC-генератора. Или если вывод RESET или JTAG используются как обычные порты ввода-вывода, должны быть установлены соответствующие фузы. Или если нигде нет настройки сторожевого таймера и его сбросов, надо его и фузами отключить. Ну и так далее.
Иногда необходимые фузы прописываются в каком-то из файлов конфигурации или описания, или даже в Makefile.

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

Ср авг 16, 2017 09:32:29

WinAVR-20100110
Как стал объем
Program: 50.0% Full,
То *.hex - файл не шьется
делаешь 49.9 - все норм

WinAVR- вроде как свободна для распространения?

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

Ср авг 16, 2017 09:46:08

А контроллер-то правильный?

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

Ср авг 16, 2017 09:50:09

Если вопрос мне, то стоит mega128 и WinAVR сообщает тоже при компиляции

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

Ср авг 16, 2017 19:58:05

что ж вы такое на 64 килобайта насочиняли-то?! может, оптимизацию включить забыли?

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

Чт авг 17, 2017 15:12:23

В теме: Глюки программирования mega128

Я уже сообщал, что прога не моя.
Я ищу глюки и аддаптирую её для работы с портом.
А вообще содержание - это меню, LCD, небольшая обработка графики, клава, внешняя ОЗУ, работа с UART

Посмотрю Make: какой там ключ

Добавлено after 4 hours 4 minutes 10 seconds:
Из Даташит:

Внутрисистемно программируемая флэш-память программ ATmega128 содержит 128 кбайт
внутренней внутрисистемно перепрограммируемой флэш-памяти для хранения программы.
Поскольку все AVR-инструкции являются 16 или 32-разр., то флэш-память организована как 64
кбайт х 16. Для программной защиты флэш-память программ разделена на два сектора: сектор
программы начальной загрузки и сектор прикладной программы.

Регистр RAMPZ обычно используется для указания той страницы ОЗУ размером 64 кбайт, к
которой выполняется доступ через Z-указатель. Т.к. ATmega128 не поддерживает память на
статическом ОЗУ размером свыше 64 кбайт, то данный регистр используется только для выбора
страницы памяти программ, доступ к которой осуществляется с помощью инструкций ELPM/SPM.
Различные установки бита RAMPZ0 имеют следующий результат:
RAMPZ0 =0:
Инструкции ELPM/SPM осуществляют доступ к памяти программ в диапазоне адресов
$0000 - $7FFF (младшие 64 кбайт)
RAMPZ0 =1:
Инструкции ELPM/SPM выполняют доступ к памяти программ в диапазоне адресов
$8000 - $FFFF (старшие 64 кбайт)
Обратите внимание, что действие инструкции LPM не зависит от установки RAMPZ.


Получается программно нужно как-то расширять возможности записи программ больше 64к
или все приехали: на данном микроконтроллере дальше не уедешь?

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

Чт авг 17, 2017 16:08:49

А каким методом прошивка происходит? Беглый взгляд на даташит на предмет RAMPZ говорит, что это вроде как критично лишь при самопрограммировании (через загрузчик).

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

Пт авг 18, 2017 08:47:03

WinAVR, а далее запись через SinaProg

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

Пт авг 18, 2017 09:01:34

Пользуйтесь avrdude - в комплекте WinAVR есть, и в типовом шаблоне makefile тоже есть вызов. Не шиться может только по вине программатора, ядро МК тут совсем не при чем, и объем прошивки тоже не при чем.

Структуры в PROGMEM

Вс окт 08, 2017 12:27:54

Что-то мне странного захотелось - положить в PROGMEM массив структур. Или что-то еще в том же духе.

Конкретно - список станций для приемника на RDA5807 (WiseLord, похоже, модификация Вашего творения, но с экраном от Нокии 5110). То есть в в программной флеши должно лежать слово с частотой, за ним - строка текста (допустим, 16 байт) с названием станции, и так 10 и более раз.

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

Беглый поиск в Нете ничего хорошего не принес... :(

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

Вс окт 08, 2017 12:39:43

Не совсем понял, как Вы собираетесь корректировать станции, находящиеся в PROGMEM?

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

Вс окт 08, 2017 18:26:05

Как-как? Студией, вестимо. Просто в той программуле, которую я нашел, при изменении списка станций, править надо в пяти местах: во-первых, в блоке #define с частотами надо сделать два исправления - исправить define-имя для частоты станции и собственно саму частоту, затем два раза в блоке if'ов - define-имя этой станции и текст с ее названием, и, наконец, надо исправить "магическую" константу "15" в конце, на завороте таблицы станций. Я сам, пока вносил список своих станций, пару-тройку раз ошибся. А хотелось что-нибудь, вроде:
Код:
// Начало списка станций
RadioDef(10050," Тенгри FM ");
RadioDef(10120,"Радио Текс ");
        ....
RadioDef(10770,"  Дала FM  ");
// Конец списка станций
Впрочем, конечно, никто не мешает положить частоту в текстовом виде в начало каждой из строк с названием станций, фиксированным количеством цифр, а потом преобразовать его программно. Так, вероятно, и сделаю...

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

Пн окт 09, 2017 07:03:29

Насколько я знаю, WinAVR не позволяет макросом определять строковую константу и одновременно делать ссылку на неё в массиве. Для массива станций в ОЗУ проблем нет, макросы элементарны, для flash - заметно хуже.

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

Пн окт 09, 2017 15:49:23

Доброго времени суток.
Требуется помощь по оптимизации быстродействия кода, так скажем идея.
Компилятор CVAVR.

Самый быстрый получается вот такой
Спойлер
Код:
#define PORT_VID   PORTD
#define   DDR_VID      DDRD
#define   VID_PIN      7

char *u;

#define COLUMN(r) transver(font[r][fontline]);            // 5.6875us
void transver ( char a) {           
   //Для 8-и бит.        //5.6875us
     
        if (a & 0b00000001) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b00000010) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b00000100) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b00001000) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b00010000) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b00100000) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b01000000) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}
        if (a & 0b10000000) { PORT_VID.VID_PIN = 1;} else { PORT_VID.VID_PIN = 0;}         
}
}

Вызов через указатель
      COLUMN(*u++);
      COLUMN(*u++);
Пробовал такие
Спойлер
Код:
//#define COLUMN(r) transver_3(font[r][fontline]);          // 11.187us
//#define COLUMN(r) transver_2(&reg1,font[r][fontline]);    // 26.562us
//#define COLUMN(r) transver_4(font[r][fontline]);          // 41.125us
//#define COLUMN(r) transver_5(font[r][fontline]);          // 10.938us
//#define COLUMN(r) transver_6(font[r][fontline]);          // 6.1875us

void transver_3 ( char a) {           
   //Для 8-и бит.     // 11.187us
   char i;   
   for(i=0; i<8; i++)
   {
      if(a & 1)   //выводим данные
         PORT_VID.VID_PIN = 1;
      else
         PORT_VID.VID_PIN = 0;
      a >>= 1;
   }         
}


typedef struct ShiftReg_t
{
   char *port;
   char data_pin;

}ShiftReg;

ShiftReg reg1 = {&PORT_VID, 1<<VID_PIN};

void transver_2 (ShiftReg *reg, char value) {           
   char i;         // 26.562us
   for(i=0; i<8; i++)
   {
      if(value & 1)   //выводим данные
         *reg->port |= reg->data_pin;
      else
         *reg->port &= ~reg->data_pin;
      value >>= 1;
   }         
}


void transver_4 ( char a) {           
   //Для 8-и бит.   // 41.125us
   char i=0;
   do
   {
        PORT_VID.VID_PIN = ((a & (1 << i)) >> i)&0x01; //побитно на PB7
        i++;   
      
   } while (i<8);       
}

void transver_5 ( char a) {           
   //Для 8-и бит.  // 10.938us
   char i=0; 
   do
   {
        PORT_VID.VID_PIN = a & 0x01; //побитно на PB7   
      a >>= 1;
        i++;   
      
   } while (i<8);       
}

void transver_6 ( char a) {           
   //Для 8-и бит.        //6.1875us
       
        PORT_VID.VID_PIN = a & 0x01; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b00000010; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b00000100; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b00001000; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b00010000; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b00100000; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b01000000; //побитно на PB7
        PORT_VID.VID_PIN = a & 0b10000000; //побитно на PB7       
}
Все коды рабочие, проверено правда в симуляторе протеус.
Время измерено протеусом между двумя вызовами COLUMN().

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

Пн окт 09, 2017 16:37:51

Код какой то странный.
При любом установленном бите в переменной "a" (т.б. "a" имеет какое либо значение), "PORT_VID.VID_PIN" присваивается единица. Иначе - ноль.
Зачем тогда куча условий ? :roll:

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

Пн окт 09, 2017 17:01:04

Видимо, идея - подёргать ножкой, пробежавшись по всем битам. Правда, насколько это может быть нужно без синхроимпульсов - непонятно.

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

Пн окт 09, 2017 17:01:46

При любом установленном бите в переменной "a" (т.б. "a" имеет какое либо значение), "PORT_VID.VID_PIN" присваивается единица. Иначе - ноль.
Зачем тогда куча условий ? :roll:


Не. На ножку порта выдвигается байт младшим битом вперед.
Dimon456, это видеосигнал чтоли? Я так понимаю, биты должны быть одинаковой длительности?

А) Приведи ассемблер transver ()
Если тебе важно быстродействие данного кода, можно его на ассемблере переписать
Б) если флеша много свободного, можно и 256 функций (для каждого байта своя функция), тогда ветвлений при выдаче байта не будет
В) Если есть возможность использовать ножку MOSI, то можно выдавать байт в SPI, а SPI контроллер сам сдвинет байт
...

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

Пн окт 09, 2017 17:23:17

Да, это видеосигнал.
Изначально так и было, через MOSI.
Спойлер
Код:
#define COLUMN(r) SPDR=font[r][fontline];                 //1.5625us  SPSR = (1<<SPI2X);
Просто может есть еще какое-то решение, не использовать MOSI.
Ассемблер
СпойлерИзображение

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

Пн окт 09, 2017 17:28:41

Ваш код в функции transver равносилен строке :
Код:
PORT_VID.VID_PIN = a!=0;    // Или PORT_VID.VID_PIN = a;
:)
Ответить