PySerial和微控制器

时间:2012-06-09 21:28:22

标签: python microcontroller pic pyserial uart

我正在尝试通过UART与pySerial通信。 我使用Arduino USB2Serial Light Converter将数据从PC发送到PIC33F。 由于Arduino转换器,我无法使用CTS或RTS。

我设法将数据发送到MCU并从中接收数据。但问题是 数据并不总是它应该是什么。

例如,我想将整个字符串从MCU发送到终端,但我得到的不是MCU程序代码中给出的字符串。另一个问题是 没有人物之间的比较工作。这意味着我将一个字符发送给MCU,MCU将其与一个字符进行比较以做出决定。

现在好了一些代码:

1。将字符串从PIC33F发送到PC并使用pySerial

读取
putsU1("string");

// print a string

    int putsU1(char *s) {
     while(*s)
        putU1(*s++); 
    }

// print a character

    int putU1(int c) {
      while (_UTXBF);
        U1TXREG = c;
      return c; 
    }

如果我通过pySerial阅读此代码,我得到的结果如下:

In [13]: ser = serial.Serial('/dev/ttyACM0', 9600, bytesize=7, xonxoff=0)

In [14]: while True:                                                     
            print(struct.unpack('s', ser.read()))
         ....:     
('\x7f',)
('c',)
('\x11',)
('\t',)
('e',)
('y',)
('=',)
('\x7f',)

2。使用pySerial将数据发送到PIC33F并将其回送

这个只适用于单个字符而不适用于字符串。回显的字符也会在uppcase和小写之间随机切换。

     getsnU1(s, BUF_SIZE);

     char *getsnU1(char *s, int len) {
        char *p = s;
        int cc = 0;
        do {
           *s = getU1();
           putU1(*s);

           if ((*s == 0x8) && (s > p)) {
              putU1(' ');
              putU1(0x8);
              len++;
              s--;
              continue;
           }

           if (*s == '\n')
              continue;

           if (*s == '\r')
              break;
           s++;
          len--;
       } while (len > 1);

      *s = '\0';

      return p;
    }

UART配置:

#define FOSC            8000000
#define FCY             (FOSC/2)
#define BAUD            9600
#define U1BRGValue      (((FCY/BAUD)/16)-1)

void initUART1(void) {
/* general UART config */
RPINR18bits.U1RXR = U1RXPIN;            // set RP5 as UART1 RX
_RP6R = 0b00011;                        // set RP6 as UART Tx pin
U1RXPINTRIS = 1;                        // set RP5 (RB5) as input
U1MODEbits.PDSEL = DATAPARITY;           // set data bits and parity
U1MODEbits.STSEL = STOPBITS;            // set stop bits
U1MODEbits.ABAUD = 0;                   // auto-baud disabled
U1MODEbits.BRGH = 0;                    // low speed baud rate
U1BRG = U1BRGValue;                     // set baud value


/* enable interrupt on error */
IEC4bits.U1EIE = 1;                     // enable UART1 error interrupt
IPC16bits.U1EIP = 6;                     // set interrupt priority to 6

/* enable RX buffer interrupt */
IEC0bits.U1RXIE = 0;                    // enable UART1 RX interrupt
U1STAbits.URXISEL = 0b00;                // interrupt flag is set when buffer is 3/4 full
IPC2bits.U1RXIP = 6;                     // set interrupt priority to 6

/* enable TX interrupt */
IEC0bits.U1TXIE = 0;


/* enable UART1 module */
U1MODEbits.UEN = 0b00;
U1MODEbits.UARTEN = 1;
_UTXEN = 1;                             // enable UART Tx

}

我有点沮丧,因为我无法弄清问题所在。经过几个小时的测试和阅读,看起来如此简单,让它开始运行,但它不会在我的最后;(。 我试图用serial.write('text'.encode('ascii'))和{...}将数据写入PIC33F serial.write(struct.pack('s',('test')))都会产生相同的结果。

非常感谢任何帮助!

1 个答案:

答案 0 :(得分:1)

我认为你不想要bytesize = 7(除非你确切知道为什么)。

此外,UART的一个经典问题是单个字符有效,但整个字符串不起作用 - 这通常是在接收微控制器仅缓冲硬件中的单个字符时。我不知道PIC,但在上面的代码中,你执行getU1()后跟putU1()我猜putU1()等待一个字符的持续时间,所以当你稍后再次调用getU1()时你会错过一个字符(如果软件没有暂停发送它)。

我通常的解决方法是:

def write(s):
    for c in s:
        ser.write(c)
        time.sleep(0.001) # often not required

一般来说,pyserial似乎对我的所有项目都没问题,但你也应该检查一下普通的终端程序。除此之外,我只建议您仔细检查微控制器上的波特率和FOSC。