Перейти к содержанию

Как подружить две ATMega8?


DimonRX

Рекомендуемые сообщения

1 час назад, DimonRX сказал:

Т.е. в примере читается максимум 32 байта?

 

1 час назад, DimonRX сказал:

data_buff_spi[y]=data;

...

if(++y>33){ y=0; }

В примере читается 34 байта почему то:

{[0], ... [33] } = 34 штуки

Только когда у=33 , data будет сохранен в 33-й элемент массива, и только после этого у станет = 0!!!

Наверно автор ошибся со знаком, и с остальным соответственно, так должно быть:

if(!(++y<32)){ y=0; }

Изменено пользователем ruhi
допись :)

Можно сделать все! Но чем больше можно, тем больше нельзя!

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

2 минуты назад, ruhi сказал:

В примере читается 34 байта почему то:

Все правильно тут.  Но тут не все еще. Этот код для защиты выхода за пределы объявленного массива. 

А у меня на самом деле 32 байта принимается. Я еще не показывал обработчик сброса указателя. Не стал загромождать пример. 

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

3 минуты назад, artos5 сказал:

Все правильно тут

Ну как же правильно если пишется за пределы выделенного массива???

Человеку и так от С-ей голову сносит, а вы дополнительно его путаете.

Можно сделать все! Но чем больше можно, тем больше нельзя!

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

11 минуту назад, ruhi сказал:

Ну как же правильно если пишется за пределы выделенного массива???

А с чего Вы взяли?? 

Выделенный массив у меня 34 байта. 

Но пишу в него только 32.

 

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

В 03.07.2018 в 14:54, artos5 сказал:

Выделенный массив у меня 34 байта. 

Но пишу в него только 32.

О как! Вот ведь до чего техника дошла!

Можно сделать все! Но чем больше можно, тем больше нельзя!

Ссылка на комментарий
Поделиться на другие сайты

  • 2 месяца спустя...

Так у меня ничего и не получилось.

Купил логический анализатор. Подключил. Он все читает как надо. Что передаю, то и читает. А вот у меня не получается читать.

Опишу свои действия, может кто-то подскажет, где я делаю не так.

Значит для тестов собрал модель и написал программку,  эмулирующую анимацию. В сдвиговый регистр данные передаю следующим образом:

1) Поднимаем и держим RESET в 1
2) Выдаем первый (старший) бит на Data.
3) Опускаем в 0 и поднимаем в 1 тактовый выход. На восходящем фронте происходит занос в регистр и сдвиг всей цепочки на один шаг.
Код, который это делает:

procedure HC164_write(Out_data : byte);
var
 i, Dat : byte;
begin
 for i := 0 to 7 do
  begin
   Dat := (Out_data  shl i) and %10000000;
   PORTC0_bit := Dat.B7;
   
   PORTC1_bit := 0;
   PORTC1_bit := 1;
  end;
end;

В основной программе разрешил прерывание int1 по изменению уровня

GICR := %11000000; 
MCUCR := %00000100; 
SREG_I_bit := 1; 

И пробую читать данные со сдвигового регистра (нога PD3 подключена к CLK, PD1 подключена к линии данных) в массив из 127 элементов для дальнейшего анализа.

procedure ReadData(); iv IVT_ADDR_INT1; ics ICS_AUTO;
var
 rd_bit, rd_data : byte;
 Data_SPI_buf : array[127] of byte; volatile;
begin
 if (PIND3_bit = 1) and (yy <= 127) then
  begin
   rd_data := rd_data shl 1;
   if (PIND1_bit = 1) then
    rd_data := rd_data or 0x01
   else
    rd_data := rd_data or 0x00;
   inc(rd_bit);
   if (rd_bit > 7) then
    begin
     rd_bit := 0;
     Data_SPI_buf[yy] := rd_data;
     inc(yy);
     rd_data := 0;
    end;
  end;
end;

И ничего не читается из того, что передаю. Может подскажете, что я делаю не так?

Если это поможет, то могу выложить те данные, что читает логический анализатор.

IMG_2906.JPG

Ссылка на комментарий
Поделиться на другие сайты

Для начала вставьте задержки при передаче в регистр. Регистр может и работает, а Атмега не успеет поймать такие короткие импульсы.

PORTC1_bit := 0;

// задержка 1 мс

PORTC1_bit := 1;

// задержка 1 мс

При приеме надо ещё анализировать на какой разряд приходят данные. Ножки РС2 и РС3.

Ссылка на комментарий
Поделиться на другие сайты

1 час назад, snn_krs сказал:

Для начала вставьте задержки при передаче в регистр. Регистр может и работает, а Атмега не успеет поймать такие короткие импульсы.

PORTC1_bit := 0;

// задержка 1 мс

PORTC1_bit := 1;

// задержка 1 мс

Задержки я могу вставить, а как быть с промышленным решением? У меня же только модель для отладки, к реальной программе, которая делает то же самое, у меня доступа нет.

1 час назад, snn_krs сказал:

При приеме надо ещё анализировать на какой разряд приходят данные. Ножки РС2 и РС3.

А это зачем? Я же данные с другой стороны читаю. Ну приходит на первый разряд код 140, я знаю, что это буква "Р" и просто игнорирую эти байты. Меня больше интересуют сегменты, а именно коды 254, 253, 251, 247, 239, 223. А их прочитать не получается. А вот логический анализатор их читает:

Time [s]	 Analyzer Name	 Decoded Protocol Result
0.000000000000000	SPI	MISO: 140
0.010413000000000	SPI	MISO: 247
0.020802000000000	SPI	MISO: 140
0.031215000000000	SPI	MISO: 247
0.041603000000000	SPI	MISO: 140
0.052017000000000	SPI	MISO: 247
0.062408000000000	SPI	MISO: 140
0.072822000000000	SPI	MISO: 247
0.083219000000000	SPI	MISO: 140
0.093631000000000	SPI	MISO: 251
0.104020000000000	SPI	MISO: 140
0.114433000000000	SPI	MISO: 251
0.124824000000000	SPI	MISO: 140
0.135237000000000	SPI	MISO: 251
0.145626000000000	SPI	MISO: 140
0.156039000000000	SPI	MISO: 251
0.166429000000000	SPI	MISO: 140
0.176842000000000	SPI	MISO: 251
0.187232000000000	SPI	MISO: 140
0.197644000000000	SPI	MISO: 251
0.208034000000000	SPI	MISO: 140
0.218446000000000	SPI	MISO: 251
0.228835000000000	SPI	MISO: 140
0.239248000000000	SPI	MISO: 251
0.249638000000000	SPI	MISO: 140
0.260051000000000	SPI	MISO: 251
0.270439000000000	SPI	MISO: 140
0.280852000000000	SPI	MISO: 251
0.291241000000000	SPI	MISO: 140

 

Ссылка на комментарий
Поделиться на другие сайты

21 minutes ago, DimonRX said:

Задержки я могу вставить, а как быть с промышленным решением?

В устройстве можете анализатором посмотреть время обновления, думаю больше 1 мс. У вас импульс очень короткий, анализатор его поймает, а Атмега нет.

40 minutes ago, DimonRX said:

А это зачем? Я же данные с другой стороны читаю.

Если анализировать РС2 и РС3, то вы точно знаете первый или второй индикатор вы анализируете. Если анализировать как вы, то надо проверять все возможные символы.

Ссылка на комментарий
Поделиться на другие сайты

@snn_krs , спасибо, кто бы мог подумать!

Да, правильно говорят: "Век живи-век учись, а все равно дураком помрёшь." Вставил задержки по 1 мс и все стало читаться! А я месяц голову ломал, почему не работает? Вроде все просто и логично, а не работало. Теперь надо на железе попробовать, будет читаться или нет.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Сообщения

    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
    • Ну тогда дорога к сименсу в гости - они вам какой-нибудь Desigo CC или даже Siematic предложат, тыщ за 10 долларов. Ну и ещё тыщ 5 надо будет отдать за контроллеры и их конфигурирование.   А если попроще - то можно к отечественным MasterSCADA обратиться, либо к WiredBoard - у них не совсем SCADA система, но нормальные контроллеры, довольно просто настраиваются и можно графическую оболочку рисовать.
    • тогда вы имеете то, что имеете, и никак от этого не избавиться. Хоть святой водой окропите. "Или трусы или крестик" (с) Нагрузки у вас немаленькие. Вы же с нуля переделываете, снова некуда ? Понятие LowESR очень неконкретное. Сколько вешать в граммах ? пустая трата времени
    • Да все это туфта, выеденного яйца не стоит. В общем чушь собачья. На мониторе тему уже сплавили в мусорку, а здесь треп еще будет на 10 страницах. Все камеры, их у него было три, исправные. Записывают отлично. А дальше вся проблема в этом. Особо интересно - монтажник видео.
    • 1. А это как определяется?  Так пробовали на другом смотреть? 2. Так как всё-таки смотрели - напрямую с камеры или "Копирование файлов на компьютер ничего не меняет по сравнению с просмотром с камеры напрямую"?
  • Похожий контент

×
×
  • Создать...