Я пытаюсь захватить входной номер через входной обработчик событий UART и распечатать его с некоторыми умножениями этого числа. Он печатает строку просто отлично, но после того, как она напечатана, программа больше не реагирует ни на какой ввод. Можно напечатать алфавит или отобразить сообщение об ошибке, но когда я использую функцию printf, терминал перестает реагировать на ввод, и курсор помещается на полпути к следующей строке.
Это код C:
#include "mss_uart.h"
#include <stdio.h>
#define RX_BUFF_SIZE 64
#define MSS_UART_57600_BAUD 57600
uint8_t g_rx_buff[RX_BUFF_SIZE];
uint8_t g_rx_idx;
void uart0_rx_handler( mss_uart_instance_t * this_uart )
{
MSS_UART_get_rx( &g_mss_uart0, &g_rx_buff[g_rx_idx], sizeof(g_rx_buff) );
if(g_rx_buff[g_rx_idx] > 96 && g_rx_buff[g_rx_idx] < 123)
{
uint8_t message[55] = "De letter was: x, de uppercase letter van : x is y.\n\r";
message[15] = g_rx_buff[g_rx_idx];
message[44] = g_rx_buff[g_rx_idx];
message[49] = g_rx_buff[g_rx_idx] - 32;
MSS_UART_polled_tx( &g_mss_uart0, message, sizeof(message) );
}
else if(g_rx_buff[g_rx_idx] > 64 && g_rx_buff[g_rx_idx] < 91)
{
uint8_t message[55] = "De letter was: x, de lowercase letter van : x is y.\n\r";
message[15] = g_rx_buff[g_rx_idx];
message[44] = g_rx_buff[g_rx_idx];
message[49] = g_rx_buff[g_rx_idx] + 32;
MSS_UART_polled_tx( &g_mss_uart0, message, sizeof(message) );
}
else if(g_rx_buff[g_rx_idx] > 47 && g_rx_buff[g_rx_idx] < 58)
{
int number = g_rx_buff[g_rx_idx] - '0';
int number2 = number * number;
int number3 = number2 * number;
int number4 = number3 * number;
printf("Getallenreeks: %d, %d, %d, %d.\n\r", number, number2, number3, number4);
}
else
{
uint8_t message[10] = "Error.\n\r";
MSS_UART_polled_tx( &g_mss_uart0, message, sizeof(message) );
}
}
int main(void)
{
MSS_UART_init
(
&g_mss_uart0,
MSS_UART_57600_BAUD,
MSS_UART_DATA_8_BITS | MSS_UART_NO_PARITY | MSS_UART_ONE_STOP_BIT
);
MSS_UART_set_rx_handler( &g_mss_uart0, uart0_rx_handler, MSS_UART_FIFO_SINGLE_BYTE );
while ( 1 )
{}
return(0);
}
void uart0_rx_handler является обработчиком прерываний, а MSS_UART_get_rx помещает входные данные в g_rx_buff[g_rx_idx].
Я попытался напечатать числа с помощью той же функции MSS_UART_polled_tx, которую я использую для символов, но безуспешно. Он печатает неправильные значения ascii:
if(g_rx_buff[g_rx_idx] > 47 && g_rx_buff[g_rx_idx] < 58)
{
int number = g_rx_buff[g_rx_idx] - '0';
int number2 = number * number;
int number3 = number2 * number;
int number4 = number3 * number;
uint8_t message[15] = "Getallenreeks: ";
uint8_t komma[2] = ", ";
uint8_t end[5] = ".\n\r";
char numberstring2[2];
char numberstring3[3];
char numberstring4[4];
sprintf(numberstring2, "%d", number2);
sprintf(numberstring3, "%d", number3);
sprintf(numberstring4, "%d", number4);
uint8_t messagenumber[1];
uint8_t messagenumber2[1];
uint8_t messagenumber3[1];
uint8_t messagenumber4[1];
messagenumber[0] = '0' + number;
messagenumber2[0] = '0' + number2;
messagenumber3[0] = '0' + number3;
messagenumber4[0] = '0' + number4;
http://imageshack.us/photo/my-images/843/testlan.jpg/( &g_mss_uart0, message, sizeof(message) );
MSS_UART_polled_tx( &g_mss_uart0, messagegetal, sizeof(messagenumber) );
MSS_UART_polled_tx( &g_mss_uart0, komma, sizeof(komma) );
MSS_UART_polled_tx( &g_mss_uart0, messagegetal2, sizeof(messagenumber2) );
MSS_UART_polled_tx( &g_mss_uart0, komma, sizeof(komma) );
MSS_UART_polled_tx( &g_mss_uart0, messagegetal3, sizeof(messagenumber3) );
MSS_UART_polled_tx( &g_mss_uart0, komma, sizeof(komma) );
MSS_UART_polled_tx( &g_mss_uart0, messagegetal4, sizeof(messagenumber4) );
MSS_UART_polled_tx( &g_mss_uart0, end, sizeof(end) );
}
Пример вывода кода: http://imageshack.us/photo/my-images/843/testlan.jpg/ Левый терминал показывает использование функции printf, правый терминал показывает использование функции MSS_UART_polled_tx для чисел (показана во втором блоке кода ).
'0'
и'9'
(и>=
и<=
) вместо47
и58
. - person pmg   schedule 21.03.2012isdigit()
для обнаружения цифр, а не жестко кодировать закодированные значения. Если у вас нетisdigit()
, воспользуйтесь советом @pmg. - person unwind   schedule 21.03.2012char message[] = "literal";
(в этом случае сообщение sizeof будет включать нулевой терминатор). Использование слишком большого размера (55), вероятно, приведет к выводу мусора. Вы действительно хотите вывести NUL? - person wildplasser   schedule 21.03.2012