ARM技术william hill官网
直播中

demonguy

10年用户 18经验值
擅长:可编程逻辑
私信 关注
[问答]

一个基于TQ210的逻辑UART0的程序,只能发送数据而不能接受

我自己写了一段TQ210板子的串口0裸机驱动,但是不知道为什么,PC上可以接受到板子发过来的数据,但是怎么板子怎么都接受不到PC传过去的数据,请问是啥情况?我自己也试过,非常的确定他就是卡在 while (!(UTRSTAT0 & (1 << 2))); 直到现在都木有弄明白是怎么回事,调试了一天也没发现问题....


1.jpg



  1. #define GPC0CON                *((volatile unsigned int *)0xE0200060)
  2. #define GPC0DAT                *((volatile unsigned int *)0xE0200064)

  3. int main() __attribute__((section(".main")));

  4. int main()
  5. {
  6.         unsigned char c;
  7.         uart_init();
  8.        
  9.         GPC0CON &= ~(0xFF << 12);
  10.         GPC0CON |= 0x11 << 12;                // 配置GPC0_3和GPC0_4为输出
  11.         GPC0DAT |= (0x3 << 3);                // 熄灭LED1和LED2

  12.         puts("UART Test in S5PV210");
  13.         puts("1.LED1 Toggle");
  14.         puts("2.LED2 Toggle");
  15.         puts("Please select 1 or 2 to Toggle the LED");
  16.         // putchar('1');
  17.        
  18.         while (1)
  19.         {
  20.                 c = getchar();                        // 从串口终端获取一个字符
  21.                 putchar(c);                                // 回显
  22.                 putchar('r');

  23.                 if (c == '1')
  24.                         GPC0DAT ^= 1 << 3;        // 改变LED1的状态
  25.                 else if (c == '2')
  26.                         GPC0DAT ^= 1 << 4;        // 改变LED2的状态
  27.         }
  28.         return 0;
  29. }
  1. #define GPA0CON                *((volatile unsigned int *)0xE0200000)
  2. #define ULCON0                 *((volatile unsigned int *)0xE2900000)
  3. #define UCON0                 *((volatile unsigned int *)0xE2900004)
  4. #define UFCON0                 *((volatile unsigned int *)0xE2900008)
  5. #define UTRSTAT0         *((volatile unsigned int *)0xE2900010)
  6. #define UTXH0                  *((volatile unsigned int *)0xE2900020)
  7. #define URXH0                 *((volatile unsigned int *)0xE2900024)
  8. #define UBRDIV0         *((volatile unsigned int *)0xE2900028)
  9. #define UDIVSLOT0        *((volatile unsigned int *)0xE290002C)



  10. // #define GPA0CON                *((volatile unsigned int *)0xE0200000)
  11. // #define ULCON0                 *((volatile unsigned int *)0xE2900400)
  12. // #define UCON0                 *((volatile unsigned int *)0xE2900404)
  13. // #define UFCON0                 *((volatile unsigned int *)0xE2900408)
  14. // #define UTRSTAT0         *((volatile unsigned int *)0xE2900410)
  15. // #define UTXH0                  *((volatile unsigned int *)0xE2900420)
  16. // #define URXH0                 *((volatile unsigned int *)0xE2900424)
  17. // #define UBRDIV0         *((volatile unsigned int *)0xE2900428)
  18. // #define UDIVSLOT0        *((volatile unsigned int *)0xE290042C)


  19. /* UART0初始化 */
  20. void uart_init()
  21. {
  22.         /*
  23.         ** 配置GPA0_0为UART_0_RXD
  24.         ** 配置GPA0_1为UART_0_TXD
  25.         */
  26.         GPA0CON &= ~0xFF;
  27.         GPA0CON |= 0x22;

  28.         GPA0CON &= ~(0xFF<<16);
  29.         GPA0CON |= (0x22<<16);

  30.         /* 8-bits/One stop bit/No parity/Normal mode operation */
  31.         ULCON0 = 0x3;

  32.         /* Interrupt request or polling mode/Normal transmit/Normal operation/PCLK/*/
  33.         UCON0 = 0x5;//1 | (1 << 2) ;//| (1<<5);

  34.         /* 静止FIFO */
  35.         UFCON0 = 0;

  36.         /*
  37.         ** 波特率计算:115200bps
  38.         ** PCLK = 66MHz
  39.         ** DIV_VAL = (66000000/(115200 x 16))-1 = 35.8 - 1 = 34.8
  40.         ** UBRDIV0 = 34(DIV_VAL的整数部分)
  41.         ** (num of 1's in UDIVSLOTn)/16 = 0.8
  42.         ** (num of 1's in UDIVSLOTn) = 12
  43.         ** UDIVSLOT0 = 0xDDDD (查表)
  44.         */
  45.         UBRDIV0 = 34;
  46.         UDIVSLOT0 = 0xDDDD;
  47. }

  48. void putchar(unsigned char c);

  49. static void uart_send_byte(unsigned char byte)
  50. {
  51.         while (!(UTRSTAT0 & (1 << 2)));        /* 等待发送缓冲区为空 */
  52.         UTXH0 = byte;                                        /* 发送一字节数据 */               
  53. }

  54. static unsigned char uart_recv_byte()
  55. {
  56.         while (!(UTRSTAT0 & 1));                /* 等待接收缓冲区有数据可读 */
  57.         return URXH0;                                        /* 接收一字节数据 */               
  58. }

  59. void putchar(unsigned char c)
  60. {
  61.         uart_send_byte(c);
  62.         /* 如果只写'n',只是换行,而不会跳到下一行开头 */
  63.         if (c == 'n')
  64.                 uart_send_byte('r');
  65. }

  66. unsigned char getchar()
  67. {
  68.         unsigned char c;
  69.         c = uart_recv_byte();
  70.         return c;
  71. }

  72. void puts(char *str)
  73. {
  74.         char *p = str;
  75.         while (*p)
  76.                 putchar(*p++);
  77.         putchar('n');
  78. }





更多回帖

发帖
×
20
完善资料,
赚取积分