T31开发笔记: 串口调试

若该文为原创文章,转载请注明原文出处

因项目需要使用串口和单片机通信,所以专门调试了一下串口,记录下过程。

一、硬件和开发环境


1、硬件:T31X+SC5235 

2、开发环境: ubuntu16.04-64bit

3、编译器:mips-gcc540-glibc222-32bit-r3.3.0.tar.gz

注:板子和和WIFI模块是某淘上淘的,使用的是RTL8188,使用的是USB接口,uboot和内核是自己裁剪移植的,内核默认自带WIFI驱动,所以不用移植可以直接使用。
 

二、UART0测试

1、引脚定义

通过T31手册可以看出,引脚70和71为UART0,74和73为UART1, UART1用于DEBUG,

主要测试UART0

 

2、测试

通过命令ls /dev/ttyS0可以查看到UART0,所以使用的设备节点为/dev/ttyS0

测试方法有两种,板子固件默认的UART0波特轨是9200。

方法一:

短接串口的收发引脚

在shell终端输入:

# cat /dev/ttyS0 &
# echo helloworld > /dev/ttyS0

就可以在终端下看到输出信息了。

方法二:

使用TTL模块,把TTL的TX接引脚71,TTL的RX接引脚70,GND和板子共地。

打开调试串口软件,这里使用的是SSCOM,设置如下:

 三、代码测试

创建comm_test.c文件

由于代码比较简单,直接附代码

/*!
 *****************************************************************************
 *
 *  Copyright ? 2017-2018 yifeng. All Rights Reserved.
 *
 * \file      comm_test.c
 * \author    yifeng
 * \version   1.0
 * \date      2022年11月28日
 * \brief     sample-Ai
 *            VX: 18750903063
 *----------------------------------------------------------------------------
 * \attention
 *
 *
 *****************************************************************************
 */

/*****************************************************************************
 change history: 
    1.date  : 2022年11月28日
      author: yifeng
      change: create file

*****************************************************************************/



/*==========================================================================================
                      本源程序包括的头文件
建议:包含本项目的文件使用 #include "文件名.扩展名" ,
   包含系统库的文件使用 #include <文件名.扩展名> 。
==========================================================================================*/
#include <unistd.h>
#include <sys/ioctl.h>
#include <sys/prctl.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <stdint.h>
#include <errno.h>
#include <pthread.h>
#include <semaphore.h>
#include <fcntl.h>
#include <sys/time.h>

#include "faac/faac.h"
#include <imp/imp_audio.h>
#include <imp/imp_log.h>

#include <stdio.h>
#include <stdlib.h>
#include <strings.h>
#include <string.h>
#include <pthread.h>
#include <unistd.h>
#include <fcntl.h>
#include <stdlib.h>
#include <error.h>
#include <termios.h>
#include <malloc.h>
#include <sys/types.h>
#include <sys/stat.h>
typedef struct termios termios_t;

typedef struct serial_data{
    char databuf[100];//发送/接受数据
    int serfd;//串口文件描述符
}ser_Data;

void *sersend(void *arg);
void *serrecv(void *arg);

int main(int argc,char *argv[])
{
    pthread_t pid1,pid2;
    pthread_attr_t *pthread_arr1,*pthread_arr2;
    pthread_arr1 = NULL;
    pthread_arr2 = NULL;
    int serport1fd;

    printf("==> main\r\n");
    /*   进行串口参数设置  */
    termios_t *ter_s = malloc(sizeof(*ter_s));

    serport1fd = open("/dev/ttyS0",O_RDWR | O_NOCTTY | O_NDELAY);//不成为控制终端程序,不受其他程序输出输出影响
    if(serport1fd < 0){
        printf("%s open faild\r\n",argv[1]);
        return -1;
    }
    printf("open /dev/ttyS0 succeed\n");

    bzero(ter_s,sizeof(*ter_s));

    ter_s->c_cflag |= CLOCAL | CREAD; //激活本地连接与接受使能

    ter_s->c_cflag &= ~CSIZE;//失能数据位屏蔽
    ter_s->c_cflag |= CS8;//8位数据位

    ter_s->c_cflag &= ~CSTOPB;//1位停止位

    ter_s->c_cflag &= ~PARENB;//无校验位

    ter_s->c_cc[VTIME] = 0;
    ter_s->c_cc[VMIN] = 0;

    /*1 VMIN> 0 && VTIME> 0
        VMIN为最少读取的字符数,当读取到一个字符后,会启动一个定时器,在定时器超时事前,如果已经读取到了VMIN个字符,则read返回VMIN个字符。如果在接收到VMIN个字符之前,定时器已经超时,则read返回已读取到的字符,注意这个定时器会在每次读取到一个字符后重新启用,即重新开始计时,而且是读取到第一个字节后才启用,也就是说超时的情况下,至少读取到一个字节数据。
        2 VMIN > 0 && VTIME== 0
        在只有读取到VMIN个字符时,read才返回,可能造成read被永久阻塞。
        3 VMIN == 0 && VTIME> 0
        和第一种情况稍有不同,在接收到一个字节时或者定时器超时时,read返回。如果是超时这种情况,read返回值是0。
        4 VMIN == 0 && VTIME== 0
        这种情况下read总是立即就返回,即不会被阻塞。----by 解释粘贴自博客园
    */
    cfsetispeed(ter_s,B115200);//设置输入波特率
    cfsetospeed(ter_s,B115200);//设置输出波特率
    printf("==> cfsetospeed\r\n");
    tcflush(serport1fd,TCIFLUSH);//刷清未处理的输入和/或输出
    printf("==> tcflush\r\n");
    if(tcsetattr(serport1fd,TCSANOW,ter_s) != 0){
            printf("com set error!\r\n");
    }
    printf("==> tcsetattr\r\n");

    char buffer[] = {"hello my world!\r\n"};
    char recvbuf[100] = {};

    ser_Data snd_data;
    ser_Data rec_data;

    snd_data.serfd = serport1fd;
    rec_data.serfd = serport1fd;

    memcpy(snd_data.databuf,buffer,strlen(buffer));//拷贝发送数据

    pthread_create(&pid1,pthread_arr1,sersend,(void *)&snd_data);
    pthread_create(&pid2,pthread_arr2,serrecv,(void *)&rec_data);


    ssize_t sizec;
    while(1){

            usleep(100000);
    }

    pthread_join(pid1,NULL);
    pthread_join(pid2,NULL);
    free(ter_s);
    return 0;
}


void *sersend(void *arg)//串口发送线程函数
{
    ser_Data *snd = (ser_Data *)arg ;
    int ret;
    printf("==> sersend\r\n");
    
    while(1){
       printf("write\r\n");
       ret = write(snd->serfd,snd->databuf,strlen(snd->databuf));
       if(ret > 0){
            printf("send success, data is  %s\r\n",snd->databuf);
       }else{
           printf("send error!\r\n");
       }
       usleep(1000*1000*3);
       /*
       if(发生中断)
       break;//退出
       */
    }
}

void *serrecv(void *arg)//串口发送线程函数
{
    ser_Data *rec= (ser_Data *)arg ;
    int ret;
    
    printf("==> serrecv\r\n");
    
    while(1){
       ret = read(rec->serfd,rec->databuf,1024);
       if(ret > 0){
            printf("recv success,recv size is %d \r\n",ret );
            printf("recv databuf: %s\r\n", rec->databuf);
       }else{
           /*
            什么也不做
           */
       }
       usleep(1000);
       /*
       if(发生中断)
       break;//退出
       */
    }
}

 先设置串口参数,波特率为115200,然后创建接收和发送线程,发送线程每3秒发送一次数据,接收线程一直等待接收数据。

这里使用测试方法二,把串口0接到TTL模块上,TTL在接到电脑上。

打开SSCOM软件,修改波特率为115200。

四、总结

