linux练习 串口跟进程6,linux下串口测试程序
linux下串口測試程序
通過簡單的參數(shù)配置,執(zhí)行文件+串口號+波特率
#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; //將數(shù)據(jù)位修改為8bit
options.c_cflag = ~PARENB; //無校驗
options.c_cflag = ~CSTOPB; // 設(shè)置一位停止位;
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); //發(fā)送數(shù)組
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下串口測試程序 相關(guān)文章
Linux下創(chuàng)建進程
節(jié)選自《AdvancedLinuxProgramming》 通常有兩種方式,第一種是使用system函數(shù),位于stlib.h頭文件下,system 建立了一個運行著標準Bourne shell( /bin/sh)的子進程,然后將命令交由它執(zhí)行 。 因為 system 函數(shù)使用 shell 調(diào)用命令,它受到系統(tǒng) shell 自身
Linux USB3.0驅(qū)動分析(十一)——Gadget設(shè)備枚舉分析
一.URT介紹 前面介紹了Linux USB Gadget的軟件結(jié)構(gòu)與各軟件層的整合過程。經(jīng)過各種注冊函數(shù),Gadget功能驅(qū)動層,USB設(shè)備層與UDC底層結(jié)合在了一起形成了一個完整的USB設(shè)備。而這個設(shè)備已經(jīng)準備好了接受主機的枚舉。在介紹USB設(shè)備枚舉之前。先熟悉一下各層通信
Linux USB3.0驅(qū)動分析(九)——Gadget function驅(qū)動分析
function目錄匯集了很多功能層的功能接口(interface)的具體實現(xiàn), 我們這里分析UAC2. 一. UAC2 function驅(qū)動分析 代碼位置 drivers\usb\gadget\function\f_uac2.c 里面實現(xiàn)usb設(shè)置中的接口和端點相關(guān)功能。 這里的DECLARE_USB_FUNCTION_INIT就是入口函數(shù)。 DE
Linux USB3.0驅(qū)動分析(八)——Gadget UDC驅(qū)動分析
一.概述 Gadget USB設(shè)備控制器(UDC)驅(qū)動指的是作為其他USB主機控制器外設(shè)的USB硬件設(shè)備上底層硬件控制器的驅(qū)動,該硬件和驅(qū)動負責將一個USB設(shè)備依附于一個USB主機控制器上。例如,當某運行Linux系統(tǒng)的手機作為PC的U盤時,手機中的底層USB控制器行使USB設(shè)備
Linux USB3.0驅(qū)動分析(九)——Gadget UAC2驅(qū)動分析
本文分析的是linux-5.4.3 一.Gadget Audio設(shè)備驅(qū)動分析 drivers/usb/gadget/legacy/audio.c因為項目的問題,了解usb音頻設(shè)備的工作原理,為啥它能讓PC識別成“speak”或者“mic”,以及你能夠播放錄音。主要涉及下面兩個層次:Gadget功能驅(qū)動層: 最主要的結(jié)構(gòu)
linux下的/etc/passwd詳解
在Linux /etc/passwd文件中每個用戶都有一個對應(yīng)的記錄行,它記錄了這個用戶的一些基本屬性。系統(tǒng)管理員經(jīng)常會接觸到這個文件的修改以完成對用戶的管理工作。 類似于下面的例子: 從上面的例子我們可以看到,/etc/passwd中一行記錄對應(yīng)著一個用戶,每行記錄
Linux環(huán)境下jdk1.8的下載與安裝
1、下載 Oracle官網(wǎng)下載相應(yīng)的版本,官網(wǎng)地址: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 文件系統(tǒng)中有許多目錄,當用戶執(zhí)行一條 Linux 命令又沒有指定該命令或參數(shù)所在的目錄時,Linux 系統(tǒng)就會首先在當前目錄(目前的工作目錄)搜尋這個命令或它的參數(shù)。因此,用戶在執(zhí)行命令之前,常常需要確定目前所在的工作目錄,即當前目錄。 當用
linux如何查看系統(tǒng)信息
查看linux系統(tǒng)版本信息(Oracle Linux、Centos Linux、Redhat Linux、Debian、Ubuntu) 一、查看Linux系統(tǒng)版本的命令(3種方法) 1、cat /etc/issue,此命令也適用于所有的Linux發(fā)行版。 [root@S-CentOS home]# cat /etc/issue CentOS release 6.5 (Final) K
linux查看分區(qū)命令
9月25日任務(wù) 4.1 df命令 4.2 du命令 4.3/4.4 磁盤分區(qū) df命令 df 輸出磁盤文件系統(tǒng)使用情況: [root@centos ~]# df文件系統(tǒng) 1K-塊 已用 可用 已用% 掛載點/dev/sda3 11208704 7214792 3993912 65% /devtmpfs 496920 0 496920 0% /devtmpfs 507752 0 507752 0%
總結(jié)
以上是生活随笔為你收集整理的linux练习 串口跟进程6,linux下串口测试程序的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java - 计算不同字符或数字的个数
- 下一篇: linux 内核 82540网卡,Lin