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

UART recive string


sbalymov

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

Привет, какой день бьюсь не как не могу принять и назад оправить строку по uart, по прерыванию, может уже есть готовые решения, подскажите.

Так мне нужно по превынию RX принять строку длинной 9 символов, потом разобью на 3 и сделаю их int ( и в дальнейшем запишу в EEPROM),

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

Как сделал на arduino:

void loop() {
  if (Serial.available() > 0){        // Смотрим если в буфере данные
    str = "";                         //Очищаем строку
     str = Serial.readStringUntil('/n');  //Читаем данные  
     s_red = str.substring(0,3);    //берем первый байт
     s_green = str.substring(3,6);  //берем 2 байт
     s_blue = str.substring(6,9);   //берем  3 байт
     b_red = s_red.toInt();    // преобразуем в str в Int
     b_green = s_green.toInt();  
     b_blue = s_blue.toInt();    
     Serial.println(b_red);     
     Serial.println(b_green);  
     Serial.println(b_blue);  
     analogWrite(red, b_red);
     analogWrite(green, b_green);
     analogWrite(blue, b_blue);
     delay(400);
   }
}

 

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

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

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

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

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

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

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

Atmega88 atmel studio.

Как принят сроку по прерыванию не могу понять.



 ISR(USART_RX_vect) //привем по прерыванию
 {  
 data  = UDR0;

}




void UART_Send_Str(char str[])   //отправка строки
{
	unsigned char i = 0;

	while (str[i]!='\0')
	{
		USART_transmit(str[i]);
		i++;
	}

 

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

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

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

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

Не силен в АВР, но принцип должен быть как я вижу такой. Надо сделать массив размером со строку которую хотите принять, и в прерывании делать что то типа 

interrupt(){
uint8_t count = 0;
    data[count] = UDR;
    count++;
}

Где interrupt() это обработчик прерывания.

Гуру придут поправят, долго сидеть в прерываниях не хорошо. Ошибочка, переменную coount и определение массива  надо вынести за функцию, иначе она будет каждый раз обнуляться при заходе в прерывание. После обработки массива переменную следует обнулять.

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

6 минут назад, elki сказал:

Не силен в АВР, но принцип должен быть как я вижу такой. Надо сделать массив размером со строку которую хотите принять, и в прерывании делать что то типа 

interrupt(){
uint8_t count = 0;
    data[count] = UDR;
    count++;
}

Где interrupt() это обработчик прерывания.

Гуру придут поправят, долго сидеть в прерываниях не хорошо.

я делал так))) но не получилось.

ISR(USART_RX_vect)
{  
  uint8_t i = 0;
  input[i] = UDR0;
  i++;
  if (i > 2) EEPROM_write_string(0, input);
}





int main(void){
	USART_Init(103);// speed 9600
	sei();

	while (1) {
 
 
 

	}
}

 

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

Вот так это делает Wizard CVAVR

Скрытый текст

 

#include <mega88.h>

// Declare your global variables here

#define DATA_REGISTER_EMPTY (1<<UDRE0)
#define RX_COMPLETE (1<<RXC0)
#define FRAMING_ERROR (1<<FE0)
#define PARITY_ERROR (1<<UPE0)
#define DATA_OVERRUN (1<<DOR0)

// USART Receiver buffer
#define RX_BUFFER_SIZE0 9
char rx_buffer0[RX_BUFFER_SIZE0];

#if RX_BUFFER_SIZE0 <= 256
unsigned char rx_wr_index0=0,rx_rd_index0=0;
#else
unsigned int rx_wr_index0=0,rx_rd_index0=0;
#endif

#if RX_BUFFER_SIZE0 < 256
unsigned char rx_counter0=0;
#else
unsigned int rx_counter0=0;
#endif

// This flag is set on USART Receiver buffer overflow
bit rx_buffer_overflow0;

// USART Receiver interrupt service routine
interrupt [USART_RXC] void usart_rx_isr(void)
{
char status,data;
status=UCSR0A;
data=UDR0;
if ((status & (FRAMING_ERROR | PARITY_ERROR | DATA_OVERRUN))==0)
   {
   rx_buffer0[rx_wr_index0++]=data;
#if RX_BUFFER_SIZE0 == 256
   // special case for receiver buffer size=256
   if (++rx_counter0 == 0) rx_buffer_overflow0=1;
#else
   if (rx_wr_index0 == RX_BUFFER_SIZE0) rx_wr_index0=0;
   if (++rx_counter0 == RX_BUFFER_SIZE0)
      {
      rx_counter0=0;
      rx_buffer_overflow0=1;
      }
#endif
   }
}

#ifndef _DEBUG_TERMINAL_IO_
// Get a character from the USART Receiver buffer
#define _ALTERNATE_GETCHAR_
#pragma used+
char getchar(void)
{
char data;
while (rx_counter0==0);
data=rx_buffer0[rx_rd_index0++];
#if RX_BUFFER_SIZE0 != 256
if (rx_rd_index0 == RX_BUFFER_SIZE0) rx_rd_index0=0;
#endif
#asm("cli")
--rx_counter0;
#asm("sei")
return data;
}
#pragma used-
#endif

....................

// USART initialization
// Communication Parameters: 8 Data, 1 Stop, No Parity
// USART Receiver: On
// USART Transmitter: Off
// USART0 Mode: Asynchronous
// USART Baud Rate: 19200
UCSR0A=(0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
UCSR0B=(1<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (1<<RXEN0) | (0<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80);
UCSR0C=(0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0);
UBRR0H=0x00;
UBRR0L=0x26;

 

 

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

ДАк у вас тут i=0; ВСЕГДА!!!

вот так хотя бы надо:

В 09.02.2019 в 17:10, sbalymov сказал:

volatile int8_t i = 0; 
ISR(USART_RX_vect) 
{ 
input[i] = UDR0; 
i++; 
if (i > 2)
{
	EEPROM_write_string(0, input); 
	i = 0;
}
}

 

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

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

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

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

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

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

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

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

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

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

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

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