ESPHome 2026.5.0-dev
Loading...
Searching...
No Matches
max6675.cpp
Go to the documentation of this file.
1#include "max6675.h"
2#include "esphome/core/log.h"
3
4namespace esphome {
5namespace max6675 {
6
7static const char *const TAG = "max6675";
8
10 this->enable();
11 delay(1);
12 // conversion initiated by rising edge
13 this->disable();
14
15 // Conversion time typ: 170ms, max: 220ms
16 this->set_timeout("value", 250, [this]() { this->read_data_(); });
17}
18
21 LOG_SENSOR("", "MAX6675", this);
22 LOG_PIN(" CS Pin: ", this->cs_);
23 LOG_UPDATE_INTERVAL(this);
24}
26 this->enable();
27 delay(1);
28 uint8_t data[2];
29 this->read_array(data, 2);
30 uint16_t val = data[1] | (uint16_t(data[0]) << 8);
31 this->disable();
32
33 if ((val & 0x04) != 0) {
34 // Thermocouple open
35 ESP_LOGW(TAG, "Got invalid value from MAX6675Sensor (0x%04X)", val);
36 this->status_set_warning();
37 return;
38 }
39
40 float temperature = float(val >> 3) / 4.0f;
41 ESP_LOGD(TAG, "'%s': Got temperature=%.1f°C", this->name_.c_str(), temperature);
42 this->publish_state(temperature);
44}
45
46} // namespace max6675
47} // namespace esphome
ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") void set_timeout(const std voi set_timeout)(const char *name, uint32_t timeout, std::function< void()> &&f)
Set a timeout function with a unique name.
Definition component.h:510
void status_clear_warning()
Definition component.h:306
constexpr const char * c_str() const
Definition string_ref.h:73
void publish_state(float state)
Publish a new state to the front-end.
Definition sensor.cpp:68
mopeka_std_values val[3]
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7
void HOT delay(uint32_t ms)
Definition core.cpp:28
uint16_t temperature
Definition sun_gtil2.cpp:12