Skip to content
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

How to simulate DHT22 and use it with RP2040 to read temperature and humidity? #127

Closed
TBWXY777 opened this issue Apr 19, 2023 · 3 comments

Comments

@TBWXY777
Copy link

TBWXY777 commented Apr 19, 2023

Hi, I am trying to use the DHT22 temperature and humidity sensor with RP2040, and I want to simulate the sensor.
I am hoping to find some guidance on how to simulate the DHT22 sensor and use it with RP2040 to read temperature and humidity. I have attached my current Arduino code below:

#include "DHT.h"

#define GPIOPIN 2
#define DHTTYPE DHT22

DHT dht(GPIOPIN, DHTTYPE);

void setup() {
  Serial1.begin(9600);
  dht.begin();
}

void loop() {
  delay(200);
  float h = dht.readHumidity();
  float t = dht.readTemperature();
  Serial1.print("Humidity: ");
  Serial1.print(h);
  Serial1.print("%  Temperature: ");
  Serial1.print(t);
  Serial1.println("°C");
}

I have seen DHT22 on both wokwi-elements and the Wokwi platform, but I am not sure how it interacts with RP2040.
Thank you very much for your help!

@TBWXY777 TBWXY777 reopened this Apr 19, 2023
@urish
Copy link
Contributor

urish commented Apr 20, 2023

Hello, nice to meet you!

I'm curious, what are you building?

Re DHT22 - you'll have to implement the protocol. Since the protocol is timing sensitive, I suggest to wait a bit until I have a chance to push the clock changes for wokwi/wokwi-features#186 (see my comment here).

Another way to go about this would be to read the symbols from the ELF file, intercept the calls to readHumidity() and readTemperature(), and return a fake value instead of calling the actual code. You could do it by replacing the blTaken() hook with your own implementation that would compare the PC value with the symbol you read from the ELF file, and in case of a match will put the return value in the relevant register (r0, if I'm not wrong), and update PC with the value of LR to immediately return from the call.

@TBWXY777
Copy link
Author

Hello, nice to meet you!

I'm curious, what are you building?

Re DHT22 - you'll have to implement the protocol. Since the protocol is timing sensitive, I suggest to wait a bit until I have a chance to push the clock changes for wokwi/wokwi-features#186 (see my comment here).

Another way to go about this would be to read the symbols from the ELF file, intercept the calls to readHumidity() and readTemperature(), and return a fake value instead of calling the actual code. You could do it by replacing the blTaken() hook with your own implementation that would compare the PC value with the symbol you read from the ELF file, and in case of a match will put the return value in the relevant register (r0, if I'm not wrong), and update PC with the value of LR to immediately return from the call.

I am glad to receive your reply. I am not building anything, I am just curious about the components of wokwi-elements. Recently, I successfully simulated the interaction between LCD1602 and PICO of wokwi-elements, which I found very interesting. Therefore, I want to try simulating DHT22. However, simulating DHT22 is a bit difficult for a beginner like me. Your suggestions have given me a lot of inspiration. Thank you very much.

@urish
Copy link
Contributor

urish commented Apr 23, 2023

Good luck!

@urish urish closed this as completed Apr 23, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants