Hi everybody,
Edit: 02.01.2021 10:33 **
finally got the sensor working. The BME280 turned out to be a BMP**280
So with a BMP280-library from adafruit and with a modified call of the begin-method
bmp.begin(0x76,0x58)) { // I2C-adress , Chip-ID
I was able to read the sensor data.
original post:
I'm testing a BME280-I2C-Sensor with a ESP8266-Wemos D1 Mini-board.
As a first test I used this democode from adafruit
/***************************************************************************
This is a library for the BME280 humidity, temperature & pressure sensor
Designed specifically to work with the Adafruit BME280 Breakout
----> http://www.adafruit.com/products/2650
These sensors use I2C or SPI to communicate, 2 or 4 pins are required
to interface. The device's I2C address is either 0x76 or 0x77.
Adafruit invests time and resources providing this open source code,
please support Adafruit andopen-source hardware by purchasing products
from Adafruit!
Written by Limor Fried & Kevin Townsend for Adafruit Industries.
BSD license, all text above must be included in any redistribution
See the LICENSE file for details.
***************************************************************************/
#include <Wire.h>
#include <SPI.h>
#include <Adafruit_Sensor.h>
#include <Adafruit_BME280.h>
#define BME_SCK 13
#define BME_MISO 12
#define BME_MOSI 11
#define BME_CS 10
#define SEALEVELPRESSURE_HPA (1013.25)
Adafruit_BME280 bme; // I2C
//Adafruit_BME280 bme(BME_CS); // hardware SPI
//Adafruit_BME280 bme(BME_CS, BME_MOSI, BME_MISO, BME_SCK); // software SPI
unsigned long delayTime;
void setup() {
Serial.begin(9600);
while(!Serial); // time to get serial running
Serial.println(F("BME280 test"));
unsigned status;
// default settings
status = bme.begin(0x76); //status = bme.begin();
// You can also pass in a Wire library object like &Wire2
// status = bme.begin(0x76, &Wire2)
if (!status) {
Serial.println("Could not find a valid BME280 sensor, check wiring, address, sensor ID!");
Serial.print("SensorID was: 0x"); Serial.println(bme.sensorID(),16);
Serial.print(" ID of 0xFF probably means a bad address, a BMP 180 or BMP 085\n");
Serial.print(" ID of 0x56-0x58 represents a BMP 280,\n");
Serial.print(" ID of 0x60 represents a BME 280.\n");
Serial.print(" ID of 0x61 represents a BME 680.\n");
while (1) delay(10);
}
Serial.println("-- Default Test --");
delayTime = 1000;
Serial.println();
}
void loop() {
printValues();
delay(delayTime);
}
void printValues() {
Serial.print("Temperature = ");
Serial.print(bme.readTemperature());
Serial.println(" *C");
Serial.print("Pressure = ");
Serial.print(bme.readPressure() / 100.0F);
Serial.println(" hPa");
Serial.print("Approx. Altitude = ");
Serial.print(bme.readAltitude(SEALEVELPRESSURE_HPA));
Serial.println(" m");
Serial.print("Humidity = ");
Serial.print(bme.readHumidity());
Serial.println(" %");
Serial.println();
}
in the serial monitor I get this as result
23:17:42.804 -> Could not find a valid BME280 sensor, check wiring, address, sensor ID!
23:17:42.898 -> SensorID was: 0x58
23:17:42.945 -> ID of 0xFF probably means a bad address, a BMP 180 or BMP 085
23:17:42.992 -> ID of 0x56-0x58 represents a BMP 280,
23:17:43.039 -> ID of 0x60 represents a BME 280.
23:17:43.086 -> ID of 0x61 represents a BME 680.
So I connected a logic-analyser to look and decode the bitbanging in the I2C-Bus
THe result of the logic analyser shows that the request with I2C-Adress results in an ACK
Adresswrite gets an ACK
Datawrite gets an ACK
ADressread gets an ACK
Dataread works but and retrieves a 0x58 but I get a NACK
The "N" in the protocol-anaylser.
I'm not familiar with th ebitbanging details of the I2C-Bus.
see attached picture.
Does anybody know what the reason could be that reading the sensordata does not work?
best regards Stefan