STM32一键连接JQ8400-FLJQ8900语音模块程序分析

发布者:TechGuru123最新更新时间:2019-09-09 来源: eefocus关键字:STM32  一键连接  JQ8400  FLJQ8900  语音模块 手机看文章 扫描二维码
随时随地手机看文章

首先是JQ8900.C


#include "JQ8900.h"

#include "delay.h"

//初始化PB5使能端口的时钟            

//SDA IO初始化

void JQ8900_Init(void)

{



    

     GPIO_InitTypeDef  GPIO_InitStructure;

     

 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOE, ENABLE);     //使能PB,PE端口时钟

    

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;                 //LED0-->PB.5 端口配置

 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;          //推挽输出

 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;         //IO口速度为50MHz

 GPIO_Init(GPIOC, &GPIO_InitStructure);                     //根据设定参数初始化GPIOB.5

 GPIO_SetBits(GPIOC,GPIO_Pin_7);                         //PB.5 输出高

}



//#define JQ8900_SDA  PCout(7)// PC7

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

 函 数 名  : SendData

 功能描述  : 一线串口发送函数

 输入参数  : u16 N

 输出参数  : 无

 返 回 值  :

 调用函数  :

 被调函数  :


 修改历史      :

  1.日    期   : 2014年8月17日

    作    者   : wskblueice

    修改内容   : 新生成函数


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

void SendData ( uint8_t addr )

{

    uint8_t i;

    JQ8900_SDA = 1;/*开始拉高*/

    delay_us ( 1000 );

    JQ8900_SDA = 0;/*开始引导码*/

    delay_us ( 3200 );/*此处延时最少要大于2ms,此参数延时为310ms  */


    for ( i = 0; i < 8; i++ ) /*总共8位数据  */

    {

        JQ8900_SDA = 1;

        if ( addr & 0x01 ) /*3:1表示数据位1,每个位用两个脉冲表示  */

        {

            delay_us ( 600 );

            JQ8900_SDA = 0;

            delay_us ( 200 );

        }

        else              /*1:3表示数据位0 ,每个位用两个脉冲表示  */

        {

            delay_us ( 200 );

            JQ8900_SDA = 0;

            delay_us ( 600 );

        }

        addr >>= 1;

    }

    JQ8900_SDA = 1;

}



void test()

    

{


            delay_ms ( 210 );

            JQ8900_SDA = 0;

            delay_ms( 500 );

              JQ8900_SDA = 1;



}



//关于时钟晶振  速率  倍频


/*********

//在STM32中,有五个时钟源,为HSI、HSE、LSI、LSE、PLL。


//①HSI是高速内部时钟,RC振荡器,频率为8MHz。


//②HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。


//③LSI是低速内部时钟,RC振荡器,频率为40kHz。


//④LSE是低速外部时钟,接频率为32.768kHz的石英晶体。


//⑤PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。


//二、在STM32上如果不使用外部晶振,OSC_IN和OSC_OUT的接法:如果使用内部RC振荡器而不使用外部晶振,请按照下面方法处理:


//①对于100脚或144脚的产品,OSC_IN应接地,OSC_OUT应悬空。

//②对于少于100脚的产品,有2种接法:第1种:OSC_IN和OSC_OUT分别通过10K电阻接地。此方法可提高EMC性能;第2种:分别重映射OSC_IN和OSC_OUT至PD0和PD1,再配置PD0和PD1为推挽输出并输出'0'。此方法可以减小功耗并(相对上面)节省2个外部电阻。


//三、用HSE时钟,程序设置时钟参数流程:

//01、将RCC寄存器重新设置为默认值   RCC_DeInit;

//02、打开外部高速时钟晶振HSE    RCC_HSEConfig(RCC_HSE_ON);

//03、等待外部高速时钟晶振工作    HSEStartUpStatus = RCC_WaitForHSEStartUp();

//04、设置AHB时钟         RCC_HCLKConfig;

//05、设置高速AHB时钟     RCC_PCLK2Config;

//06、设置低速速AHB时钟   RCC_PCLK1Config;

//07、设置PLL              RCC_PLLConfig;

//08、打开PLL              RCC_PLLCmd(ENABLE);

//09、等待PLL工作   while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)

//10、设置系统时钟        RCC_SYSCLKConfig;

//11、判断是否PLL是系统时钟     while(RCC_GetSYSCLKSource() != 0x08)

//12、打开要使用的外设时钟    RCC_APB2PeriphClockCmd()/RCC_APB1PeriphClockCmd()


//四、下面是STM32软件固件库的程序中对RCC的配置函数(使用外部8MHz晶振)

//void RCC_Configuration(void)

//{

//  /*将外设RCC寄存器重设为缺省值*/

