本程序首要完结DS18B20温度传感器数据获取,并运用串口通讯把温度数据传至计算机
注:运用普中科技开发板测验时,需求拔掉Boot1插口,由于用到的是PA15管脚, 由开发板电路图可知,需求改动PA15管脚的映射,将其设置成一般IO口
参考资料
DS18B20中文手册.pdf http://download.csdn.net/detail/leytton/7742193
STM32-外设篇 视频教程(Cortex-M3)-主讲人:刘洋 http://yun.baidu.com/pcloud/album/info?uk=2853967793&album_id=5492137931588632574
main.c
/** * 软件功用: DS18B20温度传感器* */#include "stm32f10x.h"#include#include "delay.h"#include "ds18b20.h"void RCC_Configuration(void);void GPIO_Configuration(void);void USART1_Configuration(void);void Uart1_PutChar(u8 ch);void Uart1_PutString(u8* buf , u8 len);int fputc(int ch, FILE *f);/*函数: int main(void)功用: main主函数参数: 无回来: 无/int main(void){double temperature=0;RCC_Configuration();GPIO_Configuration();delay_init(72);USART1_Configuration();while(1){ if(!DS18B20_Is_Exist()){printf("未检测到DS18B20温度传感器...\n");delay_ms(500);}else{printf("检测到DS18B20温度传感器\n获取数据中...\n");temperature=DS18B20_Get_wd();printf("当时温度:%0.4lf ℃\n\n",temperature);}}}/*函数: void RCC_Configuration(void)功用: 复位和时钟操控 装备参数: 无回来: 无/void RCC_Configuration(void){ErrorStatus HSEStartUpStatus; //界说外部高速晶体发动状况枚举变量RCC_DeInit(); //复位RCC外部设备寄存器到默许值RCC_HSEConfig(RCC_HSE_ON); //翻开外部高速晶振HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等候外部高速时钟预备好if(HSEStartUpStatus == SUCCESS) //外部高速时钟现已准别好{FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //舱位FLASH预读缓冲功用,加快FLASH的读取。一切程序中有必要的用法.方位:RCC初始化子函数晒干,时钟起振之后FLASH_SetLatency(FLASH_Latency_2); //flash操作的延时RCC_HCLKConfig(RCC_SYSCLK_Div1); //装备AHB(HCLK)时钟等于==SYSCLKRCC_PCLK2Config(RCC_HCLK_Div1); //装备APB2(PCLK2)钟==AHB时钟RCC_PCLK1Config(RCC_HCLK_Div2); //装备APB1(PCLK1)钟==AHB1/2时钟RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //装备PLL时钟 == 外部高速晶体时钟 * 9 = 72MHzRCC_PLLCmd(ENABLE); //使能PLL时钟while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) //等候PLL时钟安排妥当{}RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //装备体系时钟 = PLL时钟while(RCC_GetSYSCLKSource() != 0x08) //查看PLL时钟是否作为体系时钟{}}RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1 | RCC_APB2Periph_AFIO, ENABLE); //答应 GPIOA、USART1、AFIO时钟}/*函数: void GPIO_Configuration(void)功用: GPIO装备参数: 无回来: 无/void GPIO_Configuration(void){GPIO_InitTypeDef GPIO_InitStructure; //界说GPIO初始化结构体GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复合推挽输出 GPIO_Init(GPIOA, &GPIO_InitStructure); //PA9串口输出//把调试设置一般IO口GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable,ENABLE); // 改动指定管脚的映射 GPIO_Remap_SWJ_JTAGDisable ,JTAG-DP 禁用 + SW-DP 使能GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable , ENABLE);}/*函数名:USART1_Configuration输 入:输 出:功用阐明:初始化串口硬件设备,启用中止装备过程:(1)翻开GPIO和USART1的时钟(2)设置USART1两个管脚GPIO形式(3)装备USART1数据格式、波特率等参数(4)使能USART1接纳中止功用(5)最终使能USART1功用*/void USART1_Configuration(void) //串口装备 详见《STM32的函数阐明(中文).pdf》P346{USART_InitTypeDef USART_InitStructure;USART_InitStructure.USART_BaudRate=9600; //波特率为9600USART_InitStructure.USART_WordLength=USART_WordLength_8b; //数据位为8USART_InitStructure.USART_StopBits=USART_StopBits_1; //在帧结束传输 1 个中止位USART_InitStructure.USART_Parity=USART_Parity_No; //校验形式:奇偶失能USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None; //硬件流操控失能USART_InitStructure.USART_Mode=USART_Mode_Tx | USART_Mode_Rx; //USART_Mode 指定了使能或许失能发送和接纳形式:发送使能|接纳失能USART_Init(USART1, &USART_InitStructure); //初始化装备USART_Cmd(USART1,ENABLE); //使能或许失能 USART 外设USART_ClearFlag(USART1, USART_FLAG_TC);//铲除传输完结标志位,不然可能会丢掉第1个字节的数据.USART_FLAG_TC为发送完结标志位}//发送一个字符void Uart1_PutChar(u8 ch){USART_SendData(USART1, (u8) ch);while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);//等候发送完结}//发送一个字符串 Input : buf为发送数据的地址 , len为发送字符的个数void Uart1_PutString(u8* buf , u8 len){ u8 i;for(i=0;i DS18B20.h
#ifndef __DS18B20_H#define __DS18B20_H #include "stm32f10x.h"#define DS18B20_Pin GPIO_Pin_15#define DS18B20_GPIO GPIOA#define DS18B20_DQ_High() GPIO_SetBits(DS18B20_GPIO,DS18B20_Pin)#define DS18B20_DQ_Low() GPIO_ResetBits(DS18B20_GPIO,DS18B20_Pin)void DS18B20_IO_IN(void);void DS18B20_IO_OUT(void);u8 DS18B20_Read_Byte(void);void DS18B20_Write_Byte(u8 dat);void DS18B20_Reset(void);double DS18B20_Get_wd(void);u8 DS18B20_Is_Exist(void);#endifDS18B20.c
#include "stm32f10x.h"#include "ds18b20.h"#include "delay.h"void DS18B20_IO_IN(void){GPIO_InitTypeDef GPIO_InitStructure; //界说GPIO初始化结构体GPIO_InitStructure.GPIO_Pin = DS18B20_Pin; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //装备成上拉输入; GPIO_Init(DS18B20_GPIO, &GPIO_InitStructure);}void DS18B20_IO_OUT(void){GPIO_InitTypeDef GPIO_InitStructure; //界说GPIO初始化结构体GPIO_InitStructure.GPIO_Pin = DS18B20_Pin; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //装备成推挽输出; GPIO_Init(DS18B20_GPIO, &GPIO_InitStructure);}u8 DS18B20_Read_Byte(void){u8 i=0,TmpData=0;for(i=0;i<8;i++){TmpData>>=1; //右移DS18B20_IO_OUT(); //输出形式DS18B20_DQ_Low(); //拉低delay_us(4); //延时4usDS18B20_DQ_High(); //拉高,开释总线delay_us(10); //延时10usDS18B20_IO_IN(); //输入形式 if(GPIO_ReadInputDataBit(DS18B20_GPIO,DS18B20_Pin)== 1) TmpData |=0x80; //读取数据 ,从低位开端delay_us(45); //延时45us}return TmpData;}void DS18B20_Write_Byte(u8 dat){u8 i=0;DS18B20_IO_OUT(); //输出形式for(i=0;i<8;i++){ DS18B20_DQ_Low(); //拉低delay_us(15); //延时15usif(dat&0x01==0x01) DS18B20_DQ_High(); else DS18B20_DQ_Low();delay_us(60); //延时60usDS18B20_DQ_High(); //拉高dat>>=1; //预备下一位数据的写入}}//复位函数void DS18B20_Reset(void){DS18B20_IO_OUT(); //输出形式DS18B20_DQ_Low(); //拉低delay_us(480); //延时480usDS18B20_DQ_High();delay_us(480); //延时480us}//回来温度值double DS18B20_Get_wd(void){u8 TL=0,TH=0;u16 temp=0;double wd=0;DS18B20_Reset();//复位DS18B20_Write_Byte(0xCC); //越过ROM指令DS18B20_Write_Byte(0x44); //温度转化指令delay_ms(800);//延时800毫秒DS18B20_Reset();//复位DS18B20_Write_Byte(0xCC); //越过ROM指令DS18B20_Write_Byte(0xBE); //读温度指令TL=DS18B20_Read_Byte();//LSBTH=DS18B20_Read_Byte();//MSBtemp=TH;temp=(temp<<8)+TL;if((temp&0xF800)==0xF800)//负温度判别{temp=~temp;temp=temp+1;wd=temp*(-0.0625);}else{wd=temp*0.0625; }return wd;}//等候DS18B20的回应//回来1:检测到DS18B20的存在//回来0:不存在u8 DS18B20_Is_Exist(void) { DS18B20_IO_OUT(); //输出形式DS18B20_DQ_High(); //默许高电平DS18B20_DQ_Low(); //拉低delay_us(600); //延时600usDS18B20_DQ_High();delay_us(100); //延时100usDS18B20_IO_IN(); //输入形式if(GPIO_ReadInputDataBit(DS18B20_GPIO,DS18B20_Pin)== 0) return 1; else return 0;}