ESPHome 2026.1.3
Loading...
Searching...
No Matches
gpio.h
Go to the documentation of this file.
1#pragma once
2#include <algorithm>
3#include <cstdint>
4#include <cstring>
5#include <string>
6
8#include "esphome/core/log.h"
9
10namespace esphome {
11
13inline constexpr size_t GPIO_SUMMARY_MAX_LEN = 48;
14
15#ifdef USE_ESP8266
16#define LOG_PIN(prefix, pin) log_pin(TAG, F(prefix), pin)
17#else
18#define LOG_PIN(prefix, pin) log_pin(TAG, prefix, pin)
19#endif
20
21// put GPIO flags in a namespace to not pollute esphome namespace
22namespace gpio {
23
24enum Flags : uint8_t {
25 // Can't name these just INPUT because of Arduino defines :(
26 FLAG_NONE = 0x00,
27 FLAG_INPUT = 0x01,
32};
33
35 public:
36 constexpr FlagsHelper(Flags val) : val_(val) {}
37 constexpr operator Flags() const { return val_; }
38
39 protected:
41};
42constexpr FlagsHelper operator&(Flags lhs, Flags rhs) {
43 return static_cast<Flags>(static_cast<uint8_t>(lhs) & static_cast<uint8_t>(rhs));
44}
45constexpr FlagsHelper operator|(Flags lhs, Flags rhs) {
46 return static_cast<Flags>(static_cast<uint8_t>(lhs) | static_cast<uint8_t>(rhs));
47}
48
56
57} // namespace gpio
58
59class GPIOPin {
60 public:
61 virtual void setup() = 0;
62
63 virtual void pin_mode(gpio::Flags flags) = 0;
64
70 virtual gpio::Flags get_flags() const = 0;
71
72 virtual bool digital_read() = 0;
73
74 virtual void digital_write(bool value) = 0;
75
81 virtual size_t dump_summary(char *buffer, size_t len) const;
82
85 ESPDEPRECATED("Override dump_summary(char*, size_t) instead. Will be removed in 2026.7.0.", "2026.1.0")
86 virtual std::string dump_summary() const;
87
88 virtual bool is_internal() { return false; }
89};
90
93 public:
94 ISRInternalGPIOPin() = default;
95 ISRInternalGPIOPin(void *arg) : arg_(arg) {}
96 bool digital_read();
97 void digital_write(bool value);
98 void clear_interrupt();
100
101 protected:
102 void *arg_{nullptr};
103};
104
105class InternalGPIOPin : public GPIOPin {
106 public:
107 template<typename T> void attach_interrupt(void (*func)(T *), T *arg, gpio::InterruptType type) const {
108 this->attach_interrupt(reinterpret_cast<void (*)(void *)>(func), arg, type);
109 }
110
111 virtual void detach_interrupt() const = 0;
112
113 virtual ISRInternalGPIOPin to_isr() const = 0;
114
115 virtual uint8_t get_pin() const = 0;
116
117 bool is_internal() override { return true; }
118
119 virtual bool is_inverted() const = 0;
120
121 protected:
122 virtual void attach_interrupt(void (*func)(void *), void *arg, gpio::InterruptType type) const = 0;
123};
124
125// Inline default implementations for GPIOPin virtual methods.
126// These provide bridge functionality for backwards compatibility with external components.
127
128// Default implementation bridges to old std::string method for backwards compatibility.
129inline size_t GPIOPin::dump_summary(char *buffer, size_t len) const {
130 if (len == 0)
131 return 0;
132#pragma GCC diagnostic push
133#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
134 std::string s = this->dump_summary();
135#pragma GCC diagnostic pop
136 size_t copy_len = std::min(s.size(), len - 1);
137 memcpy(buffer, s.c_str(), copy_len);
138 buffer[copy_len] = '\0';
139 return s.size(); // Return would-be length (snprintf semantics)
140}
141
142// Default implementation returns empty string.
143// External components should override this if they haven't migrated to buffer-based version.
144// Remove before 2026.7.0
145inline std::string GPIOPin::dump_summary() const { return {}; }
146
147// Inline helper for log_pin - allows compiler to inline into log_pin in gpio.cpp
148inline void log_pin_with_prefix(const char *tag, const char *prefix, GPIOPin *pin) {
149 char buffer[GPIO_SUMMARY_MAX_LEN];
150 size_t len = pin->dump_summary(buffer, sizeof(buffer));
151 len = std::min(len, sizeof(buffer) - 1);
152 esp_log_printf_(ESPHOME_LOG_LEVEL_CONFIG, tag, __LINE__, "%s%.*s", prefix, (int) len, buffer);
153}
154
155// log_pin function declarations - implementation in gpio.cpp
156#ifdef USE_ESP8266
157void log_pin(const char *tag, const __FlashStringHelper *prefix, GPIOPin *pin);
158#else
159void log_pin(const char *tag, const char *prefix, GPIOPin *pin);
160#endif
161
162} // namespace esphome
virtual void pin_mode(gpio::Flags flags)=0
virtual void setup()=0
virtual void digital_write(bool value)=0
virtual ESPDEPRECATED("Override dump_summary(char*, size_t) instead. Will be removed in 2026.7.0.", "2026.1.0") virtual std boo is_internal)()
Get a summary of this pin as a string.
Definition gpio.h:88
virtual gpio::Flags get_flags() const =0
Retrieve GPIO pin flags.
virtual bool digital_read()=0
virtual size_t dump_summary(char *buffer, size_t len) const
Write a summary of this pin to the provided buffer.
Definition gpio.h:129
Copy of GPIOPin that is safe to use from ISRs (with no virtual functions)
Definition gpio.h:92
ISRInternalGPIOPin(void *arg)
Definition gpio.h:95
void digital_write(bool value)
Definition gpio.cpp:148
void pin_mode(gpio::Flags flags)
Definition gpio.cpp:157
virtual uint8_t get_pin() const =0
bool is_internal() override
Definition gpio.h:117
virtual void detach_interrupt() const =0
void attach_interrupt(void(*func)(T *), T *arg, gpio::InterruptType type) const
Definition gpio.h:107
virtual bool is_inverted() const =0
virtual ISRInternalGPIOPin to_isr() const =0
virtual void attach_interrupt(void(*func)(void *), void *arg, gpio::InterruptType type) const =0
constexpr FlagsHelper(Flags val)
Definition gpio.h:36
uint16_t type
uint16_t flags
mopeka_std_values val[4]
@ INTERRUPT_FALLING_EDGE
Definition gpio.h:51
@ INTERRUPT_RISING_EDGE
Definition gpio.h:50
@ INTERRUPT_HIGH_LEVEL
Definition gpio.h:54
@ INTERRUPT_LOW_LEVEL
Definition gpio.h:53
@ INTERRUPT_ANY_EDGE
Definition gpio.h:52
@ FLAG_OUTPUT
Definition gpio.h:28
@ FLAG_OPEN_DRAIN
Definition gpio.h:29
@ FLAG_NONE
Definition gpio.h:26
@ FLAG_PULLUP
Definition gpio.h:30
@ FLAG_INPUT
Definition gpio.h:27
@ FLAG_PULLDOWN
Definition gpio.h:31
constexpr FlagsHelper operator|(Flags lhs, Flags rhs)
Definition gpio.h:45
constexpr FlagsHelper operator&(Flags lhs, Flags rhs)
Definition gpio.h:42
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7
void HOT esp_log_printf_(int level, const char *tag, int line, const char *format,...)
Definition log.cpp:11
std::string size_t len
Definition helpers.h:595
void log_pin_with_prefix(const char *tag, const char *prefix, GPIOPin *pin)
Definition gpio.h:148
constexpr size_t GPIO_SUMMARY_MAX_LEN
Maximum buffer size for dump_summary output.
Definition gpio.h:13
struct ESPDEPRECATED("Use std::index_sequence instead. Removed in 2026.6.0", "2025.12.0") seq
Definition automation.h:24
void log_pin(const char *tag, const __FlashStringHelper *prefix, GPIOPin *pin)
Definition gpio.cpp:7