//  RCC_DeInit();

// 

//  /*设置外部高速晶振(HSE)*/

//  RCC_HSEConfig(RCC_HSE_ON);   //RCC_HSE_ON——HSE晶振打开(ON)

// 

//  /*等待HSE起振*/

//  HSEStartUpStatus = RCC_WaitForHSEStartUp();

// 

//  if(HSEStartUpStatus == SUCCESS)        //SUCCESS:HSE晶振稳定且就绪

//  {

//    /*设置AHB时钟(HCLK)*/ 

//    RCC_HCLKConfig(RCC_SYSCLK_Div1);  //RCC_SYSCLK_Div1——AHB时钟= 系统时钟

// 

//    /* 设置高速AHB时钟(PCLK2)*/ 

//    RCC_PCLK2Config(RCC_HCLK_Div1);   //RCC_HCLK_Div1——APB2时钟= HCLK

// 

//    /*设置低速AHB时钟(PCLK1)*/    

//RCC_PCLK1Config(RCC_HCLK_Div2);   //RCC_HCLK_Div2——APB1时钟= HCLK / 2

//    /*设置FLASH存储器延时时钟周期数*/

//    FLASH_SetLatency(FLASH_Latency_2);    //FLASH_Latency_2  2延时周期

// /*选择FLASH预取指缓存的模式*/  

//    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);       // 预取指缓存使能

//    /*设置PLL时钟源及倍频系数*/ 

//    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);     

//// PLL的输入时钟= HSE时钟频率;RCC_PLLMul_9——PLL输入时钟x 9 

//  /*使能PLL */

//    RCC_PLLCmd(ENABLE); 

//    /*检查指定的RCC标志位(PLL准备好标志)设置与否*/   

//    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)      

//       {

//       }

//    /*设置系统时钟(SYSCLK)*/ 

//    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); 

////RCC_SYSCLKSource_PLLCLK——选择PLL作为系统时钟

//    /* PLL返回用作系统时钟的时钟源*/

//    while(RCC_GetSYSCLKSource() != 0x08)        //0x08:PLL作为系统时钟

//       { 

//       }

//     }

// 

// /*使能或者失能APB2外设时钟*/    

//  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | 

//RCC_APB2Periph_GPIOC , ENABLE); 

////RCC_APB2Periph_GPIOA    GPIOA时钟

////RCC_APB2Periph_GPIOB    GPIOB时钟

////RCC_APB2Periph_GPIOC    GPIOC时钟

////RCC_APB2Periph_GPIOD    GPIOD时钟

//}

//五、时钟频率

//STM32F103内部8M的内部震荡,经过倍频后最高可以达到72M。目前TI的M3系列芯片最高频率可以达到80M。

//在stm32固件库3.0中对时钟频率的选择进行了大大的简化,原先的一大堆操作都在后台进行。系统给出的函数为SystemInit()。但在调用前还需要进行一些宏定义的设置,具体的设置在system_stm32f10x.c文件中。


//文件开头就有一个这样的定义: 

////#define SYSCLK_FREQ_HSE    HSE_Value 

////#define SYSCLK_FREQ_20MHz 20000000 

////#define SYSCLK_FREQ_36MHz 36000000 

////#define SYSCLK_FREQ_48MHz 48000000 

////#define SYSCLK_FREQ_56MHz 56000000 

//#define SYSCLK_FREQ_72MHz 72000000


//ST 官方推荐的外接晶振是 8M,所以库函数的设置都是假定你的硬件已经接了 8M 晶振来运算的.以上东西就是默认晶振 8M 的时候,推荐的 CPU 频率选择.在这里选择了:

//#define SYSCLK_FREQ_72MHz 72000000 

//也就是103系列能跑到的最大值72M


//然后这个 C文件继续往下看 

//#elif defined SYSCLK_FREQ_72MHz 

//const uint32_t SystemFrequency         = SYSCLK_FREQ_72MHz;    

//const uint32_t SystemFrequency_SysClk = SYSCLK_FREQ_72MHz;    

//const uint32_t SystemFrequency_AHBClk = SYSCLK_FREQ_72MHz;    

//const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_72MHz/2);

//const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_72MHz;

//这就是在定义了CPU跑72M的时候,各个系统的速度了.他们分别是:硬件频率,系统时钟,AHB总线频率,APB1总线频率,APB2总线频率.再往下看,看到这个了: 

