《开发板 — 调试串口》

1.查看串口设备

ls /dev/tty*

  其中ttyAMA1是我们要调试我串口。

 

2.使用ttyAMA1

通过stty -F  /dev/ttyAMA1 -a查看串口属性

  

   可以查看波特率是9600

 

通过stty修改串口设置:

stty -F /dev/ttyAMA1 ispeed 115200 ospeed 115200 cs8 

115200波特率 8数据位 1停止位 无校验位

  

从ttyAMA1中读取数据:

cat  /dev/ttyAMA1    //读取串口中的数据
cat  /dev/ttyAMA1  > file.txt    //读取到的数据保存到txt文本文件中
或者
microcom -t 10000 -s 115200 /dev/ttyAMA1 # microcom 读数据,10秒无数据,退出
microcom 

  

 

向ttyAMA1中写数据:

echo "1"  >  /dev/ttyAMA1

 

 

3.串口配置

  场景:在调试串口为ttyFIQ0的时候,要调试485。485连接在uart0上。在设备树中使能了设备树后,发现只能往外发送数据,但是用cat数据接收不进来。(用示波器测试485芯片上的Rx有数据进来的情况下)

  可能原因:波特率不同,因为ttyFIQ0是115200,但是uart0的波特率是9600。但是数据可以发送出去用echo,并且在电脑端接收没有乱码。不太理解为什么?

  解决:写串口程序。

/******************************************************* 
*filename:serial_rev.c 
*Description:receivedata from Serial_Port 
*Date:
*******************************************************/ 
#include <stdio.h> 
#include <string.h> 
#include <malloc.h> 
#include <sys/types.h> 
#include <sys/stat.h> 
#include <fcntl.h> 
#include <unistd.h> 
#include <sys/msg.h>	
#include <termios.h> 
#include <sys/time.h>
#include <stdlib.h>
#include <unistd.h> 
#include <termios.h> 
#include <sys/ioctl.h>  
#include "uart_4g_ttyusb2.h"
//#include <pthread.h>
/*********************************************************/ 
#define CMD_LEN 7
//#define MAX_MSG_BUFF_SIZE   128 /*定义缓冲区最大宽度*/ 
static int g_fg_4g = -1;
static char frame_tail[] = {0xFF,0xFC,0xFF,0xFF};

//#define TTYS_DEVNAME "/dev/ttyAMA1" /*需要把寄存器配置uart2的复用口为uart*/
//#define TTYS_DEVNAME "/dev/ttyAMA2" /*需要把寄存器配置uart2的复用口为uart*/
//#define TTYS_DEVNAME "/dev/ttyS1"
//#define TTYS_DEVNAME "/dev/ttyUSB0"
#define TTYS_USB2_DEVNAME "/dev/ttyAMA1"


int uart_4gserial_dev_init()
{
    struct termios opt; 
    if(0 < g_fg_4g)
    {
        printf("%s is already opened!",TTYS_USB2_DEVNAME); 
	}


    if(0 > g_fg_4g)
    {
        g_fg_4g = open(TTYS_USB2_DEVNAME, O_RDWR|O_NOCTTY); /*读写方式打开串口*/ 
    }
    if(0 > g_fg_4g) /*打开失败*/ 
    {
        printf("open %s Error",TTYS_USB2_DEVNAME); 
        return -1; 
    }
    DBG_PRT(DBG_OFF," FD=%d\n",g_fg_4g);

    tcgetattr(g_fg_4g,&opt); 
    
    DBG_PRT(DBG_OFF," A cflg=%2X oflg=%2X lflg=%2X iflg=%2X\n",
        opt.c_cflag,opt.c_oflag,opt.c_lflag,opt.c_iflag);
    cfmakeraw(&opt); 
    DBG_PRT(DBG_OFF," B cflg=%2X oflg=%2X lflg=%2X iflg=%2X\n",
        opt.c_cflag,opt.c_oflag,opt.c_lflag,opt.c_iflag);

    cfsetispeed(&opt,B9600); /*波特率设置为B115200bps*/ 
    cfsetospeed(&opt,B9600); 

    //cfsetispeed(&opt,B115200); /*波特率设置为B115200bps*/ 
    //cfsetospeed(&opt,B115200); 
    opt.c_iflag = 0; 
    opt.c_oflag = 0; 
    opt.c_lflag = 0; //non ICANON 

	opt.c_cflag &= ~PARENB;
	opt.c_cflag |= CSTOPB;//停止位2位
	opt.c_cflag &= ~CSIZE;
	opt.c_cflag |= CS8;

	fcntl(g_fg_4g,F_SETFL,0); 
	opt.c_cc[VTIME] = 2;
	opt.c_cc[VMIN]  = 128;

    tcsetattr(g_fg_4g,TCSANOW,&opt); 
    tcflush(g_fg_4g, TCIFLUSH); 

    tcgetattr(g_fg_4g,&opt); 
    
    DBG_PRT(DBG_OFF," C cflg=%2X oflg=%2X lflg=%2X iflg=%2X\n",
        opt.c_cflag,opt.c_oflag,opt.c_lflag,opt.c_iflag);
    DBG_PRT(DBG_OFF," FD=%d return 0\n",g_fg_4g);
    DBG_PRT(DBG_OFF,"#####\n");

    return 0; 
}

int uart_4gserial_dev_close()
{
    int ret = 0;
    ret = close(g_fg_4g); 
    if(ret == -1)
    DBG_PRT(DBG_OFF,"Closethe Device failur"); 
    return 0; 

} 

#define PRI_LEN 8 
void buf_print(char* str,unsigned char *buf, int len)
{
    int i = 0;
	int j = 0;

	if(NULL == buf)	
    {
		return;
	}

	fprintf(stderr,"\n******** print %s begin len=%d********\n",str,len);
	while (i < len)
	{
		
		if ((len - i) < PRI_LEN )
		{
			for (; i < len; i++)
			{
				fprintf(stderr,"0x%02X ",buf[i]);
			}
		}
		else
		{
			for (j = 0; j < PRI_LEN; j++)
			{
				fprintf(stderr,"0x%02X ", buf[i + j]);
			}

			i += 8;
		}	
		
		fprintf(stderr,"\n");

	}	

	fprintf(stderr,"******** print %s end ********\n",str);

	return;
}


int uart_4guart_cmd_send(unsigned char *cmd, int len)
{ 
    int write_len = -1; 

    if(len > SERIAL_OUT_BUFF_SIZE - 1 || 0 > g_fg_4g)
    {
        return -1;
    }
    
    //buf_print("uart_cmd_send buf",cmd,len);
    write_len = write(g_fg_4g, cmd, len);
    //write_len = len;
    if(write_len != len) 
    {
        DBG_PRT(DBG_OFF,"write Device failureá"); 
        return -1;
    }
    return 0; 
}

int uart_4guart_at_read(unsigned char *tmpbuff, int len)
{
    int ret,rcv_len,n = 0; 

    rcv_len = read(g_fg_4g, tmpbuff, len); 
    if(rcv_len == -1) 
    { 
        DBG_PRT(DBG_ON," read err\n");
        perror("read"); 
        return -1;
    } 
    
    return rcv_len; 

}

  

 

4.从内核配置串口

问题描述:一开始通过ls查看到有ttyAMA1这个设备节点。但是直接使用的时候不能使用。然后使用stty查看属性。提示:没有这个设备或者地址。

 

问题分析:有可能是串口驱动里面直接映射了这个设备节点,也就是创建了这个设备节点。但是并没有配置硬件。

 

问题修改:

1.使能uart1

vi arch/arm/boot/dts/hi3521d.dtsi

   可以查看到这个设备。直接将status中修改成okay。就可以了(不过不建议直接在这边修改)

直接修改

vi arch/arm/boot/dts/hi3521d.dts

 

 本来只有一个uart0,这个是我们的调试串口。

然后模仿写一个uart1。

 

2.引脚复用

查看海思的引脚复用手册可以看到

 

 

 

通过himm修改引脚复用。这样串口就配置成功。 

 

posted @ 2019-11-29 16:58  一个不知道干嘛的小萌新  阅读(4386)  评论(0编辑  收藏  举报