串口测试例程

串口分为RS232和TTL,所以在测试前请先确认自己的串口类型进行测试。下面以海思的一个RS232串口为例说明一下具体的测试过程,串口测试代码参考的为讯为提供的,在其基础上做的调整。

 

1、确定接口,将RXD与USB转串口模块的TXD相连,将TXD与USB转串口模块的RXD相连,GND直连。这是在硬件上的准备。

 

2、准备测试代码,将其编译成ELF文件,并拷贝至开发板下,准备运行。

测试源码如下:

 

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <termios.h>
#include <errno.h>

int set_opt(int,int,int,char,int);
int main(int argc,const char *argv[])
{
	if (argc < 2){
			printf("Usage %s  1 or 2 or 3\n",argv[0]);
			printf("example:test_uart_argv 0\n");
			return 0;
		}
	int fd,nByte;
	char *uart = NULL;
	switch (atoi(argv[1]))
		{
			case 1:
				uart = "/dev/ttyAMA1";
				break;

			case 2:
				uart = "/dev/ttyAMA2";
				break;

			case 3:
				uart = "/dev/ttyAMA3";
				break;
			
			default:
				printf("plz input argv[2] from 1 to 3\n");
				break;
				
		}
	
	char buffer[512];
	char *uart_out = "please input\r\n";
	memset(buffer, 0, sizeof(buffer));
	if((fd = open(uart, O_RDWR|O_NOCTTY))<0)
		printf("open %s is failed\n",uart);
	else{
		//set_opt(fd, 115200, 8, 'N', 1);
		set_opt(fd, 9600, 8, 'N', 1);
		write(fd,uart_out, strlen(uart_out));
		while(1){
			while((nByte = read(fd, buffer, 512))>0){
				buffer[nByte+1] = '\0';			
				write(fd,buffer,strlen(buffer));
				memset(buffer, 0, strlen(buffer));
				nByte = 0;
			}
		}
	}
	return 0;
}

int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop)
{
	struct termios newtio,oldtio;
	if  ( tcgetattr( fd,&oldtio)  !=  0) { 
		perror("SetupSerial 1");
		return -1;
	}
	bzero( &newtio, sizeof( newtio ) );
	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);
		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)
	{
		perror("com set error");
		return -1;
	}
	
	//	printf("set done!\n\r");
	return 0;
}


我是用的是传参方式进行测试,我的需要传3,这需要与自己的设备节点对应即可。

 

3、开发板下运行编译好的ELF文件,并运行。

 

4、打开串口助手,打开该串口,我的设置为9600bps,8N1。

 

 

5、开始测试,如果每发送一个数据,对应的接收到相同的数据,即证明串口正常。

 

 

至此,整个串口的测试完成! 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 32l431是一款STM32系列的微控制器芯片。串口通信是一个常见的应用场景。因此,实现串口中断例程是非常有用和必要的。 首先,需要配置芯片的串口外设。可以通过寄存器设置来实现。指定必要的设置,例如波特率、数据位、停止位、校验等等。电路连接方面,需要确保使用正确的物理接口并连接外设。 其次,需要编写中断服务子例程。在STM32系列中,中断服务程序是在向量表中组织的。我们需要将它与给定的中断号相关联并实现其代码。使用编程语言如C/C++,实现任务处理代码。这个例程需要执行任务,例如接收和发送数据、校验和错误处理等等。 最后,需要编写测试代码来验证串口中断例程的功能。为了确保代码正确、性能可靠,请反复测试和调试代码。在验证期间,可以使用串口调试助手。 总之,串口中断例程是STM32系列微控制器中实现串口通信的基本必需品。它为设计师和开发人员提供了高度自由度的选项以将微控制器芯片连接到其他设备并传输数据。 ### 回答2: 32L431是一款ST公司的32位低功耗微控制器,内部集成了丰富的外设和硬件资源。在实际应用中,串口是常用的通信方式之一。针对串口通信的应用场景,32L431提供了相应的串口中断例程,方便开发者进行快速开发。 串口中断是指在串口接收或发送数据时,当达到一定条件时,通过中断信号来通知CPU进入相应的中断服务程序,完成接收或发送数据的操作。在32L431中,串口采用了DMA方式进行数据传输,可以充分利用硬件资源,提高系统效率。 在32L431的串口中断例程中,主要包括以下几个方面的内容: 1.串口初始化:主要包括设置串口的各个工作参数,如波特率、数据位、停止位、奇偶校验等。 2.中断服务程序:当串口接收到数据或发送数据时,会触发相应的中断服务程序。在中断服务程序中,需要完成数据的接收或发送、错误处理、清除中断标志位等操作。 3.数据处理:当接收到数据后,需要进行相应的处理。可以根据需要进行数据解析、存储、显示等操作。 4.错误处理:在通信过程中,可能会出现一些错误,如数据溢出、帧错误、校验错误等。这时需要在中断服务程序中进行相应的错误处理,通常是清除相应的中断标志位,并记录相应的错误码,方便后续的调试和维护。 总的来说,在32L431的串口中断例程中,需要注意以下几点:合理设置串口参数,编写正确、高效的中断服务程序,实现数据的及时处理和错误处理,保证通信的稳定和可靠。 ### 回答3: 32l431是一款32位ARM Cortex-M4内核的微控制器,串口中断是在编写嵌入式软件时经常用到的一种技术。串口中断例程可以用来实现在程序运行时接收和发送串口数据的功能。 首先,在32l431上实现串口中断需要先进行GPIO的初始化,给定USART的两个引脚(TX和RX)的复用功能和GPIO端口口的时钟使能。同时,还需要设置UART的工作模式,数据位数、校验位、停止位等参数。此外,在开启中断前,还要设置NVIC(Nested Vectored Interrupt Controller)相应优先级和使能对应的USART中断。 其次,在中断服务程序中,接收数据时需要判断接收完成及是否出现错误,通常需要判断空闲中断和接收中断标志位的状态。如果有数据接收完成,可以通过读取接收缓存区的方式获取数据。将接收到的数据存储到内存或进行相关处理后,可以清除接收标志位来等待下一次中断。 在发送数据时,需要先将数据存储在发送缓冲区中,然后等待发送标志位中断,当发送完成后,清除相应中断标志位。同时,在发送数据时程序需要等待发送缓冲区为空才继续发送下一个字节。 总之,32l431串口中断例程的编写需要详细理解串口的工作原理,熟练掌握相应寄存器操作和中断处理技术,才能做出优秀的中断例程,实现稳定、高效的串口通信。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值