1、添加在app_cmd.c中最后添加。
int cmd_send(int argc, char * *argv)
{
if (argc == 1)
{
rt_kprintf("usage: send <BP01_XX> \n");
}
else
{
uint8_t len;
char in_buf[128], out_buf[128];
rt_strncpy(in_buf, argv[1], 128);
len = Cmd_process_str(in_buf, out_buf);
if (len < 128)
{
out_buf[len] = 0;
rt_kprintf("%s\n", out_buf);
}
memset(&in_buf, 0, sizeof(in_buf));
}
return 0;
}
#if defined(FINSH_USING_MSH) && defined(RT_USING_FINSH)
#include <finsh.h>
FINSH_FUNCTION_EXPORT_ALIAS(cmd_send, __cmd_send, cmd for BP.);
#endif
2、在drv_uart.c打开
void UART0_IRQHandler(void)
{
volatile uint32_t IIR, tmp;
/* enter interrupt */
rt_interrupt_enter();
IIR = LPC_UART0->IIR;
IIR &= 0x0e;
switch (IIR)
{
case 0x04:
case 0x0C:
#if RTTHREAD_VERSION < 20000
rt_hw_serial_isr(&serial0);
#else
rt_hw_serial_isr(&serial0, RT_SERIAL_EVENT_RX_IND);
#endif
break;
case 0x06:
tmp = LPC_UART0->LSR;
break;
default :
tmp = LPC_UART0->LSR;
break;
}
/* leave interrupt */
rt_interrupt_leave();
}
#endif
将以下代码屏蔽
void UART0_IRQHandler (void)
{
uint8_t IIR;
while(((IIR = LPC_UART0->IIR) & 0x01) == 0)
{ /* 有中断未处理完 */
switch (IIR & 0x0e)
{
case 0x04: /* 接收数据可用 */
case 0x0c: /* 字符超时指示 */
//如果串口一直在发数据,开机后等串口初始化完成再发出信号量
rt_sem_release(&uart0_sem);/* 通知接收任务 */
LPC_UART0->IER = LPC_UART0->IER & (~0x01); /* 禁止接收及字符超时中断 */
break;
default :
// temp = LPC_UART0->LSR;
break;
}
}
}