//#elif defined SYSCLK_FREQ_72MHz 

//static void SetSysClockTo72(void);

//这就是定义 72M 的时候,设置时钟的函数.这个函数被 SetSysClock ()函数调用,而

//SetSysClock ()函数则是被 SystemInit()函数调用.最后 SystemInit()函数,就是被你调用的了

//所以设置系统时钟的流程就是: 

//首先用户程序调用 SystemInit()函数,这是一个库函数,然后 SystemInit()函数里面,进行了一些寄存器必要的初始化后,就调用 SetSysClock()函数. SetSysClock()函数根据那个#define SYSCLK_FREQ_72MHz 72000000 的宏定义,知道了要调用SetSysClockTo72()这个函数,于是,就一堆麻烦而复杂的设置~!@#$%^然后,CPU跑起来了,而且速度是 72M. 虽然说的有点累赘,但大家只需要知道,用户要设置频率,程序中就做的就两个事情:


//第一个: system_stm32f10x.c 中 #define SYSCLK_FREQ_72MHz 72000000 

//第二个:调用SystemInit()



//delay_1us延时函数  语音模块专用的延时函数

///////////////////////////////////////////////////////////////////////////////

//////说    明:__NOP()CPU跑72M的时【用__NOP()函数延时 72次】

//////////////////////////////////////////////////////////////////////////////

void delay_1us(u32 nTimer)

{

    u32 i=0;

    for(i=0;i        __NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();

        __NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();

        __NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();

        __NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();

        __NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();__NOP();

        

    }    

    }

 


#ifndef __JQ8900_H

#define __JQ8900_H


#include "stm32f10x.h"



#include "sys.h"

#define JQ8900_SDA  PCout(7)// PC7


void JQ8900_Init(void);//初始化


void SendData( uint8_t addr );//一线串口发送函数

void delay_1us(u32 nTimer);

//void test();                             

#endif

 


main.c


#include "user_usart.h" 

#include "user_gpio.h"

#include "user_74_165.h"

#include "user_74_595.h"

#include "user_timer.h"

#include "user_adc.h"

#include "user_iwdg.h"

#include "user_crc.h"

#include

#include "delay.h"

[1] [2]
关键字:STM32  一键连接  JQ8400  FLJQ8900  语音模块 引用地址:STM32一键连接JQ8400-FLJQ8900语音模块程序分析

上一篇:关于时钟晶振 速率 倍频
下一篇:串口接收数据并对数据进行处理

推荐阅读最新更新时间:2024-11-11 15:03

