ядре linux на Allwinner a40i.
Проблема была в том, что пин rts не возвращался в исходное положение, после отправки данных в порт и порт переставал отвечать и функционировать до перезагрузки.
После перерыва вернулся к проблеме и вот что накопал.
В модуле драйвера uart порта linux/drivers/tty/serial/8250/8250_port.c есть кусок кода, который обрабатывает прерывания от порта.
int serial8250_handle_irq(struct uart_port *port, unsigned int iir)
{
struct uart_8250_port *up = up_to_u8250p(port);
struct tty_port *tport = &port->state->port;
bool skip_rx = false;
unsigned long flags;
u16 status;
if (iir & UART_IIR_NO_INT)
return 0;
spin_lock_irqsave(&port->lock, flags);
status = serial_lsr_in(up);
Проблемы оказались в нем, если в начале кода, до вызова функции spin_lock_irqsave(&port->lock, flags);, поставить вывод в консоль отладочного сообщения dev_err(port->dev, "Hello \n");, то все начинает работать.
Если поставить после spin_lock_irqsave(&port->lock, flags); вывод отладочного сообщения, то виснет загрузка ядра.
В прерывании порт уходит в бесконечный spinlock и все.
Как решить такую проблему ? Не спамить же в консоль?!
Какая версия ядра? В репо самих allwinner нет патча/дискуссии?
Обсуждают сегодня