1、相对于海思,君正T31的串口使用还是挺方便的,途中没遇到要修改的,固件直接可以使用。

2、串口的使用相当常见,测试只是为了功能更快的集成。 

如有侵权,请及时联系博主删除。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: T31 Tiziano ISP动态调试工具是一款专业的嵌入式系统调试工具,旨在帮助开发人员在嵌入式系统开发过程中进行高效、准确的调试,提高开发效率。该工具具有多种功能和使用方法,下面介绍其中的几种常见的使用方法。 1、代码调试功能:利用T31 Tiziano ISP可以对嵌入式系统中的应用程序进行断点调试,实时监测程序的运行状态,可以帮助开发人员快速定位问题并进行解决。 2、性能监测功能:该工具可以对嵌入式系统中的性能参数进行实时监测和记录,例如CPU使用率、内存使用量等,可以帮助开发人员了解系统运行状态,及时调优系统性能。 3、外设调试功能:T31 Tiziano ISP支持对嵌入式系统中的外设进行调试,包括串口、网络等外设,可以快速定位外设出现的问题。 4、协议分析功能:该工具还支持各种嵌入式协议的分析和解码,包括CAN、SPI、I2C、UART等协议,可以帮助开发人员诊断协议相关的问题。 总之,T31 Tiziano ISP动态调试工具拥有丰富的功能和灵活的使用方法,可以满足嵌入式系统开发中的各种调试需求,是一款值得推荐的工具。开发人员可以根据自己的需求选择合适的使用方法,提高开发效率和代码质量。 ### 回答2: T31 Tiziano ISP动态调试工具是一款针对图像处理器的调试工具,可以在调试过程中对图像进行实时显示和操作。使用该工具需要先将目标机器和调试工具连接,然后进行如下步骤: 1. 打开T31 Tiziano ISP动态调试工具,选择“连接”,输入目标机器的IP地址和连接端口,点击“连接”按钮连接目标机器。 2. 在“配置”选项中设置所需的图像分辨率、色彩空间等参数。 3. 选择“调试”选项卡,在左侧的“输入”窗口中选择所需的图像输入源,可以是相机、视频流等。 4. 在右侧的“输出”窗口中,选择所需的图像输出源,可以是显示器、文件输出等。 5. 在调试过程中,可以使用工具栏上的各种调试工具,例如图像放大、旋转、裁剪等,并可以实时查看调试结果。 6. 调试结束后,可以保存调试过程中的图像和参数等信息。 总之,T31 Tiziano ISP动态调试工具是一款性能强大、操作简单的图像处理调试工具,适用于图像算法调试和优化等方面。 ### 回答3: T31 Tiziano ISP动态调试工具是一种用于数字视频信号处理和图像算法开发的高性能工具。使用该工具可以快速定位和解决数字视频信号处理中的问题。以下是使用T31 Tiziano ISP动态调试工具的方法: 1.安装工具:首先,从官方网站下载最新版本的工具,并按照说明进行安装。 2.打开工具:启动工具,打开需要调试的图像文件。 3.设置调试参数:在工具栏中选择ISP调试模式,然后进入ISP调试参数设置,选择相应的调试参数,例如图像格式、分辨率、图像区域等。 4.调试功能:在调试功能栏中选择需要调试的功能,例如白平衡、色彩增强等。然后进行相应的参数设置,例如色相、亮度、对比度等。 5.图像分析:在图像分析栏中选择需要分析的图像,例如YUV、RGB等格式。然后进行相应的像素值和统计分析。 6.保存数据:将调试结果保存到相应的文件中,例如XML格式文件。 7.反馈结果:将调试结果反馈给开发人员,帮助开发优化相应的图像算法。 总之,T31 Tiziano ISP动态调试工具可以帮助用户快速定位和解决数字视频信号处理中的问题。通过选择相应的调试参数、调试功能和图像分析,用户可以快速优化相应的图像算法,并获得更好的图像处理效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

殷忆枫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值