extern void Delay(__IO uint32_t nCount);
USARType USART_SendStr(UART_HandleTypeDef * USART_Handler,char * str)
{
while (*str != '\0')
{
while(__HAL_UART_GET_FLAG(USART_Handler,UART_FLAG_TXE)==RESET);
HAL_UART_Transmit(USART_Handler,(uint8_t *)str,,);
str++;
}
return USARTOK;
} /*
* 功能:固定时间指令匹配函数
* 入口参数1:串口句柄
* 入口参数2:串口接受缓冲区
* 入口参数3:发送的字符串
* 入口参数4:要匹配的字符串
* 返回值:
* USARTTIMEOUT:超时未读取到数据
* USARTOK :成功读取到数据
* USARTERROR :接受到数据,但是没有提取到*recestr
*/
USARType USART_Cmd_Marry(UART_HandleTypeDef * USART_Handler,Usart_RecerivePoint Rusart,char *sendstr,char *recestr)
{
/*通过串口发送指令*/
char * val;
char * str;
int count1 = ;
int count2 = ;
str = recestr;
USART_SendStr(USART_Handler,sendstr);//发送字符串
while (*recestr != '\0')//如果读取到\0则匹配完成
{
if(Usart_fifo_Read(Rusart,(uint8_t *)val,) == USARTOK)
{
if (*val == *recestr)//读取到的第一个字节数相同
{
recestr++;
}
else
{
recestr = str;
count1++;
if (count1 == )
{
return USARTERROR;
}
}
}
else
{
count2++;
Delay_ms();
if (count2 > )
{
return USARTTIMEOUT;
}
}
}
return USARTOK;
}
/*
* 功能:固定时间指令应答函数
* 入口参数1:串口句柄
* 入口参数2:串口接受缓冲区
* 入口参数3:发送的字符串
* 入口参数4:接受数据的地址
* 返回值:
* USARTTIMEOUT:超时未读取到数据
* USARTOK :成功读取到数据
*
*/
USARType USART_Cmd_Ack(UART_HandleTypeDef * USART_Handler,Usart_RecerivePoint Rusart,char *sendstr,char *recestr)
{
/*通过串口发送指令*/
char * val;
int count2 = ; USART_SendStr(USART_Handler,sendstr);
while ()
{
if(Usart_fifo_Read(Rusart,(uint8_t *)val,) == USARTOK)
{
*recestr = *val;
recestr++;
if (*val == )
{
*recestr = '\0';
return USARTOK;
}
}
else
{
Delay_ms();
count2++;
if (count2 > )
{
return USARTTIMEOUT;
}
}
}
}
/*
* 功能:可变时间指令匹配函数
* 入口参数1:串口句柄
* 入口参数2:串口接受缓冲区
* 入口参数3:发送的字符串
* 入口参数4:要匹配的字符串
* 入口参数5:限制的时间内检测,单位ms
* 入口参数6:限制的数据大小内查找,单位字节
* 返回值:
* USARTTIMEOUT:超时未读取到数据
* USARTOK :成功读取到数据
* USARTERROR :接受到数据,但是没有提取到*recestr
*/
USARType USART_Cmd_Time_Marry(UART_HandleTypeDef * USART_Handler,Usart_RecerivePoint Rusart,char *sendstr,char *recestr,uint16_t timeout,uint16_t countout)
{
/*通过串口发送指令*/
char * val;
char * str;
uint16_t count1 = ;
uint16_t count2 = ;
str = recestr;
USART_SendStr(USART_Handler,sendstr);//发送字符串
while (*recestr != '\0')//如果读取到\0则匹配完成
{
if(Usart_fifo_Read(Rusart,(uint8_t *)val,) == USARTOK)
{
if (*val == *recestr)//读取到的第一个字节数相同
{
recestr++;
}
else
{
recestr = str;
count1++;
if (count1 == countout)
{
return USARTERROR;
}
}
}
else
{
count2++;
Delay_ms();
if (count2 > timeout)
{
return USARTTIMEOUT;
}
}
}
return USARTOK;
} /*
* 功能:可变时间指令应答函数
* 入口参数1:串口句柄
* 入口参数2:串口接受缓冲区
* 入口参数3:发送的字符串
* 入口参数4:接受数据的地址
* 入口参数5:限制的时间内检测,单位ms
* 入口参数6:限制的数据大小内查找,单位字节
* 返回值:
* USARTTIMEOUT:超时未读取到数据
* USARTOK :成功读取到数据
*
*/
USARType USART_Cmd_Time_Ack(UART_HandleTypeDef * USART_Handler,Usart_RecerivePoint Rusart,char *sendstr,char *recestr,uint16_t timeout,uint16_t countout)
{
/*通过串口发送指令*/
char * val;
int count2 = ; USART_SendStr(USART_Handler,sendstr);
while ()
{
if(Usart_fifo_Read(Rusart,(uint8_t *)val,) == USARTOK)
{
*recestr = *val;
recestr++;
if (*val == )
{
*recestr = '\0';
return USARTOK;
}
}
else
{
Delay_ms();
count2++;
if (count2 > )
{
return USARTTIMEOUT;
}
}
}
}

这个里面一共有四段代码,其实是两段代码,只是因为需求不同而复制出来了而已

实现原理是一样的,目的是实现AT指令的匹配,和响应返回,详细信息在代码中都给出来了,这里面用到的数据类型和程序代码都在前面的文章中给出来了,我发出来的代码都是经过测试的,绝对可行,若有疑问可以添加QQ大家相互交流

AT指令调试程序的更多相关文章

  1. CPU标志寄存器

    这个标志寄存器似乎很重要,不干掉它,中断这玩意还进行不下去了,但是过于复杂,都是一些跟计算结果相关的位,头痛 (这是别人写的一篇非常好的关于标志寄存器的文章http://blog.csdn.net/w ...

  2. 利用foo函数的Bof漏洞攻击:构造攻击字符串

    利用foo函数的Bof漏洞攻击:构造攻击字符串 一.基础知识储备 objdump反汇编指令.gdb函数调试运行.Perl语言.|管道符 二.实验步骤 1. 通过反汇编了解程序功能及代码 ①反汇编查看文 ...

  3. (原创)解决远程桌面连接远程应用时,出现 '应用程序错误: '0x7c931780'指令引用的 '0x89abcdef' 内存。该内存不能为 'read'"

    公司的部分应用为cs结构,没有web版的,这些应用的外部访问基本都是通过使用windows server 2008 r2的远程桌面服务来实现的. 个人感觉微软远程桌面服务问题很多,今天有同事使用Rem ...

  4. Windows内核 基本汇编指令

    1)用VS2010新建Win32 Console Application,工程名为ACECore,工程建立完成后得到打开文件ACECore.cpp,代码如下: #include "stdaf ...

  5. Linux高级编程--04.GDB调试程序(查看数据)

    查看栈信息 当程序被停住了,你需要做的第一件事就是查看程序是在哪里停住的.当你的程序调用了一个函数,函数的地址,函数参数,函数内的局部变量都会被压入"栈"(Stack)中.你可以用 ...

  6. Linux高级编程--04.GDB调试程序(设置断点)

    调试已运行的程序 在UNIX下用ps查看正在运行的程序的PID(进程ID),然后用gdb PID格式挂接正在运行的程序. 先用gdb 关联上源代码,并进行gdb,在gdb中用attach命令来挂接进程 ...

  7. 常用ARM汇编指令

    常用ARM汇编指令 [日期:2012-07-14] 来源:Linux社区  作者:xuyuanfan77 [字体:大 中 小]     在嵌入式开发中,汇编程序常常用于非常关键的地方,比如系统启动时初 ...

  8. [转] 用GDB调试程序(五)

    转:http://blog.csdn.net/haoel/article/details/2883 查看运行时数据———————        在你调试程序时,当程序被停住时,你可以使用print命令 ...

  9. GDB单步调试程序

    linux下gdb单步调试 用 GDB 调试程序 GDB 概述———— GDB 是 GNU开源组织发布的一个强大的 UNIX下的程序调试工具.或许,各位比较喜欢那种图形界面方式的,像 VC. BCB等 ...

随机推荐

  1. Web服务器与数据库服务器分离 导入 Excel数据至数据库

    一般情况一般项目WEB服务器与数据库均部署在一台服务器,文件上传,数据导入在一台服务器完成.web服务器与数据库服务器分离,文件上传与数据导入将分布在两台服务器或多台服务器之间.本案例为两台服务器,具 ...

  2. Node的express框架安装

    第一步:在cmd命令行下执行npm install -g express,安装全局的express. 第二步:在命令行中输入express,如果出现express不是内部命令时, 输入npm inst ...

  3. kettle系列-我的开源kettle管理平台[kettle-manager]介绍

    kettle管理工具 专门为kettle这款优秀的ETL工具开发的web端管理工具. 项目简介 kettle作为非常优秀的开源ETL工具得到了非常广泛的使用,一般的使用的都是使用客户端操作管理,但问题 ...

  4. 19.Java 注解

    19.Java注解 1.Java内置注解----注解代码 @Deprecated                                    //不推荐使用的过时方法 @Deprecated ...

  5. Beginning Scala study note(1) Geting Started with Scala

    1. Scala is a contraction of "scalable" and "language". It's a fusion of objecte ...

  6. webform Repeater、地址栏传值、Response

    Repeater: 重复器 Repeater中有五个模板,这里需要注意的是4个 <HeaderTemplate> - 开头,只执行一次的内容 <ItemTemplate> - ...

  7. SQL函数说明大全

    一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...

  8. 关于淘宝店铺装修弹出层popup的记录

    小龙最近做了一下下淘宝的店铺装修,里面封装的widget深不见底,刚刚整明白popup,也就是弹出层的使用方法,大神勿喷: <div class="area001">触 ...

  9. 微信开发笔记:获取用户openid,以及用户头像昵称等信息

    微信开发的时候有一个很便利的途径来进行一个用户的一步注册登录,就是使用用户的微信信息来直接进行登陆,可以省去很多不必要的麻烦.那具体这些信息是如何来获取的呢? 首先呢,我们需要对微信进行一个授权,让微 ...

  10. 构建高性能的MYSQL数据库系统

    实验环境: DB1:172.16.1.100 DB2:172.16.1.101 VRRIP:172.16.1.99 步骤: yum -y install mysql 1.修改DB1的mysql配置文件 ...