STM32的USART中RTS、 CTS的作用和意义
写在前面 Ⅰ 我们都知道USART中RX和TX这两个引脚的功能,这两个引脚是USART串行通信最常见和必不可少的两个引脚。但我们在手册中会发现关于USART的其他引脚:USART_CK、USART_RTS、USART_CTS,如下图: 但我们大部分都没怎么使用过USART_RTS和USART_CTS这两个引脚。下面将给大家简单讲述一下关于USART串口拓展的知识。 关于DB9串口接头 Ⅱ 我们都听说过RS232,说232就知道DB9这个串口接头。 DB9个引脚的功能: 1 CD ← Carrier Detect 载波检测 2 RXD ← Receive Data 接收数据 3 TXD → Transmit Data 发送数
[单片机]
<font color='red'>STM32</font>的USART中RTS、 CTS的作用和意义
STM32开发 -- 信号强度CSQ
使用GSM模块的时候,需要查看信号强度。 使用查询信号AT指令: AT+CSQ +CSQ: 21,99 OK 这个AT指令使用都是了解的,但是+CSQ: 21,99,后面的数字代表什么意思呢? 怎么看是信号强弱还是没有信号呢? 接下来开始总结: 一、查看芯片手册 我查看的是 SIM7500_SIM7600 Series_AT Command Manual _V1.06 下载:SIM7600 技术文档 其他模块的可能有些许不一样。 芯片手册上有关于AT+CSQ的介绍: 描述 该命令用于从ME返回接收信号强度指示和信道误码率。 测试命令将TA支持的值作为复合值返回。 命令 信号强度指示 信道误
[单片机]
<font color='red'>STM32</font>开发 -- 信号强度CSQ
STM32中的SPI总线介绍
SPI总线概述 SPI总线介绍 SPI是由摩托罗拉(Motorola)公司开发的全双工同步串行总线,是微处理控制单元(MCU)和外围设备之间进行通信的同步串行端口。主要应用在EEPROM、Flash、实时时钟(RTC)、数模转换器(ADC)、网络控制器、MCU、数字信号处理器(DSP)以及数字信号解码器之间。 SPI总线接口和物理拓扑结构 接口: 五线制接口(四线SPI):全双工 MOSI(主出从入)、MISO(主入从出)、SCK、CS、GND 四线制接口(三线SPI):半双工 IO(双向通信数据线)、SCK、CS、GND 物理拓扑结构:支持一主多从,依靠片选线区分从设备,每增加一个从设备就要增加一个片选线,消耗一个IO口。
[单片机]
<font color='red'>STM32</font>中的SPI总线介绍
ARM学习《八》——STM32定时器配置及其中断设置!
好久没有写东西了,工作太忙都快没时间学习了。今天调试了STM32的定时器功能,STM32定时器比较多,但调试都是一样的,寄存器都是一一对应的。就拿TIM2举例说明。在网上搜了好多关于定时器的设置,但大多数都是一个版本,而且都是针对库函数操作的,让人看起来一头雾水,对于初学者很是不利(我也是初学者)。下面我将自己的定时器设置过程一一记录下来,以供大家参考,我们共同学习 首先定义定时器头文件,也就是定义寄存器以供操作: //************************************************************************* // // TIM2-Register //
[单片机]
STM32中断理解
题外话: 几乎所有的要学习的实在或虚拟的事物(或仅仅是一个理论)都可以用下面的方法对其了解; 但对于具体某一个事物不一定需要全部研究下面的项目; 什么是XXX 为什么要XXX XXX的分类 XXX的组成 XXX的特点 XXX的流程 用及XXX时注意事项 其他特有项目 ----------------------------------------------- stm32中断主题: 1 什么是中断 暂停原先的程序或事情,执行另外一些程序或事情,执行完成后返回原来的程序。 2 为什么要中断 因为另一些程序或事情比你原先正在做的事情要重要,或者这些突发事情你是无法控制它的来临的。 3 中断的分类 按不同方法进行分类 3.1 内部中
[单片机]
工作问题笔记-----STM32休眠问题
STM32低功耗分三种: SLEEP: 电压调节器开启,Cortex-M3内核停止运行,外设保持运行态; STOP: 电压调节器可选择性开启,所有外设时钟、PLL、HSI和HSE被关闭,Cortex-M3内核和所有外设停止运行,保留SRAM和寄存器的内容; STANDBY: 待机模式Standby:电压调节器关闭、整个1.8v区域断电。除了备份区域和待机电路的寄存器以外,SRAM和寄存器的内容全部丢失。 在休眠状态下,MCU的代码并不会继续执行,而是进入休眠状态,等待唤醒,唤醒的过程会先执行IRQ中断服务函数,然后再执行WFI后的函数。 省电级别由低到高,standby休眠后会让我们的数据丢失,而SLEE
[单片机]
STM32的I2C通信
I2C总线是由NXP(原PHILIPS)公司设计,有十分简洁的物理层定义,其特性如下: 只要求两条总线线路:一条串行数据线SDA,一条串行时钟线SCL; 每个连接到总线的器件都可以通过唯一的地址和一直存在的简单的主机/从机关系软件设定地址,主机可以作为主机发送器或主机接收器; 它是一个真正的多主机总线,如果两个或更多主机同时初始化,数据传输可以通过冲突检测和仲裁防止数据被破坏; 串行的8 位双向数据传输位速率在标准模式下可达100kbit/s,快速模式下可达400kbit/s,高速模式下可达3.4Mbit/s; 连接到相同总线的IC 数量只受到总线的最大电容400pF 限制。 其典型的接口连线如下:
[单片机]
<font color='red'>STM32</font>的I2C通信
工程师STM32单片机学习基础手记(4):用PWM实现荧火虫灯(五)
按SW方式来调试      1脚不接时出现的画面      DMA初步   DMA有什么用?   直接存储器存取用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU的干预,通过DMA数据可以快速地移动。这就节省了CPU的资源来做其他操作。   有多少个DMA资源   有两个DMA控制器,DMA1有7个通道,DMA2有5个通道。   数据从什么地方送到什么地方?   外设到SRAM(I2C/UART等获取数据并送入SRAM);   SRAM的两个区域之间;   外设到外设(ADC读取数据后送到TIM1控制其产生不同的PWM占空比);   SRAM到外设(SRAM中预先保存的数据送入DA
[模拟电子]
工程师<font color='red'>STM32</font>单片机学习基础手记(4):用PWM实现荧火虫灯(五)
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved