linux下串口测试程序
通过简单的参数配置,执行文件+串口号+波特率
#include stdio.h
#include stdlib.h
#include unistd.h
#include sys/types.h
#include sys/stat.h
#include fcntl.h
#include errno.h
#include sys/time.h
#include time.h
#include string.h
#include sys/ioctl.h
#include termios.h
#include stdint.h
#include stdio.h
#include fcntl.h
#include sys/ioctl.h
#include linux/spi/spidev.h
#include string.h
#include assert.h
#include netinet/in.h
#include sys/types.h
#include signal.h
#include stdlib.h
#include sys/time.h
#define msleep(x) usleep(x*1000)
void my_printf(const char* head_l, unsigned char*date_in, int length_l)
{
int k;
printf("%s ", head_l);
for ( k = 0; k length_l; k++)
{
printf("%02x ", date_in[k]);
}
printf("\n");
}
int select_serial_device(int dev_id, char *name)
{
switch (dev_id)
{
case 1:
strcpy(name, "/dev/ttyS1");
break;
case 2:
strcpy(name, "/dev/ttyS2");
break;
case 3:
strcpy(name, "/dev/ttyS3");
break;
case 4:
strcpy(name, "/dev/ttyS4");
break;
case 5:
strcpy(name, "/dev/ttyS5");
break;
case 6:
strcpy(name, "/dev/ttyS6");
break;
case 7:
strcpy(name, "/dev/ttyS7");
break;
case 8:
strcpy(name, "/dev/ttyS8");
break;
case 9:
strcpy(name, "/dev/ttyS9");
break;
case 10:
strcpy(name, "/dev/ttyS10");
break;
case 11:
strcpy(name, "/dev/ttyS11");
break;
default:
return -1;
}
return 0;
}
unsigned int choose_baud_rate(int br_id)
{
unsigned int baud;
switch (br_id)
{
case 0:
baud = B0;
break;
case 50:
baud = B50;
break;
case 75:
baud = B75;
break;
case 110:
baud = B110;
break;
case 134:
baud = B134;
break;
case 150:
baud = B150;
break;
case 200:
baud = B200;
break;
case 300:
baud = B300;
break;
case 600:
baud = B600;
break;
case 1200:
baud = B1200;
break;
case 1800:
baud = B1800;
break;
case 2400:
baud = B2400;
break;
case 9600:
baud = B9600;
break;
case 19200:
baud = B19200;
break;
case 38400:
baud = B38400;
break;
case 57600:
baud = B57600;
break;
case 115200:
baud = B115200;
break;
case 460800:
baud = B460800;
break;
case 921600:
baud = B921600;
break;
case 1000000:
baud = B1000000;
break;
default:
printf("input error: baud rate not correct");
return -1;
}
return baud;
}
int init_serial_device(char *name, int baud)
{
int fd;
int ret;
struct termios options;
fd = open(name, O_RDWR | O_NDELAY | O_NOCTTY);
if (fd == -1){
printf("%s: open error\n", name);
return -1;
}
ret = tcgetattr(fd, options);
if (-1 == ret)
return -1;
options.c_cflag = ~CSIZE; //屏蔽其他标志
options.c_cflag |= CS8; //将数据位修改为8bit
options.c_cflag = ~PARENB; //无校验
options.c_cflag = ~CSTOPB; // 设置一位停止位;
options.c_lflag = ~(ICANON | ECHO | ECHOE | ISIG);
cfsetispeed(options, baud);
cfsetospeed(options, baud);
options.c_iflag = ~(BRKINT | ICRNL | INPCK | ISTRIP | IXON);
ret = tcsetattr(fd, TCSANOW, options);
if (-1 == ret)
return -1;
return fd;
}
void process_serial_data(int fd)
{
char sendbuf[64] = "123456789123456789123456789123456789";
char recvbuf[64] = "";
int ret;
while (1){
ret = write(fd, sendbuf,36); //发送数组
my_printf("send:",sendbuf,ret);
msleep(100);
while(1){
memset(recvbuf, 0, sizeof(recvbuf));
ret = read(fd, recvbuf, 255);
if (ret == 0)
continue;
if(ret0){
my_printf("recv:",recvbuf,ret);
break;
}
}
msleep(200);
}
}
int main(int argc, char **argv)
{
int fd;
int bn;
int ret;
char name[12];
char sn;
speed_t baud;
if (argc 2){
printf("input error:*argv=1-11\n");
exit(-1);
}
if (argc 3){
printf("input error: less than 4 parameters\n");
exit(-1);
}
ret = sscanf(argv[1], "%d", sn);
ret = select_serial_device(sn,name);
if (-1 == ret)
return -1;
ret = sscanf(argv[2], "%d", bn);
baud = choose_baud_rate(bn);
if (-1 == ret)
return -1;
fd = init_serial_device(name,baud);
if (-1 == fd)
return -1;
process_serial_data(fd);
return 0;
}
直接交叉编译即可
linux下串口测试程序 相关文章
Linux下创建进程
节选自《AdvancedLinuxProgramming》 通常有两种方式,第一种是使用system函数,位于stlib.h头文件下,system 建立了一个运行着标准Bourne shell( /bin/sh)的子进程,然后将命令交由它执行 。 因为 system 函数使用 shell 调用命令,它受到系统 shell 自身
Linux USB3.0驱动分析(十一)——Gadget设备枚举分析
一.URT介绍 前面介绍了Linux USB Gadget的软件结构与各软件层的整合过程。经过各种注册函数,Gadget功能驱动层,USB设备层与UDC底层结合在了一起形成了一个完整的USB设备。而这个设备已经准备好了接受主机的枚举。在介绍USB设备枚举之前。先熟悉一下各层通信
Linux USB3.0驱动分析(九)——Gadget function驱动分析
function目录汇集了很多功能层的功能接口(interface)的具体实现, 我们这里分析UAC2. 一. UAC2 function驱动分析 代码位置 drivers\usb\gadget\function\f_uac2.c 里面实现usb设置中的接口和端点相关功能。 这里的DECLARE_USB_FUNCTION_INIT就是入口函数。 DE
Linux USB3.0驱动分析(八)——Gadget UDC驱动分析
一.概述 Gadget USB设备控制器(UDC)驱动指的是作为其他USB主机控制器外设的USB硬件设备上底层硬件控制器的驱动,该硬件和驱动负责将一个USB设备依附于一个USB主机控制器上。例如,当某运行Linux系统的手机作为PC的U盘时,手机中的底层USB控制器行使USB设备
Linux USB3.0驱动分析(九)——Gadget UAC2驱动分析
本文分析的是linux-5.4.3 一.Gadget Audio设备驱动分析 drivers/usb/gadget/legacy/audio.c因为项目的问题,了解usb音频设备的工作原理,为啥它能让PC识别成“speak”或者“mic”,以及你能够播放录音。主要涉及下面两个层次:Gadget功能驱动层: 最主要的结构
linux下的/etc/passwd详解
在Linux /etc/passwd文件中每个用户都有一个对应的记录行,它记录了这个用户的一些基本属性。系统管理员经常会接触到这个文件的修改以完成对用户的管理工作。 类似于下面的例子: 从上面的例子我们可以看到,/etc/passwd中一行记录对应着一个用户,每行记录
Linux环境下jdk1.8的下载与安装
1、下载 Oracle官网下载相应的版本,官网地址:https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html。 由于我的Linux是CentOS6.5(32位)的,因此我下载jdk-8u271-linux-i586.tar.gz文件。 2、解压文件 新建/usr/java文件夹 mkdir
linux查看当前路径命令
由于 Linux 文件系统中有许多目录,当用户执行一条 Linux 命令又没有指定该命令或参数所在的目录时,Linux 系统就会首先在当前目录(目前的工作目录)搜寻这个命令或它的参数。因此,用户在执行命令之前,常常需要确定目前所在的工作目录,即当前目录。 当用
linux如何查看系统信息
查看linux系统版本信息(Oracle Linux、Centos Linux、Redhat Linux、Debian、Ubuntu) 一、查看Linux系统版本的命令(3种方法) 1、cat /etc/issue,此命令也适用于所有的Linux发行版。 [root@S-CentOS home]# cat /etc/issue CentOS release 6.5 (Final) K
linux查看分区命令
9月25日任务 4.1 df命令 4.2 du命令 4.3/4.4 磁盘分区 df命令 df 输出磁盘文件系统使用情况: [root@centos ~]# df文件系统 1K-块 已用 可用 已用% 挂载点/dev/sda3 11208704 7214792 3993912 65% /devtmpfs 496920 0 496920 0% /devtmpfs 507752 0 507752 0%