-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
SPI Example #26
Comments
The error rises due the mismatch of sensor id check in the init: https://github.com/pezi/dart_periphery/blob/main/lib/src/hardware/bme280.dart
My I2C BME280 has also contact points for SPI, but due to my lack of soldering skills, I tested only the SPI loop device. Is this SPI loop example working for you? |
Hi, thanks for getting back to me. I too don't solder well but was able to get the header pins with wires solder well to the BME you all recommend from Seeed Studio. I went through the usual stuff in the terminal command line to verify SPI was set up and even tried the other three SPI configurations using the dtoverlay in the config.txt. I built the c-periphery code and used their SPI test code which includes a loop back. I have not used the loopback you show. |
Hi, I tried the spi_loopback.dart and it works fine. |
Do you think that you can test your SPI BME280 and work out what the issues are? |
Hi, if you all don't have time to work on this can you give me some bread crumbs to help me find the root cause? If I fix it what next? |
Sorry for the late answer, because of work I am working on an other location with limited hardware. End of month I am back to my main working location - than I am an able to build up a SPI test environment. |
No worries, thanks for the help. I am building an online class embedded Flutter class that leverages this package and have everything that I need working except SPI. In the future, I want to add more I2C devices (A/D IC for example) and from my read of the software I think that I understand some of the code. How would the logistics of that work out to add it to the package? |
Hi, I was wondering if this was fixed in your latest release. |
I also wondering, because I am not aware, that I changed anything in this area. But I will look, if there was a code change over the time, which was a possible fix. |
I am waiting for the fix concerning the issue I reported on June 18th. Please let me know if you are going to fix the problem. I am working on an online class that will use SPI. Thanks, |
I have tested the simple example for SPI using the same BME280 you recommended.
It is not working - the error is "unknown model"
Linux kernel: Linux 6.6.31+rpt-rpi-v8 aarch64
Setup using raspi-config and added the dtoverlay shown below to config.txt
I have used the https://github.com/rm-hull/spidev-test to do a loop back test on /dev/spidev0.0 and the loop back is working as expected.
GPIO 9 MISO to GPIO 10 MOSI
config.txt has these lines included:
dtparam=spi=on,
dtoverlay=spi1-2cs,cs0_pin=18,cs1_pin=17
cs0_spidev=enable
cs1_spidev=enable
ran this on terminal: ls -l /dev/spi* and spidev0.0 to 1.1 are all showing
Wiring:
GPIO 9 MISO to SDO on module
GPIO 10 MOSI to SDI on module
GPIO 11 SCLK to SCK on module
CS on module to ground (tried it open also)
Tried switching SDI and SDO but still did not work.
Not sure if anyone is monitoring the package but any help would be great.
Here is my code, I added a catch to the try block so I could see the error.
import 'package:dart_periphery/dart_periphery.dart';
import 'package:flutter/foundation.dart';
void main() {
var spi = SPI(0, 0, SPImode.mode0, 1000000);
try {
debugPrint('SPI info:${spi.getSPIinfo()}');
var bme280 = BME280.spi(spi);
var r = bme280.getValues();
debugPrint('Temperature [°] ${r.temperature.toStringAsFixed(1)}');
debugPrint('Humidity [%] ${r.humidity.toStringAsFixed(1)}');
debugPrint('Pressure [hPa] ${r.pressure.toStringAsFixed(1)}');
} catch (e) {
debugPrint("Error is: $e");
} finally {
spi.dispose();
}
}
The text was updated successfully, but these errors were encountered: