BMP085 STM32
- 基于STM32f103的BMP085气压计的检测
- #ifndef __BMP085_H
- #define __BMP085_H
- #include "sys.h"
-
- #define BMP085_SlaveAddress 0xee
- #define OSS 0
-
- #define SDA_IN() {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)8<<28;}
- #define SDA_OUT() {GPIOB->CRL&=0X0FFFFFFF;GPIOB->CRL|=(u32)3<<28;}
- #define IIC_SCL PBout(6)
- #define IIC_SDA PBout(7)
- #define READ_SDA PBin(7)
-
- void IIC_Init(void);
- void IIC_Start(void);
- void IIC_Stop(void);
- void IIC_Send_Byte(u8 txd);
- u8 IIC_Read_Byte(unsigned char ack);
- u8 IIC_Wait_Ack(void);
- void IIC_Ack(void);
- void IIC_NAck(void);
- void IIC_Write_One_Byte(u8 daddr,u8 addr,u8 data);
- u8 IIC_Read_One_Byte(u8 daddr,u8 addr);
- void bmp085Convert(void);
- void Init_BMP085(void);
- long bmp085ReadPressure(void);
- long bmp085ReadTemp(void);
- short Multiple_read(u8 ST_Address);
- double BMP085_Get_Altitude(long Pressure);
- #endif
- #include
-
- short ac1;
- short ac2;
- short ac3;
- unsigned short ac4;
- unsigned short ac5;
- unsigned short ac6;
- short b1;
- short b2;
- short mb;
- short mc;
- short md;
- long temperature = 0;
- long pressure = 0;
-
- void IIC_Init(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOB, ENABLE );
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- GPIO_Init(GPIOB, &GPIO_InitStructure);
- GPIO_SetBits(GPIOB,GPIO_Pin_6|GPIO_Pin_7);
- }
-
- void IIC_Start(void)
- {
- SDA_OUT();
- IIC_SDA=1;
- IIC_SCL=1;
- Delay_us(4);
- IIC_SDA=0;
- Delay_us(4);
- IIC_SCL=0;
- }
-
- void IIC_Stop(void)
- {
- SDA_OUT();
- IIC_SCL=0;
- IIC_SDA=0;
- Delay_us(4);
- IIC_SCL=1;
- Delay_us(4);
- IIC_SDA=1;
- Delay_us(4);
- }
-
- u8 IIC_Wait_Ack(void)
- {
- u8 ucErrTime=0;
- SDA_IN();
- IIC_SDA=1;Delay_us(1);
- IIC_SCL=1;Delay_us(1);
- while(READ_SDA)
- {
- ucErrTime++;
- if(ucErrTime>250)
- {
- IIC_Stop();
- return 1;
- }
- }
- IIC_SCL=0;
- return 0;
- }
-
- void IIC_Ack(void)
- {
- IIC_SCL=0;
- SDA_OUT();
- IIC_SDA=0;
- Delay_us(2);
- IIC_SCL=1;
- Delay_us(2);
- IIC_SCL=0;
- }
-
- void IIC_NAck(void)
- {
- IIC_SCL=0;
- SDA_OUT();
- IIC_SDA=1;
- Delay_us(2);
- IIC_SCL=1;
- Delay_us(2);
- IIC_SCL=0;
- }
-
- void IIC_Send_Byte(u8 txd)
- {
- u8 t;
- SDA_OUT();
- IIC_SCL=0;
- for(t=0;t<8;t++)
- {
- if((txd&0x80)>>7)
- IIC_SDA=1;
- else
- IIC_SDA=0;
- txd<<=1;
- Delay_us(2);
- IIC_SCL=1;
- Delay_us(2);
- IIC_SCL=0;
- Delay_us(2);
- }
- }
-
- u8 IIC_Read_Byte(unsigned char ack)
- {
- unsigned char i,receive=0;
- SDA_IN();
- for(i=0;i<8;i++ )
- {
- IIC_SCL=0;
- Delay_us(2);
- IIC_SCL=1;
- receive<<=1;
- if(READ_SDA)receive++;
- Delay_us(1);
- }
- if (!ack)
- IIC_NAck();
- else
- IIC_Ack();
- return receive;
- }
-
- short Multiple_read(u8 ST_Address)
- {
- u8 m***, l***;
- short _data;
- IIC_Start();
- IIC_Send_Byte(BMP085_SlaveAddress);
- while(IIC_Wait_Ack());
- IIC_Send_Byte(ST_Address);
- while(IIC_Wait_Ack()){}
- IIC_Start();
- IIC_Send_Byte(BMP085_SlaveAddress+1);
- while(IIC_Wait_Ack()){}
- m*** = IIC_Read_Byte(1);
- l*** = IIC_Read_Byte(0);
- IIC_Stop();
- Delay_ms(5);
- _data = m*** << 8;
- _data |= l***;
- return _data;
- }
-
- //********************************************************************
- long bmp085ReadTemp(void)
- {
- IIC_Start();
- IIC_Send_Byte(BMP085_SlaveAddress);
- while(IIC_Wait_Ack()){}
- IIC_Send_Byte(0xF4);
- while(IIC_Wait_Ack()){}
- IIC_Send_Byte(0x2E);
- while(IIC_Wait_Ack()){}
- IIC_Stop();
- Delay_ms(10);
- return (long) Multiple_read(0xF6);
- }
- //*************************************************************
- long bmp085ReadPressure(void)
- {
- long pressure = 0;
- IIC_Start();
- IIC_Send_Byte(BMP085_SlaveAddress);
- while(IIC_Wait_Ack()){}
- IIC_Send_Byte(0xF4);
- while(IIC_Wait_Ack()){}
- IIC_Send_Byte(0x34);
- while(IIC_Wait_Ack()){}
- IIC_Stop();
- Delay_ms(10);
- pressure = Multiple_read(0xF6);
- pressure &= 0x0000FFFF;
- return pressure;
- }
-
- void Init_BMP085()
- {
- ac1 = Multiple_read(0xAA);
- ac2 = Multiple_read(0xAC);
- ac3 = Multiple_read(0xAE);
- ac4 = Multiple_read(0xB0);
- ac5 = Multiple_read(0xB2);
- ac6 = Multiple_read(0xB4);
- b1 = Multiple_read(0xB6);
- b2 = Multiple_read(0xB8);
- mb = Multiple_read(0xBA);
- mc = Multiple_read(0xBC);
- md = Multiple_read(0xBE);
- }
-
- //***********************************************************************
- void bmp085Convert()
- {
- unsigned int ut;
- unsigned long up;
- long x1, x2, b5, b6, x3, b3, p;
- unsigned long b4, b7;
-
- ut = bmp085ReadTemp();
- up = bmp085ReadPressure();
- x1 = (((long)ut - (long)ac6)*(long)ac5) >> 15;
- x2 = ((long) mc << 11) / (x1 + md);
- b5 = x1 + x2;
- temperature = ((b5 + 8) >> 4);
- b6 = b5 - 4000;
- x1 = (b2 * (b6 * b6)>>12)>>11;
- x2 = (ac2 * b6)>>11;
- x3 = x1 + x2;
- b3 = (((((long)ac1)*4 + x3)<>2;
- x1 = (ac3 * b6)>>13;
- x2 = (b1 * ((b6 * b6)>>12))>>16;
- x3 = ((x1 + x2) + 2)>>2;
- b4 = (ac4 * (unsigned long)(x3 + 32768))>>15;
- b7 = ((unsigned long)(up - b3) * (50000>>OSS));
- if (b7 < 0x80000000)
- p = (b7<<1)/b4;
- else
- p = (b7/b4)<<1;
- x1 = (p>>8) * (p>>8);
- x1 = (x1 * 3038)>>16;
- x2 = (-7357 * p)>>16;
- pressure = p+((x1 + x2 + 3791)>>4);
- }
-
-
- double BMP085_Get_Altitude(long Pressure)
- {
- double altitude;
- altitude=44330.0*(1-pow((double)Pressure/101325,1/5.255));
- altitude*=100;
- return altitude;
更多回帖