LINUX下的串口测试的GCC程序

 

本程序的功能是测试EP9307的7个标准串口的接发。下LINUX下用ARM-LINUX-GCC编译。

程序调用LINUX的串口标准函数。CPU为EP9307.    晶振:14.7456M(200MHZ) 电平转换SP3243  .

在debug终端输入字符(长度在256之内)后回车,在选择的串口端显示字符的长度和字符。


#include     <stdio.h>      /*标准输入输出定义*/
//#include     <stdlib.h>     /*标准函数库定义*/
#include     <unistd.h>     /*Unix标准函数定义*/
#include     <sys/types.h>  /**/
#include     <sys/stat.h>   /**/
#include     <fcntl.h>      /*文件控制定义*/
#include     <termios.h>    /*PPSIX终端控制定义*/
#include     <errno.h>      /*错误号定义*/

/***@brief  设置串口通信速率
*@param  fd     类型 int  打开串口的文件句柄
*@param  speed  类型 int  串口速度
*@return  void*/

#define FALSE 1
#define TRUE 0

char *recchr="We received:/"";

int speed_arr[] = { B921600, B460800, B230400, B115200, B57600, B38400, B19200, B9600, B4800, B2400, B1200, B300, B38400, B19200, B9600, B4800, B2400, B1200, B300, };
int name_arr[] = {921600, 460800, 230400, 115200, 57600, 38400,  19200,  9600,  4800,  2400,  1200,  300, 38400,  19200,  9600, 4800, 2400, 1200,  300, };
void set_speed(int fd, int speed)
{
  int   i;
  int   status;
  struct termios   Opt;
  tcgetattr(fd, &Opt);
  for ( i= 0;  i < sizeof(speed_arr) / sizeof(int);  i++)
   {
    if  (speed == name_arr[i])
    {
        tcflush(fd, TCIOFLUSH);
     cfsetispeed(&Opt, speed_arr[i]);
     cfsetospeed(&Opt, speed_arr[i]);
     status = tcsetattr(fd, TCSANOW, &Opt);
     if  (status != 0)
            perror("tcsetattr fd1");
      return;
      }
   tcflush(fd,TCIOFLUSH);
   }
}
/**
*@brief   设置串口数据位,停止位和效验位
*@param  fd     类型  int  打开的串口文件句柄*
*@param  databits 类型  int 数据位   取值 为 7 或者8*
*@param  stopbits 类型  int 停止位   取值为 1 或者2*
*@param  parity  类型  int  效验类型 取值为N,E,O,,S
*/
int set_Parity(int fd,int databits,int stopbits,int parity)
{
 struct termios options;
 if  ( tcgetattr( fd,&options)  !=  0)
  {
   perror("SetupSerial 1");
   return(FALSE);
  }
  options.c_cflag &= ~CSIZE;
  switch (databits) /*设置数据位数*/
  {
   case 7:
    options.c_cflag |= CS7;
    break;
   case 8:
  options.c_cflag |= CS8;
  break;
 default:
  fprintf(stderr,"Unsupported data size/n");
  return (FALSE);
 }
  switch (parity)
   {
   case 'n':
 case 'N':
  options.c_cflag &= ~PARENB;   /* Clear parity enable */
  options.c_iflag &= ~INPCK;     /* Enable parity checking */
  break;
 case 'o':
 case 'O':
  options.c_cflag |= (PARODD | PARENB);  /* 设置为奇效验*/
  options.c_iflag |= INPCK;             /* Disnable parity checking */
  break;
 case 'e':
 case 'E':
  options.c_cflag |= PARENB;     /* Enable parity */
  options.c_cflag &= ~PARODD;   /* 转换为偶效验*/ 
  options.c_iflag |= INPCK;       /* Disnable parity checking */
  break;
 case 'S':
 case 's':  /*as no parity*/
  options.c_cflag &= ~PARENB;
  options.c_cflag &= ~CSTOPB;
  break;
 default:
  fprintf(stderr,"Unsupported parity/n");
  return (FALSE);
  }
  /* 设置停止位*/  
  switch (stopbits)
   {
   case 1:
    options.c_cflag &= ~CSTOPB;
  break;
 case 2:
  options.c_cflag |= CSTOPB;
  break;
 default:
  fprintf(stderr,"Unsupported stop bits/n");
  return (FALSE);
 }
  /* Set input parity option */
  if (parity != 'n')
    options.c_iflag |= INPCK;
    options.c_cc[VTIME] = 150; // 15 seconds
    options.c_cc[VMIN] = 0;

  tcflush(fd,TCIFLUSH); /* Update the options and do it NOW */
  if (tcsetattr(fd,TCSANOW,&options) != 0)
   {
    perror("SetupSerial 3");
  return (FALSE);
 }
  return (TRUE);
 }
/**
*@breif 打开串口
*/
int OpenDev(char *Dev)
{
int fd = open( Dev, O_RDWR );         //| O_NOCTTY | O_NDELAY
 if (-1 == fd)
  { /*设置数据位数*/
   perror("Can't Open Serial Port");
   return -1;
  }
 else
 return fd;

}
/**
*@breif  main()
*/
int main(int argc, char *argv[])
{
 int fd;
 int nread;
 char buff[512];
 char *dev ="/dev/ttyAM1";
 
 int device, c;
 printf("Select a port to test (0-6) /n");
AGAIN:
 if(scanf("%d", &device)!=EOF){
  while((c=getchar())!='/n' && c!=EOF){
   ;
  }
 }
 
 
 if(device==0){
  printf("ttyAM0 is selected /n");
  dev="/dev/ttyAM0";
 }
 else if(device==1){
  printf("ttyAM1 is selected /n");
  dev="/dev/ttyAM1";
 }
 else if(device==2){
  printf("ttyAM2 is selected /n");
  dev="/dev/ttyAM2";
 }
 else if(device==3){
  printf("ttyAM3 is selected /n");
  dev="/dev/ttyAM3";
 }
 else if(device==4){
  printf("ttyAM4 is selected /n");
  dev="/dev/ttyAM4";
 }
 else if(device==5){
  printf("ttyAM5 is selected /n");
  dev="/dev/ttyAM5";
 }
 else if(device==6){
  printf("ttyAM6 is selected /n");
  dev="/dev/ttyAM6";
 }
 else{
  printf("Invalid choice, please try again! /n");
  goto AGAIN;
 }
 sleep(1);
 fd = OpenDev(dev);

 if (fd>0){
      set_speed(fd,115200);
 }
 else{
  printf("Can't Open Serial Port!/n");
  exit(0);
 }

 if (set_Parity(fd,8,1,'N')== FALSE)
  {
     printf("Set Parity Error/n");
      exit(1);
   }
 //printf("start to read the device %s /n", dev);
   while(1)
   {
     
  if((nread = read(fd,buff,512))>0)    //nread为输出字符的实际长度,buff是读缓冲。
     {
         printf("/nLen %d/n",nread);
         buff[nread]='/0';
         printf("/n%s",buff);
         
         
   write(fd, recchr, 13);
     write(fd, buff, nread-1);
   write(fd, "/"/n", 2);
  }
 /* 
  if(device==0)write(fd,"01234567/n",9);
  if(device==1)write(fd,"12345678/n",9);
  if(device==2)write(fd,"23456789/n",9);
  if(device==3)write(fd,"3456789a/n",9);
  if(device==4)write(fd,"456789ab/n",9);
  if(device==5)write(fd,"56789abc/n",9);
  if(device==6)write(fd,"6789abcd/n",9);
  sleep(1);*/
   }
     close(fd);
     exit(0);
}


 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值