笔者通过查阅相关资料,了解了BeagleBoneBlack开发板的UART接口特性,掌握的UART接口的基本使用方法,最后通过一个C语言的例程实现串口的自发自收。有了这个串口开发板就可和其他设备进行串口通信了,比如可以将单片机通过串口挂在开发板上。
第一步:硬件连接
1、用miniUSB线将 电脑与开发板相连,BeagleBoneBlack启动之后,在浏览器里面输入192.168.7.2,打开网页之后就可以查看相关的串口信息。
注:
(1)BeagleBoneBlack开发板的P8,P9扩展接口上共引出了四个半的串口,其中UART1,UART2,UART4,UART5四个串口的发射和接收引脚全部引出,UART3只引出了发射引脚,所以共引出了四个串口;
(2)BeagleBoneBlack开发板的UART0引脚默认作为调试引脚使用,系统上电之后UART0作为默认的打印引脚使用;
(3)接下来的实验将会以UART4为例说明串口的使用。
2、本实验的硬件连接如下图所示,将P9的11,13引脚直接连接,这样就可以实现自发自收。
3、实物图如下
第二步:手动打开串口
1、加载设备
(1)添加环境变量:export SLOTS=/sys/devices/bone_capemgr.8/slots
注:
1)功能说明:设置或显示环境变量。
2)语法:export [-fnp][变量名称]=[变量设置值]
3)补充说明:在shell中执行程序时,shell会提供一组环境变量。 export可新增,修改或删除环境变量,供后续执行的程序使用。
4)作用范围:export的有效期仅限于于该此登陆操作。
5)参 数:
-f 代表[变量名称]中为函数名称。
-n 删除指定的变量。变量实际上并未删除,只是不会输出到后续指令的执行环境中。
-p 列出所有的shell赋予程序的环境变量。
6)一个变量创建时,它不会自动地为在它之后创建的shell进程所知。而命令export可以向后面的shell传递变量的值。当一个shell脚本调用并执行时,它不会自动得到原为脚本(调用者)里定义的变量的访问权,除非这些变量已经被显式地设置为可用。
7)export命令可以用于传递一个或多个变量的值到任何后继脚本
(2)查看环境变量:cat $SLOTS
(3)加载UART4:echo BB-UART4 > $SLOTS
(4)查看设备:ls ttyO*,ttyO4就是添加的UART4设备
注:
1)*:匹配符。ttyO*可以过滤出所有ttyO开头的文件
2、利用minicom打开串口
注:如果想知道minicom的参数配置和相关命令,可以输入minicom –h,如下图所示,
注:
(1) 由上图可知道,刚才打开的minicom时配置参数的意义;
(2)-b 9600 设置波特率
(3)-o 不初始化模块,且锁定启动状态
(4)-D /dev/ttyO4 设置驱动名称
3、回车之后就可以进入UART4了,这时候输入任何字符在终端上都会显示出来。
第三步:用C语言编程实现自发自收
1、代码如下
1 #include2 #include 3 #include 4 #include // using the termios.h library 5 6 int main() 7 { 8 int file, count; 9 if ((file = open("/dev/ttyO4", O_RDWR | O_NOCTTY | O_NDELAY))<0) 10 { 11 perror("UART: Failed to open the file. \n"); 12 return -1; 13 } 14 struct termios options; // the termios structure is vital 15 tcgetattr(file, &options); // sets the parameters associated with file 16 // Set up the communications options: 17 // 9600 baud, 8-bit, enable receiver, no modem control lines 18 options.c_cflag = B9600 | CS8 | CREAD | CLOCAL; 19 options.c_iflag = IGNPAR | ICRNL; // ignore partity errors, CR -> newline 20 tcflush(file, TCIFLUSH); // discard file information not transmitted 21 tcsetattr(file, TCSANOW, &options); // changes occur immmediately 22 unsigned char transmit[18] = "Hello BeagleBone!"; // the string to send 23 24 if ((count = write(file, &transmit,18))<0) 25 { // send the string 26 perror("Failed to write to the output\n"); 27 return -1; 28 } 29 30 usleep(100000); // give the Arduino a chance to respond 31 unsigned char receive[100]; // declare a buffer for receiving data 32 if ((count = read(file, (void*)receive, 100))<0) 33 { // receive the data 34 perror("Failed to read from the input\n"); 35 return -1; 36 } 37 if (count==0) 38 printf("There was no data available to read! \n"); 39 else 40 { 41 printf("The following was read in [%d]: %s\n",count,receive); 42 } 43 close(file); 44 return 0; 45 }
2、实验现象