linux arm-tiny-6410實現串列埠通訊
阿新 • • 發佈:2019-01-10
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <errno.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <termios.h>
#include <stdlib.h>
#include "serial.h"
int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop) //fd檔案描述符,nSpeed要設定的波特率,nBits停止位(要傳送的位數),nEvent奇偶校驗位,nStop停止位
{
struct termios newtio,oldtio;
if ( tcgetattr( fd,&oldtio) != 0) { //tcgetattr函式用於獲取與終端相關的引數。儲存測試現有串列埠引數設定,在這裡如果串列埠號出錯,會有相關的出錯資訊不懂的函式可自行百度百科,哪裡有詳細的說明
perror("SetupSerial 1");
return -1;
}
bzero( &newtio, sizeof( newtio ) ); //清0
newtio.c_cflag |= CLOCAL | CREAD; //通過位掩碼的方式啟用本地連線和接受使能選項
newtio.c_cflag &= ~CSIZE; //看不懂沒關係,知道有這回事就行
switch( nBits ) //設定停止位
{
case 7:
newtio.c_cflag |= CS7;
break;
case 8:
newtio.c_cflag |= CS8;
break;
}
switch( nEvent ) //設定奇偶效驗位
{
case 'O': //奇數
newtio.c_cflag |= PARENB; //啟動校驗
newtio.c_cflag |= PARODD; //啟動奇校驗
newtio.c_iflag |= (INPCK | ISTRIP); //INPCK啟用輸入奇偶檢測。ISTRIP去掉第八位
break;
case 'E': //偶數
newtio.c_iflag |= (INPCK | ISTRIP);
newtio.c_cflag |= PARENB;
newtio.c_cflag &= ~PARODD; //啟動偶校驗
break;
case 'N':
newtio.c_cflag &= ~PARENB; //不啟動校驗
break;
}
switch( nSpeed ) //設定資料傳輸率
{
case 2400:
cfsetispeed(&newtio, B2400);
cfsetospeed(&newtio, B2400);
break;
case 4800:
cfsetispeed(&newtio, B4800);
cfsetospeed(&newtio, B4800);
break;
case 9600:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
case 115200:
cfsetispeed(&newtio, B115200);
cfsetospeed(&newtio, B115200);
break;
case 460800:
cfsetispeed(&newtio, B460800);
cfsetospeed(&newtio, B460800);
break;
default:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
}
if( nStop == 1 )
newtio.c_cflag &= ~CSTOPB;
else if ( nStop == 2 )
newtio.c_cflag |= CSTOPB;
newtio.c_cc[VTIME] = 0; //設定等待時間和最少的接收字元
newtio.c_cc[VMIN] = 0;
tcflush(fd,TCIFLUSH); //處理未接收字元
if((tcsetattr(fd,TCSANOW,&newtio))!=0) //函式用於設定終端引數,TCSANOW:不等資料傳輸完畢就立即改變屬性。
{
perror("com set error");
return -1;
}
printf("set done!\n");
return 0;
}
#include <string.h>
#include <sys/types.h>
#include <errno.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <termios.h>
#include <stdlib.h>
#include "serial.h"
int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop) //fd檔案描述符,nSpeed要設定的波特率,nBits停止位(要傳送的位數),nEvent奇偶校驗位,nStop停止位
{
struct termios newtio,oldtio;
if ( tcgetattr( fd,&oldtio) != 0) { //tcgetattr函式用於獲取與終端相關的引數。儲存測試現有串列埠引數設定,在這裡如果串列埠號出錯,會有相關的出錯資訊不懂的函式可自行百度百科,哪裡有詳細的說明
perror("SetupSerial 1");
return -1;
}
bzero( &newtio, sizeof( newtio ) ); //清0
newtio.c_cflag |= CLOCAL | CREAD; //通過位掩碼的方式啟用本地連線和接受使能選項
newtio.c_cflag &= ~CSIZE; //看不懂沒關係,知道有這回事就行
switch( nBits ) //設定停止位
{
case 7:
newtio.c_cflag |= CS7;
break;
case 8:
newtio.c_cflag |= CS8;
break;
}
switch( nEvent ) //設定奇偶效驗位
{
case 'O': //奇數
newtio.c_cflag |= PARENB; //啟動校驗
newtio.c_cflag |= PARODD; //啟動奇校驗
newtio.c_iflag |= (INPCK | ISTRIP); //INPCK啟用輸入奇偶檢測。ISTRIP去掉第八位
break;
case 'E': //偶數
newtio.c_iflag |= (INPCK | ISTRIP);
newtio.c_cflag |= PARENB;
newtio.c_cflag &= ~PARODD; //啟動偶校驗
break;
case 'N':
newtio.c_cflag &= ~PARENB; //不啟動校驗
break;
}
switch( nSpeed ) //設定資料傳輸率
{
case 2400:
cfsetispeed(&newtio, B2400);
cfsetospeed(&newtio, B2400);
break;
case 4800:
cfsetispeed(&newtio, B4800);
cfsetospeed(&newtio, B4800);
break;
case 9600:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
case 115200:
cfsetispeed(&newtio, B115200);
cfsetospeed(&newtio, B115200);
break;
case 460800:
cfsetispeed(&newtio, B460800);
cfsetospeed(&newtio, B460800);
break;
default:
cfsetispeed(&newtio, B9600);
cfsetospeed(&newtio, B9600);
break;
}
if( nStop == 1 )
newtio.c_cflag &= ~CSTOPB;
else if ( nStop == 2 )
newtio.c_cflag |= CSTOPB;
newtio.c_cc[VTIME] = 0; //設定等待時間和最少的接收字元
newtio.c_cc[VMIN] = 0;
tcflush(fd,TCIFLUSH); //處理未接收字元
if((tcsetattr(fd,TCSANOW,&newtio))!=0) //函式用於設定終端引數,TCSANOW:不等資料傳輸完畢就立即改變屬性。
{
perror("com set error");
return -1;
}
printf("set done!\n");
return 0;
}