#include #include #include #include #include "timer.h" #include "circular_buf.h" #define F_CPU 16000000 #define SIZE_BUF 16 volatile unsigned char usartTxBuf[SIZE_BUF]; volatile unsigned char txBufTail = 0; volatile unsigned char txBufHead = 0; volatile unsigned char txCount = 0; volatile unsigned char usartRxBuf[SIZE_BUF]; volatile unsigned char rxBufTail = 0; volatile unsigned char rxBufHead = 0; volatile unsigned char rxCount = 0; void UARTInit(void) { UCSR0B = (1 << RXEN0) | (1 << TXEN0) | (1 << RXCIE0) | (1 << TXCIE0); UCSR0C = (1 << UCSZ01) | (1 << UCSZ00); UBRR0H = 0; UBRR0L = 103; } void UARTSend(uint8_t* data, size_t length) { for (size_t i = 0; i < length; i++) { // Ждём опустошения буфера передачи (читаем флаг). while (!(UCSR0A & (1 << UDRE0))); UDR0 = data[i];// Записываем в регистр значение переменной "data" для передачи. } } //положить символ в буфер void USART_PutChar(unsigned char sym) { if (((UCSR0A & (1 << UDRE0)) != 0) && (txCount == 0)) { UDR0 = sym; } else { if (txCount < SIZE_BUF) { usartTxBuf[txBufTail] = sym; txCount++; txBufTail++; if (txBufTail == SIZE_BUF) { txBufTail = 0; } } } } //взять символ из буфера unsigned char GetChar(void) { unsigned char sym = 0; if (txCount > 0) { sym = usartTxBuf[txBufHead]; txCount--; txBufHead++; if (txBufHead == SIZE_BUF) { txBufHead = 0; } } return sym; } //функция загрузки строк void USART_SendStr(const unsigned char* data) { while (*data) { USART_PutChar(*data++); } } //получаем данные из буфера void UARTReceive(uint8_t* data) { uint32_t timeout_ms_mb = 100;//timeout 100ms, в нашем случае, иногда по 1 сек, и даже по 4-5 с, если байт повредился и идет около 1-2секунд, то штора может сломаться uint32_t timeout_ms = 4; uint32_t start_time = millis();//запоминаем время начала ожидания while (rxCount == 0) { //ожидание наличия данных в буфере приёма if ((millis() - start_time) > timeout_ms_mb) { //если время ожидания истекло return 0; //выходим из цикла } } data[0] = usartRxBuf[rxBufHead];//считывание байта из буфера rxCount--; rxBufHead++; if (rxBufHead == SIZE_BUF) { rxBufHead = 0; } start_time = millis();//обнуляем таймаут, так как данные начали приходить while (rxCount > 0) { //ожидание окончания приёма данных if ((millis() - start_time) > timeout_ms) { //если время ожидания истекло break; //выходим из цикла ожидания } } } int main(void) { sei(); UARTInit(); timerInit(); DDRD = 0xFF; uint8_t buff[] = {0x48, 0x45, 0x4C, 0x4C, 0x4F, 0x21, 0x09}; UARTSend(buff, sizeof(buff)); //for (int i = 0; i < 7; i++) { //UARTSend(buff, sizeof(buff)); //} uint8_t receivedData[SIZE_BUF]; UARTReceive(receivedData); UARTSend(receivedData, sizeof(receivedData)); while (1) { //unsigned long currentTime = millis(); // Делайте что-то с текущим временем... } return 0; } ISR(USART_RX_vect) { if (rxCount < SIZE_BUF) { usartRxBuf[rxBufTail] = UDR0; rxBufTail++; if (rxBufTail == SIZE_BUF) { rxBufTail = 0; } rxCount++; } } ////обработчик прерывания по завершению передачи //ISR(USART_TXC_vect) { //if (txCount > 0){ //если буфер не пустой //UDR0 = usartTxBuf[txBufHead]; //записываем в UDR символ из буфера //txCount--; //уменьшаем счетчик символов //txBufHead++; //инкрементируем индекс головы буфера //if (txBufHead == SIZE_BUF) //txBufHead = 0; //} //else { //UCSR0B &= ~(0<