首先是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(); } } #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"
上一篇:关于时钟晶振 速率 倍频
下一篇:串口接收数据并对数据进行处理
推荐阅读
史海拾趣
蓝箭电子始终致力于技术创新和产品升级。随着科技的进步,公司不断引进先进的生产线和技术,推出了各种封装的双极型晶体管、晶闸管、集成电路等产品。这些产品广泛应用于家用电器、电源、IT数码、通信等多个领域,满足了市场的多样化需求。
DLP联合科技公司,通过与国内外知名企业的技术合作,实现了技术的快速迭代和产品的升级换代。公司积极寻求与产业链上下游企业的合作机会,共同研发新技术、新产品。通过与合作伙伴的紧密合作,DLP联合科技在DLP技术领域取得了显著成果,为电子行业的发展做出了积极贡献。
随着公司产品的技术成熟和品质提升,Esterline Power Systems开始寻求国际市场的拓展。公司高层制定了明确的国际化战略,包括在欧洲和亚洲设立分支机构,与当地合作伙伴建立紧密的合作关系。通过参展国际航空展、加强与全球航空公司的技术交流与合作,公司逐渐打开了国际市场的大门,产品销售遍及全球多个国家和地区。
面对激烈的市场竞争和行业变革,达利凯普积极推进数字化转型和产业升级。公司引入了先进的生产设备和管理系统,实现了生产过程的自动化和智能化。同时,公司还加大了对新材料、新工艺的研发力度,不断提升产品的性能和品质。这些举措使达利凯普在激烈的市场竞争中保持了领先地位,也为公司的持续发展奠定了坚实基础。
大连达利凯普科技股份公司自成立以来,始终坚持自主创新和技术研发。公司拥有一支专业的研发团队,致力于射频微波磁介电容器(射频微波MLCC)的研发和生产。通过不懈努力,公司成功掌握了射频微波MLCC的关键核心技术,并获得了全部自主知识产权。这一技术突破不仅使达利凯普在行业内树立了技术领先地位,也为公司赢得了广泛的市场认可。
为了进一步推动其技术在建筑行业的应用,EnOcean发起并建立了EnOcean联盟。该联盟由来自建筑行业的400多家公司组成,致力于推广基于EnOcean无线标准的免维护无线解决方案。通过与联盟成员的合作,EnOcean不断拓展其市场份额,并为智慧楼宇及能源管理提供更稳定的硬件解决方案。
在单片机应用开发中,代码的使用效率问题、单片机抗干扰性和可靠性等问题仍困扰着工程师。为帮助工程师解决单片机设计上的难题,《电子工程专辑》网站特邀Holtek香港分公司工程部处长邓宏杰先生担任《单片机应用编程技巧》专题讨论的嘉宾,与广大设 ...… 查看全部问答∨ |
随着电力电子技术的高速发展,电力电子设备与人们的工作、生活的关系日益密切,而电子设备都离不开可靠的电源,进入80年代计算机电源全面实现了开关电源化,率先完成计算机的电源换代,进入90年代开关电源相继进入各种电子、电器设备领域,程控交换 ...… 查看全部问答∨ |
请教下一个可实现的3G系统(比如WCDMA)的具体构成是怎样的? 偶是通信专业的,考研想考WCDMA。感觉大学学的知识比较零碎。想请教下一个现实的3G系统的构成是怎样的?这个问题可能比较白。 有很多疑问比如: 现实的3G系统与用户终端之间的信息交换的过程? 假设只是单单移动电话方面的应用是大概构成 ...… 查看全部问答∨ |
我刚开始学c8051f040,我想知道一下,怎样给040芯片内部烧写程序呢,我有一个仿真器,可是我不知道该怎么用,还有那个编程器是做什么用的,高手能不能给我把烧写程序的步骤说一下,要一步一步操作的 谢谢… 查看全部问答∨ |
用VC++ 6.0写的程序,现在要用EVC 4.0打开,并且进行调试现生成新的应用程序,可以实现吗? 可以的话要怎么操作? 要是不可以的话,要对VC++ 6.0写的程序进行怎样的转化呢? 谢谢 … 查看全部问答∨ |
|
我用FET编写的.S43,现在想在MSP-GANG430中使用。 不过后者只接受.txt和.A43文件, 我该怎么办?有没有什么办法把.S43文件转换成.A43文件啊,请各位大侠不吝赐教!… 查看全部问答∨ |