esphome 2025.5.2__py3-none-any.whl → 2025.6.0b2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- esphome/__main__.py +20 -14
- esphome/components/a4988/a4988.cpp +1 -1
- esphome/components/absolute_humidity/absolute_humidity.cpp +6 -4
- esphome/components/ac_dimmer/ac_dimmer.cpp +4 -2
- esphome/components/adc/adc_sensor_esp32.cpp +5 -3
- esphome/components/adc/adc_sensor_esp8266.cpp +5 -3
- esphome/components/adc/adc_sensor_libretiny.cpp +5 -3
- esphome/components/adc/adc_sensor_rp2040.cpp +5 -3
- esphome/components/adc128s102/adc128s102.cpp +1 -1
- esphome/components/ade7880/ade7880.cpp +28 -17
- esphome/components/ade7953_base/ade7953_base.cpp +12 -9
- esphome/components/ade7953_i2c/ade7953_i2c.cpp +1 -1
- esphome/components/ade7953_spi/ade7953_spi.cpp +1 -1
- esphome/components/ads1115/ads1115.cpp +3 -5
- esphome/components/ads1118/ads1118.cpp +2 -1
- esphome/components/ags10/ags10.cpp +3 -2
- esphome/components/aht10/aht10.cpp +27 -29
- esphome/components/aic3204/aic3204.cpp +2 -2
- esphome/components/alarm_control_panel/__init__.py +1 -0
- esphome/components/am2315c/am2315c.cpp +2 -2
- esphome/components/am2320/am2320.cpp +2 -2
- esphome/components/am43/am43_base.h +1 -1
- esphome/components/am43/cover/am43_cover.cpp +4 -2
- esphome/components/analog_threshold/analog_threshold_binary_sensor.cpp +4 -2
- esphome/components/apds9306/apds9306.cpp +8 -5
- esphome/components/apds9960/apds9960.cpp +2 -2
- esphome/components/api/__init__.py +5 -0
- esphome/components/api/api_connection.cpp +753 -379
- esphome/components/api/api_connection.h +341 -283
- esphome/components/api/api_frame_helper.cpp +349 -344
- esphome/components/api/api_frame_helper.h +121 -94
- esphome/components/api/api_pb2.cpp +3 -0
- esphome/components/api/api_pb2.h +702 -227
- esphome/components/api/api_pb2_service.cpp +12 -688
- esphome/components/api/api_pb2_service.h +53 -207
- esphome/components/api/api_server.cpp +71 -29
- esphome/components/api/api_server.h +9 -0
- esphome/components/api/client.py +5 -4
- esphome/components/api/homeassistant_service.h +1 -1
- esphome/components/api/list_entities.cpp +1 -1
- esphome/components/api/proto.cpp +1 -0
- esphome/components/api/proto.h +5 -4
- esphome/components/api/subscribe_state.cpp +8 -16
- esphome/components/as3935/as3935.cpp +3 -3
- esphome/components/as5600/as5600.cpp +9 -7
- esphome/components/as7341/as7341.cpp +7 -5
- esphome/components/at581x/at581x.cpp +13 -10
- esphome/components/atm90e26/atm90e26.cpp +2 -2
- esphome/components/atm90e32/atm90e32.cpp +3 -3
- esphome/components/axs15231/touchscreen/axs15231_touchscreen.cpp +5 -3
- esphome/components/bang_bang/bang_bang_climate.cpp +8 -5
- esphome/components/bedjet/bedjet_hub.cpp +6 -4
- esphome/components/beken_spi_led_strip/led_strip.cpp +11 -7
- esphome/components/bh1750/bh1750.cpp +2 -2
- esphome/components/binary_sensor/__init__.py +1 -0
- esphome/components/binary_sensor/automation.cpp +1 -2
- esphome/components/bl0906/bl0906.cpp +1 -1
- esphome/components/bl0942/bl0942.cpp +11 -8
- esphome/components/bl0942/sensor.py +1 -1
- esphome/components/ble_client/__init__.py +5 -1
- esphome/components/ble_client/output/ble_binary_output.cpp +6 -3
- esphome/components/ble_client/sensor/ble_sensor.cpp +9 -6
- esphome/components/ble_client/text_sensor/ble_text_sensor.cpp +8 -5
- esphome/components/bluetooth_proxy/__init__.py +5 -1
- esphome/components/bluetooth_proxy/bluetooth_connection.cpp +5 -5
- esphome/components/bluetooth_proxy/bluetooth_proxy.cpp +18 -16
- esphome/components/bluetooth_proxy/bluetooth_proxy.h +1 -1
- esphome/components/bme280_base/bme280_base.cpp +5 -6
- esphome/components/bme680/bme680.cpp +3 -3
- esphome/components/bme680/sensor.py +2 -2
- esphome/components/bme680_bsec/bme680_bsec.cpp +11 -7
- esphome/components/bme680_bsec/sensor.py +7 -3
- esphome/components/bme68x_bsec2/__init__.py +6 -5
- esphome/components/bme68x_bsec2/bme68x_bsec2.cpp +17 -13
- esphome/components/bme68x_bsec2/sensor.py +4 -4
- esphome/components/bme68x_bsec2_i2c/bme68x_bsec2_i2c.cpp +1 -0
- esphome/components/bmi160/bmi160.cpp +11 -11
- esphome/components/bmp085/bmp085.cpp +2 -2
- esphome/components/bmp280_base/bmp280_base.cpp +3 -3
- esphome/components/bmp3xx_base/bmp3xx_base.cpp +13 -13
- esphome/components/bmp581/bmp581.cpp +33 -27
- esphome/components/bp1658cj/bp1658cj.cpp +5 -3
- esphome/components/bp5758d/bp5758d.cpp +1 -1
- esphome/components/button/__init__.py +1 -0
- esphome/components/canbus/canbus.cpp +1 -1
- esphome/components/cap1188/cap1188.cpp +6 -4
- esphome/components/captive_portal/captive_portal.cpp +1 -1
- esphome/components/ccs811/ccs811.cpp +3 -2
- esphome/components/cd74hc4067/cd74hc4067.cpp +1 -1
- esphome/components/ch422g/ch422g.cpp +2 -2
- esphome/components/chsc6x/chsc6x_touchscreen.cpp +6 -4
- esphome/components/climate/__init__.py +1 -0
- esphome/components/climate/climate.cpp +12 -7
- esphome/components/climate/climate.h +1 -1
- esphome/components/climate_ir/climate_ir.cpp +7 -4
- esphome/components/cm1106/__init__.py +1 -0
- esphome/components/cm1106/cm1106.cpp +112 -0
- esphome/components/cm1106/cm1106.h +40 -0
- esphome/components/cm1106/sensor.py +72 -0
- esphome/components/const/__init__.py +1 -0
- esphome/components/cover/__init__.py +1 -0
- esphome/components/cs5460a/cs5460a.cpp +16 -11
- esphome/components/cse7761/cse7761.cpp +2 -2
- esphome/components/cse7766/cse7766.cpp +0 -5
- esphome/components/cse7766/cse7766.h +5 -1
- esphome/components/cst226/touchscreen/cst226_touchscreen.cpp +1 -1
- esphome/components/cst816/touchscreen/cst816_touchscreen.cpp +6 -3
- esphome/components/current_based/current_based_cover.cpp +4 -2
- esphome/components/dac7678/dac7678_output.cpp +4 -4
- esphome/components/dallas_temp/dallas_temp.cpp +2 -3
- esphome/components/daly_bms/daly_bms.cpp +2 -1
- esphome/components/dashboard_import/__init__.py +1 -2
- esphome/components/datetime/__init__.py +3 -1
- esphome/components/datetime/date_entity.cpp +5 -5
- esphome/components/datetime/datetime_base.h +0 -5
- esphome/components/datetime/datetime_entity.cpp +8 -8
- esphome/components/datetime/time_entity.cpp +4 -4
- esphome/components/debug/debug_component.cpp +1 -1
- esphome/components/debug/debug_component.h +1 -1
- esphome/components/debug/debug_esp32.cpp +4 -2
- esphome/components/deep_sleep/deep_sleep_component.cpp +11 -5
- esphome/components/deep_sleep/deep_sleep_esp32.cpp +7 -5
- esphome/components/demo/__init__.py +206 -0
- esphome/components/demo/demo_alarm_control_panel.h +65 -0
- esphome/components/demo/demo_button.h +15 -0
- esphome/components/demo/demo_date.h +34 -0
- esphome/components/demo/demo_datetime.h +40 -0
- esphome/components/demo/demo_lock.h +17 -0
- esphome/components/demo/demo_select.h +15 -0
- esphome/components/demo/demo_text.h +18 -0
- esphome/components/demo/demo_time.h +34 -0
- esphome/components/demo/demo_valve.h +54 -0
- esphome/components/dfrobot_sen0395/commands.cpp +3 -3
- esphome/components/dht/dht.cpp +29 -50
- esphome/components/dht12/dht12.cpp +2 -2
- esphome/components/display/display.h +5 -3
- esphome/components/dps310/dps310.cpp +7 -5
- esphome/components/ds1307/ds1307.cpp +2 -2
- esphome/components/dsmr/dsmr.cpp +5 -3
- esphome/components/duty_cycle/duty_cycle_sensor.cpp +2 -2
- esphome/components/duty_time/duty_time_sensor.cpp +5 -3
- esphome/components/ee895/ee895.cpp +3 -3
- esphome/components/ektf2232/touchscreen/ektf2232.cpp +1 -1
- esphome/components/emc2101/emc2101.cpp +11 -9
- esphome/components/ens160_base/ens160_base.cpp +2 -2
- esphome/components/ens210/ens210.cpp +2 -2
- esphome/components/es7210/es7210.cpp +6 -4
- esphome/components/es7243e/es7243e.cpp +1 -1
- esphome/components/es8156/es8156.cpp +1 -1
- esphome/components/es8311/es8311.cpp +8 -6
- esphome/components/es8388/__init__.py +0 -0
- esphome/components/es8388/audio_dac.py +26 -0
- esphome/components/es8388/es8388.cpp +289 -0
- esphome/components/es8388/es8388.h +81 -0
- esphome/components/es8388/es8388_const.h +83 -0
- esphome/components/es8388/select/__init__.py +47 -0
- esphome/components/es8388/select/adc_input_mic_select.cpp +12 -0
- esphome/components/es8388/select/adc_input_mic_select.h +15 -0
- esphome/components/es8388/select/dac_output_select.cpp +12 -0
- esphome/components/es8388/select/dac_output_select.h +15 -0
- esphome/components/esp32/__init__.py +118 -23
- esphome/components/esp32/boards.py +208 -125
- esphome/components/esp32/const.py +6 -0
- esphome/components/esp32/gpio.py +14 -1
- esphome/components/esp32/gpio_esp32_c5.py +45 -0
- esphome/components/esp32/gpio_esp32_p4.py +43 -0
- esphome/components/esp32/preferences.cpp +7 -7
- esphome/components/esp32_ble/__init__.py +115 -0
- esphome/components/esp32_ble/ble.cpp +101 -54
- esphome/components/esp32_ble/ble.h +24 -5
- esphome/components/esp32_ble/ble_event.h +172 -32
- esphome/components/esp32_ble/ble_scan_result.h +24 -0
- esphome/components/esp32_ble/ble_uuid.h +1 -1
- esphome/components/esp32_ble/queue.h +53 -27
- esphome/components/esp32_ble_client/ble_client_base.cpp +4 -2
- esphome/components/esp32_ble_server/__init__.py +4 -1
- esphome/components/esp32_ble_server/ble_characteristic.cpp +1 -0
- esphome/components/esp32_ble_server/ble_server.h +0 -1
- esphome/components/esp32_ble_tracker/__init__.py +7 -2
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.cpp +107 -75
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.h +16 -16
- esphome/components/esp32_camera/esp32_camera.cpp +35 -27
- esphome/components/esp32_camera_web_server/camera_web_server.cpp +4 -2
- esphome/components/esp32_dac/esp32_dac.cpp +2 -2
- esphome/components/esp32_improv/__init__.py +5 -1
- esphome/components/esp32_improv/esp32_improv_component.cpp +2 -2
- esphome/components/esp32_rmt_led_strip/led_strip.cpp +11 -7
- esphome/components/esp32_rmt_led_strip/light.py +5 -1
- esphome/components/esp32_touch/esp32_touch.cpp +12 -8
- esphome/components/esp8266/preferences.cpp +6 -6
- esphome/components/esp8266_pwm/esp8266_pwm.cpp +3 -3
- esphome/components/esp_ldo/__init__.py +91 -0
- esphome/components/esp_ldo/esp_ldo.cpp +43 -0
- esphome/components/esp_ldo/esp_ldo.h +43 -0
- esphome/components/esphome/ota/ota_esphome.cpp +15 -8
- esphome/components/ethernet/ethernet_component.cpp +38 -26
- esphome/components/ethernet/ethernet_component.h +1 -1
- esphome/components/event/__init__.py +1 -0
- esphome/components/exposure_notifications/exposure_notifications.cpp +1 -1
- esphome/components/ezo/ezo.cpp +1 -1
- esphome/components/ezo_pmp/ezo_pmp.cpp +1 -1
- esphome/components/factory_reset/button/factory_reset_button.cpp +1 -1
- esphome/components/factory_reset/switch/factory_reset_switch.cpp +1 -1
- esphome/components/fan/__init__.py +1 -0
- esphome/components/fan/fan.cpp +30 -19
- esphome/components/fastled_base/fastled_light.cpp +7 -5
- esphome/components/fingerprint_grow/fingerprint_grow.cpp +8 -6
- esphome/components/fs3000/fs3000.cpp +1 -1
- esphome/components/ft5x06/touchscreen/ft5x06_touchscreen.cpp +7 -4
- esphome/components/ft63x6/ft63x6.cpp +5 -3
- esphome/components/gcja5/gcja5.cpp +0 -12
- esphome/components/gcja5/gcja5.h +8 -3
- esphome/components/gdk101/gdk101.cpp +2 -2
- esphome/components/globals/globals_component.h +13 -10
- esphome/components/gp2y1010au0f/gp2y1010au0f.cpp +4 -2
- esphome/components/gp8403/gp8403.cpp +4 -2
- esphome/components/gp8403/output/gp8403_output.cpp +4 -2
- esphome/components/gpio/one_wire/gpio_one_wire.cpp +2 -2
- esphome/components/gpio/output/gpio_binary_output.cpp +1 -1
- esphome/components/gpio/switch/gpio_switch.cpp +1 -1
- esphome/components/graphical_display_menu/graphical_display_menu.cpp +12 -8
- esphome/components/grove_gas_mc_v2/grove_gas_mc_v2.cpp +5 -6
- esphome/components/grove_tb6612fng/grove_tb6612fng.cpp +1 -1
- esphome/components/grove_tb6612fng/grove_tb6612fng.h +1 -1
- esphome/components/growatt_solar/growatt_solar.cpp +6 -3
- esphome/components/gt911/touchscreen/gt911_touchscreen.cpp +1 -1
- esphome/components/haier/haier_base.cpp +2 -2
- esphome/components/haier/hon_climate.cpp +13 -6
- esphome/components/havells_solar/havells_solar.cpp +5 -2
- esphome/components/hbridge/switch/hbridge_switch.cpp +1 -1
- esphome/components/hdc1080/hdc1080.cpp +2 -2
- esphome/components/he60r/he60r.cpp +4 -2
- esphome/components/hlw8012/hlw8012.cpp +6 -4
- esphome/components/hm3301/hm3301.cpp +2 -2
- esphome/components/hmc5883l/hmc5883l.cpp +2 -2
- esphome/components/homeassistant/time/homeassistant_time.cpp +4 -2
- esphome/components/honeywell_hih_i2c/honeywell_hih.cpp +4 -4
- esphome/components/honeywellabp/honeywellabp.cpp +4 -2
- esphome/components/honeywellabp2_i2c/honeywellabp2.cpp +8 -6
- esphome/components/hte501/hte501.cpp +3 -2
- esphome/components/http_request/__init__.py +2 -2
- esphome/components/http_request/http_request.cpp +7 -5
- esphome/components/http_request/http_request_idf.cpp +4 -2
- esphome/components/http_request/ota/ota_http_request.cpp +1 -1
- esphome/components/htu21d/htu21d.cpp +2 -2
- esphome/components/htu31d/htu31d.cpp +2 -2
- esphome/components/hx711/hx711.cpp +2 -2
- esphome/components/hydreon_rgxx/hydreon_rgxx.cpp +5 -3
- esphome/components/hyt271/hyt271.cpp +2 -2
- esphome/components/i2c/i2c_bus_arduino.cpp +14 -11
- esphome/components/i2c/i2c_bus_esp_idf.cpp +13 -11
- esphome/components/i2s_audio/__init__.py +2 -0
- esphome/components/i2s_audio/i2s_audio.cpp +3 -4
- esphome/components/i2s_audio/i2s_audio.h +1 -1
- esphome/components/i2s_audio/media_player/__init__.py +1 -1
- esphome/components/i2s_audio/media_player/i2s_audio_media_player.cpp +5 -3
- esphome/components/i2s_audio/microphone/i2s_audio_microphone.cpp +13 -10
- esphome/components/i2s_audio/speaker/i2s_audio_speaker.cpp +1 -1
- esphome/components/iaqcore/iaqcore.cpp +3 -3
- esphome/components/ili9xxx/ili9xxx_display.cpp +12 -7
- esphome/components/ili9xxx/ili9xxx_display.h +1 -1
- esphome/components/image/image.cpp +1 -0
- esphome/components/ina219/ina219.cpp +2 -2
- esphome/components/ina226/ina226.cpp +8 -5
- esphome/components/ina260/ina260.cpp +1 -1
- esphome/components/ina2xx_base/ina2xx_base.cpp +13 -9
- esphome/components/ina3221/ina3221.cpp +2 -2
- esphome/components/inkplate6/display.py +12 -2
- esphome/components/inkplate6/inkplate.cpp +13 -9
- esphome/components/inkplate6/inkplate.h +7 -6
- esphome/components/integration/integration_sensor.cpp +1 -1
- esphome/components/internal_temperature/internal_temperature.cpp +4 -4
- esphome/components/json/json_util.cpp +4 -5
- esphome/components/kamstrup_kmp/kamstrup_kmp.cpp +1 -1
- esphome/components/key_collector/key_collector.cpp +4 -2
- esphome/components/kmeteriso/kmeteriso.cpp +4 -4
- esphome/components/kuntze/kuntze.cpp +4 -2
- esphome/components/lc709203f/__init__.py +1 -0
- esphome/components/lc709203f/lc709203f.cpp +299 -0
- esphome/components/lc709203f/lc709203f.h +55 -0
- esphome/components/lc709203f/sensor.py +93 -0
- esphome/components/lcd_base/lcd_display.cpp +2 -2
- esphome/components/lcd_gpio/gpio_lcd_display.cpp +5 -3
- esphome/components/lcd_menu/lcd_menu.cpp +6 -4
- esphome/components/lcd_pcf8574/pcf8574_display.cpp +6 -4
- esphome/components/ld2410/ld2410.cpp +6 -7
- esphome/components/ld2420/ld2420.cpp +9 -7
- esphome/components/ld2450/ld2450.cpp +6 -4
- esphome/components/ld2450/sensor.py +2 -2
- esphome/components/ledc/ledc_output.cpp +32 -28
- esphome/components/libretiny/const.py +1 -1
- esphome/components/libretiny/preferences.cpp +6 -7
- esphome/components/light/__init__.py +2 -1
- esphome/components/light/esp_hsv_color.h +1 -1
- esphome/components/light/light_state.cpp +9 -5
- esphome/components/light/light_transformer.h +1 -1
- esphome/components/lightwaverf/LwTx.cpp +1 -1
- esphome/components/lightwaverf/lightwaverf.cpp +1 -1
- esphome/components/lilygo_t5_47/touchscreen/lilygo_t5_47_touchscreen.cpp +1 -1
- esphome/components/lock/__init__.py +1 -0
- esphome/components/lock/lock.h +1 -1
- esphome/components/logger/__init__.py +6 -0
- esphome/components/logger/logger.cpp +11 -20
- esphome/components/logger/logger.h +1 -2
- esphome/components/logger/logger_esp32.cpp +5 -5
- esphome/components/ltr390/ltr390.cpp +8 -5
- esphome/components/ltr501/ltr501.cpp +19 -14
- esphome/components/ltr_als_ps/ltr_als_ps.cpp +20 -13
- esphome/components/lvgl/__init__.py +2 -2
- esphome/components/lvgl/automation.py +5 -4
- esphome/components/lvgl/defines.py +0 -2
- esphome/components/lvgl/lv_validation.py +1 -3
- esphome/components/lvgl/lvcode.py +7 -8
- esphome/components/lvgl/lvgl_esphome.cpp +26 -10
- esphome/components/lvgl/schemas.py +22 -23
- esphome/components/lvgl/trigger.py +8 -3
- esphome/components/lvgl/widgets/__init__.py +2 -2
- esphome/components/lvgl/widgets/canvas.py +9 -3
- esphome/components/lvgl/widgets/line.py +2 -1
- esphome/components/lvgl/widgets/tabview.py +7 -0
- esphome/components/m5stack_8angle/m5stack_8angle.cpp +3 -3
- esphome/components/matrix_keypad/matrix_keypad.cpp +2 -2
- esphome/components/max17043/max17043.cpp +2 -2
- esphome/components/max31855/max31855.cpp +2 -1
- esphome/components/max31856/max31856.cpp +9 -11
- esphome/components/max31865/max31865.cpp +6 -4
- esphome/components/max44009/max44009.cpp +2 -2
- esphome/components/max6675/max6675.cpp +1 -1
- esphome/components/max6956/max6956.cpp +5 -3
- esphome/components/max7219/max7219.cpp +8 -6
- esphome/components/max7219digit/automation.h +52 -0
- esphome/components/max7219digit/display.py +93 -1
- esphome/components/max7219digit/max7219digit.cpp +16 -13
- esphome/components/max9611/max9611.cpp +9 -6
- esphome/components/mcp23008/mcp23008.cpp +1 -1
- esphome/components/mcp23016/mcp23016.cpp +1 -1
- esphome/components/mcp23017/mcp23017.cpp +1 -1
- esphome/components/mcp23s08/mcp23s08.cpp +1 -1
- esphome/components/mcp23s17/mcp23s17.cpp +1 -1
- esphome/components/mcp3008/mcp3008.cpp +1 -1
- esphome/components/mcp3008/sensor/mcp3008_sensor.cpp +5 -3
- esphome/components/mcp3204/mcp3204.cpp +1 -1
- esphome/components/mcp4461/mcp4461.cpp +2 -2
- esphome/components/mcp4725/mcp4725.cpp +2 -2
- esphome/components/mcp4728/mcp4728.cpp +2 -2
- esphome/components/mcp9600/mcp9600.cpp +1 -1
- esphome/components/mcp9808/mcp9808.cpp +4 -4
- esphome/components/mdns/mdns_component.cpp +8 -2
- esphome/components/mdns/mdns_component.h +3 -1
- esphome/components/mdns/mdns_esp32.cpp +2 -2
- esphome/components/media_player/__init__.py +1 -0
- esphome/components/micro_wake_word/micro_wake_word.cpp +1 -1
- esphome/components/micro_wake_word/streaming_model.cpp +10 -6
- esphome/components/micronova/micronova.h +2 -2
- esphome/components/mics_4514/mics_4514.cpp +2 -2
- esphome/components/midea/air_conditioner.cpp +7 -5
- esphome/components/midea_ir/midea_ir.cpp +1 -1
- esphome/components/mipi_spi/mipi_spi.cpp +24 -15
- esphome/components/mixer/speaker/mixer_speaker.cpp +8 -4
- esphome/components/mlx90393/sensor_mlx90393.cpp +2 -2
- esphome/components/mlx90614/mlx90614.cpp +4 -3
- esphome/components/mmc5603/mmc5603.cpp +2 -2
- esphome/components/mmc5983/mmc5983.cpp +1 -1
- esphome/components/modbus/modbus.cpp +7 -5
- esphome/components/modbus_controller/modbus_controller.cpp +6 -4
- esphome/components/modbus_controller/output/modbus_output.cpp +10 -6
- esphome/components/modbus_controller/switch/__init__.py +6 -2
- esphome/components/modbus_controller/switch/modbus_switch.cpp +4 -0
- esphome/components/modbus_controller/switch/modbus_switch.h +3 -0
- esphome/components/mpl3115a2/mpl3115a2.cpp +3 -2
- esphome/components/mpr121/mpr121.cpp +2 -2
- esphome/components/mpu6050/mpu6050.cpp +6 -6
- esphome/components/mpu6886/mpu6886.cpp +6 -6
- esphome/components/mqtt/mqtt_alarm_control_panel.cpp +7 -3
- esphome/components/mqtt/mqtt_backend_esp32.cpp +1 -1
- esphome/components/mqtt/mqtt_client.cpp +31 -24
- esphome/components/mqtt/mqtt_component.cpp +3 -3
- esphome/components/mqtt/mqtt_cover.cpp +8 -4
- esphome/components/mqtt/mqtt_fan.cpp +12 -6
- esphome/components/mqtt/mqtt_valve.cpp +4 -2
- esphome/components/ms5611/ms5611.cpp +2 -2
- esphome/components/ms8607/ms8607.cpp +2 -2
- esphome/components/msa3xx/msa3xx.cpp +16 -12
- esphome/components/my9231/my9231.cpp +7 -5
- esphome/components/nau7802/nau7802.cpp +6 -4
- esphome/components/neopixelbus/neopixelbus_light.h +2 -2
- esphome/components/network/ip_address.h +1 -1
- esphome/components/network/util.cpp +13 -0
- esphome/components/nextion/base_component.py +2 -0
- esphome/components/nextion/binary_sensor/nextion_binarysensor.cpp +3 -4
- esphome/components/nextion/display.py +34 -22
- esphome/components/nextion/nextion.cpp +182 -143
- esphome/components/nextion/nextion.h +36 -0
- esphome/components/nextion/nextion_commands.cpp +3 -3
- esphome/components/nextion/nextion_upload_arduino.cpp +69 -69
- esphome/components/nextion/nextion_upload_idf.cpp +79 -80
- esphome/components/nextion/sensor/nextion_sensor.cpp +5 -5
- esphome/components/nextion/switch/nextion_switch.cpp +2 -2
- esphome/components/nextion/text_sensor/nextion_textsensor.cpp +3 -3
- esphome/components/nfc/nci_message.h +1 -1
- esphome/components/nfc/ndef_record.h +1 -1
- esphome/components/nfc/ndef_record_text.h +1 -1
- esphome/components/nfc/ndef_record_uri.h +1 -1
- esphome/components/nfc/nfc.h +1 -1
- esphome/components/nfc/nfc_tag.h +1 -1
- esphome/components/noblex/noblex.cpp +1 -1
- esphome/components/npi19/npi19.cpp +5 -7
- esphome/components/number/__init__.py +11 -0
- esphome/components/number/number.cpp +1 -1
- esphome/components/number/number.h +0 -4
- esphome/components/online_image/__init__.py +13 -1
- esphome/components/online_image/online_image.cpp +26 -4
- esphome/components/online_image/online_image.h +21 -4
- esphome/components/opentherm/generate.py +3 -3
- esphome/components/opentherm/hub.cpp +11 -7
- esphome/components/opentherm/number/number.cpp +5 -3
- esphome/components/opentherm/opentherm.h +1 -1
- esphome/components/opentherm/schema.py +13 -13
- esphome/components/opentherm/validate.py +1 -1
- esphome/components/openthread/__init__.py +146 -0
- esphome/components/openthread/const.py +10 -0
- esphome/components/openthread/openthread.cpp +206 -0
- esphome/components/openthread/openthread.h +68 -0
- esphome/components/openthread/openthread_esp.cpp +164 -0
- esphome/components/openthread/tlv.py +58 -0
- esphome/components/openthread_info/__init__.py +0 -0
- esphome/components/openthread_info/openthread_info_text_sensor.cpp +24 -0
- esphome/components/openthread_info/openthread_info_text_sensor.h +218 -0
- esphome/components/openthread_info/text_sensor.py +105 -0
- esphome/components/output/float_output.cpp +1 -1
- esphome/components/output/switch/output_switch.cpp +1 -1
- esphome/components/packet_transport/packet_transport.cpp +6 -4
- esphome/components/pca6416a/pca6416a.cpp +2 -2
- esphome/components/pca9554/pca9554.cpp +6 -4
- esphome/components/pca9685/pca9685_output.cpp +12 -8
- esphome/components/pcd8544/pcd_8544.cpp +1 -1
- esphome/components/pcf85063/pcf85063.cpp +2 -2
- esphome/components/pcf8563/pcf8563.cpp +2 -2
- esphome/components/pcf8574/pcf8574.cpp +2 -2
- esphome/components/pid/pid_climate.cpp +8 -5
- esphome/components/pid/pid_climate.h +1 -1
- esphome/components/pid/sensor/pid_climate_sensor.cpp +1 -1
- esphome/components/pipsolar/output/pipsolar_output.cpp +1 -1
- esphome/components/pipsolar/pipsolar.cpp +3 -3
- esphome/components/pm1006/pm1006.cpp +3 -7
- esphome/components/pm1006/pm1006.h +4 -1
- esphome/components/pm2005/pm2005.cpp +12 -13
- esphome/components/pm2005/sensor.py +1 -1
- esphome/components/pmsa003i/pmsa003i.cpp +2 -2
- esphome/components/pmsx003/pmsx003.cpp +0 -4
- esphome/components/pmsx003/pmsx003.h +5 -2
- esphome/components/pmwcs3/pmwcs3.cpp +9 -13
- esphome/components/pmwcs3/pmwcs3.h +0 -1
- esphome/components/pn532/pn532.cpp +7 -7
- esphome/components/pn532/pn532.h +1 -1
- esphome/components/pn532_spi/pn532_spi.cpp +1 -1
- esphome/components/pn7150/pn7150.cpp +4 -4
- esphome/components/pn7160/pn7160.cpp +4 -4
- esphome/components/power_supply/power_supply.cpp +6 -4
- esphome/components/power_supply/power_supply.h +1 -1
- esphome/components/prometheus/__init__.py +0 -1
- esphome/components/psram/__init__.py +59 -35
- esphome/components/pulse_counter/pulse_counter_sensor.cpp +7 -4
- esphome/components/pvvx_mithermometer/display/pvvx_display.cpp +8 -5
- esphome/components/pylontech/pylontech.cpp +2 -2
- esphome/components/pylontech/sensor/pylontech_sensor.cpp +4 -2
- esphome/components/pylontech/text_sensor/pylontech_text_sensor.cpp +4 -2
- esphome/components/pzemac/pzemac.cpp +4 -2
- esphome/components/pzemdc/pzemdc.cpp +4 -2
- esphome/components/qmc5883l/qmc5883l.cpp +2 -2
- esphome/components/qmp6988/qmp6988.cpp +2 -2
- esphome/components/qmp6988/qmp6988.h +1 -1
- esphome/components/qr_code/qr_code.cpp +5 -3
- esphome/components/qspi_dbi/qspi_dbi.cpp +1 -1
- esphome/components/qwiic_pir/qwiic_pir.cpp +26 -28
- esphome/components/rc522/rc522.cpp +5 -5
- esphome/components/rdm6300/rdm6300.cpp +1 -0
- esphome/components/remote_receiver/__init__.py +10 -2
- esphome/components/remote_receiver/remote_receiver_esp32.cpp +22 -12
- esphome/components/remote_receiver/remote_receiver_esp8266.cpp +10 -7
- esphome/components/remote_receiver/remote_receiver_libretiny.cpp +10 -7
- esphome/components/remote_transmitter/__init__.py +10 -2
- esphome/components/remote_transmitter/remote_transmitter_esp32.cpp +10 -6
- esphome/components/remote_transmitter/remote_transmitter_esp8266.cpp +5 -3
- esphome/components/remote_transmitter/remote_transmitter_libretiny.cpp +5 -3
- esphome/components/resistance/resistance_sensor.cpp +6 -3
- esphome/components/restart/button/restart_button.cpp +1 -1
- esphome/components/restart/switch/restart_switch.cpp +1 -1
- esphome/components/rotary_encoder/rotary_encoder.cpp +2 -2
- esphome/components/rp2040/__init__.py +7 -0
- esphome/components/rp2040/core.cpp +8 -1
- esphome/components/rp2040/preferences.cpp +3 -3
- esphome/components/rp2040_pio_led_strip/led_strip.cpp +11 -8
- esphome/components/rp2040_pio_led_strip/light.py +1 -1
- esphome/components/rp2040_pwm/rp2040_pwm.cpp +1 -1
- esphome/components/rpi_dpi_rgb/rpi_dpi_rgb.cpp +1 -1
- esphome/components/rtttl/rtttl.cpp +11 -9
- esphome/components/safe_mode/button/safe_mode_button.cpp +1 -1
- esphome/components/safe_mode/safe_mode.cpp +9 -8
- esphome/components/safe_mode/switch/safe_mode_switch.cpp +1 -1
- esphome/components/scd30/scd30.cpp +11 -8
- esphome/components/scd4x/scd4x.cpp +12 -8
- esphome/components/sdl/display.py +40 -0
- esphome/components/sdl/sdl_esphome.cpp +2 -2
- esphome/components/sdl/sdl_esphome.h +8 -0
- esphome/components/sdm_meter/sdm_meter.cpp +5 -2
- esphome/components/sdp3x/sdp3x.cpp +11 -11
- esphome/components/sds011/sds011.cpp +5 -6
- esphome/components/sds011/sds011.h +4 -1
- esphome/components/seeed_mr24hpc1/seeed_mr24hpc1.cpp +3 -2
- esphome/components/seeed_mr60bha2/seeed_mr60bha2.cpp +1 -0
- esphome/components/seeed_mr60fda2/seeed_mr60fda2.cpp +3 -2
- esphome/components/selec_meter/selec_meter.cpp +5 -2
- esphome/components/select/__init__.py +1 -0
- esphome/components/select/select.cpp +1 -1
- esphome/components/select/select.h +0 -4
- esphome/components/sen0321/sen0321.cpp +2 -2
- esphome/components/sen21231/sen21231.cpp +1 -1
- esphome/components/sen5x/sen5x.cpp +10 -7
- esphome/components/sensirion_common/i2c_sensirion.cpp +2 -1
- esphome/components/sensirion_common/i2c_sensirion.h +1 -0
- esphome/components/sensor/__init__.py +11 -1
- esphome/components/sensor/filter.h +1 -1
- esphome/components/sensor/sensor.cpp +8 -4
- esphome/components/sensor/sensor.h +12 -11
- esphome/components/servo/servo.cpp +12 -9
- esphome/components/servo/servo.h +1 -1
- esphome/components/sfa30/sfa30.cpp +1 -1
- esphome/components/sgp30/sgp30.cpp +10 -8
- esphome/components/sgp4x/sgp4x.cpp +49 -61
- esphome/components/sgp4x/sgp4x.h +0 -1
- esphome/components/shelly_dimmer/shelly_dimmer.cpp +11 -7
- esphome/components/sht3xd/sht3xd.cpp +1 -1
- esphome/components/sht4x/sht4x.cpp +2 -2
- esphome/components/shtcx/shtcx.cpp +13 -16
- esphome/components/shutdown/button/shutdown_button.cpp +1 -1
- esphome/components/shutdown/switch/shutdown_switch.cpp +1 -1
- esphome/components/sim800l/sim800l.cpp +2 -2
- esphome/components/slow_pwm/slow_pwm_output.cpp +4 -2
- esphome/components/sm16716/sm16716.cpp +1 -1
- esphome/components/sm2135/sm2135.cpp +1 -1
- esphome/components/sm2235/sm2235.cpp +5 -3
- esphome/components/sm2335/sm2335.cpp +5 -3
- esphome/components/sml/sml.cpp +1 -1
- esphome/components/sn74hc165/sn74hc165.cpp +1 -2
- esphome/components/sn74hc595/sn74hc595.cpp +1 -2
- esphome/components/sntp/sntp_component.cpp +1 -1
- esphome/components/socket/__init__.py +2 -0
- esphome/components/socket/bsd_sockets_impl.cpp +51 -7
- esphome/components/socket/lwip_raw_tcp_impl.cpp +5 -0
- esphome/components/socket/lwip_sockets_impl.cpp +51 -7
- esphome/components/socket/socket.cpp +31 -0
- esphome/components/socket/socket.h +27 -1
- esphome/components/sonoff_d1/sonoff_d1.cpp +7 -4
- esphome/components/sonoff_d1/sonoff_d1.h +2 -2
- esphome/components/sound_level/sound_level.cpp +4 -2
- esphome/components/speaker/media_player/__init__.py +3 -0
- esphome/components/speaker/media_player/speaker_media_player.cpp +1 -3
- esphome/components/speaker/media_player/speaker_media_player.h +6 -0
- esphome/components/spi/__init__.py +10 -2
- esphome/components/spi/spi.cpp +4 -4
- esphome/components/spi_device/spi_device.cpp +1 -2
- esphome/components/sprinkler/sprinkler.cpp +9 -6
- esphome/components/sps30/sps30.cpp +16 -15
- esphome/components/ssd1306_base/ssd1306_base.cpp +1 -1
- esphome/components/ssd1306_i2c/ssd1306_i2c.cpp +11 -8
- esphome/components/ssd1306_spi/ssd1306_spi.cpp +10 -7
- esphome/components/ssd1322_base/ssd1322_base.cpp +1 -1
- esphome/components/ssd1322_spi/ssd1322_spi.cpp +1 -1
- esphome/components/ssd1325_base/ssd1325_base.cpp +1 -1
- esphome/components/ssd1325_spi/ssd1325_spi.cpp +1 -1
- esphome/components/ssd1327_base/ssd1327_base.cpp +1 -1
- esphome/components/ssd1327_i2c/ssd1327_i2c.cpp +2 -2
- esphome/components/ssd1327_spi/ssd1327_spi.cpp +1 -1
- esphome/components/ssd1331_base/ssd1331_base.cpp +1 -1
- esphome/components/ssd1331_spi/ssd1331_spi.cpp +1 -1
- esphome/components/ssd1351_base/ssd1351_base.cpp +1 -1
- esphome/components/ssd1351_spi/ssd1351_spi.cpp +1 -1
- esphome/components/st7567_base/st7567_base.cpp +3 -3
- esphome/components/st7567_i2c/st7567_i2c.cpp +7 -5
- esphome/components/st7567_spi/st7567_spi.cpp +1 -1
- esphome/components/st7701s/st7701s.cpp +4 -2
- esphome/components/st7735/st7735.cpp +3 -3
- esphome/components/st7789v/st7789v.cpp +10 -7
- esphome/components/st7920/st7920.cpp +6 -4
- esphome/components/statsd/statsd.cpp +9 -5
- esphome/components/status_led/light/status_led_light.cpp +3 -3
- esphome/components/status_led/light/status_led_light.h +1 -1
- esphome/components/status_led/status_led.cpp +1 -1
- esphome/components/stepper/stepper.h +5 -3
- esphome/components/sts3x/sts3x.cpp +2 -2
- esphome/components/switch/__init__.py +1 -0
- esphome/components/switch/switch.cpp +18 -12
- esphome/components/switch/switch.h +1 -1
- esphome/components/sx1509/__init__.py +53 -20
- esphome/components/sx1509/sx1509.cpp +29 -5
- esphome/components/sx1509/sx1509.h +9 -1
- esphome/components/t6615/t6615.cpp +1 -0
- esphome/components/tc74/tc74.cpp +1 -1
- esphome/components/tca9548a/tca9548a.cpp +1 -1
- esphome/components/tca9555/tca9555.cpp +2 -2
- esphome/components/tcs34725/tcs34725.cpp +4 -4
- esphome/components/tee501/tee501.cpp +3 -2
- esphome/components/tem3200/tem3200.cpp +5 -6
- esphome/components/template/alarm_control_panel/__init__.py +6 -0
- esphome/components/template/alarm_control_panel/template_alarm_control_panel.cpp +43 -12
- esphome/components/template/alarm_control_panel/template_alarm_control_panel.h +4 -1
- esphome/components/template/cover/template_cover.cpp +1 -1
- esphome/components/template/select/template_select.cpp +6 -4
- esphome/components/template/text/template_text.cpp +2 -3
- esphome/components/template/valve/template_valve.cpp +5 -3
- esphome/components/text/__init__.py +10 -11
- esphome/components/text/text.cpp +1 -1
- esphome/components/text/text.h +0 -4
- esphome/components/text_sensor/__init__.py +1 -0
- esphome/components/text_sensor/text_sensor.cpp +8 -4
- esphome/components/text_sensor/text_sensor.h +6 -6
- esphome/components/thermostat/thermostat_climate.cpp +67 -43
- esphome/components/time/__init__.py +1 -2
- esphome/components/time_based/time_based_cover.cpp +4 -2
- esphome/components/tlc59208f/tlc59208f_output.cpp +8 -6
- esphome/components/tm1621/tm1621.cpp +3 -3
- esphome/components/tm1637/tm1637.cpp +9 -7
- esphome/components/tm1638/tm1638.cpp +7 -5
- esphome/components/tm1651/tm1651.cpp +2 -2
- esphome/components/tmp102/tmp102.cpp +1 -3
- esphome/components/tmp102/tmp102.h +0 -3
- esphome/components/tmp1075/tmp1075.cpp +12 -9
- esphome/components/tmp117/tmp117.cpp +2 -2
- esphome/components/tof10120/tof10120_sensor.cpp +2 -2
- esphome/components/tormatic/tormatic_cover.cpp +4 -2
- esphome/components/tsl2561/tsl2561.cpp +7 -5
- esphome/components/tsl2591/tsl2591.cpp +25 -27
- esphome/components/tt21100/touchscreen/tt21100.cpp +1 -1
- esphome/components/ttp229_bsf/ttp229_bsf.cpp +1 -1
- esphome/components/ttp229_lsf/ttp229_lsf.cpp +2 -2
- esphome/components/tuya/select/tuya_select.cpp +5 -3
- esphome/components/tx20/tx20.cpp +3 -3
- esphome/components/uart/__init__.py +4 -5
- esphome/components/uart/button/uart_button.cpp +1 -1
- esphome/components/uart/switch/uart_switch.cpp +2 -2
- esphome/components/uart/uart.cpp +2 -2
- esphome/components/uart/uart_component_esp32_arduino.cpp +8 -6
- esphome/components/uart/uart_component_esp8266.cpp +9 -7
- esphome/components/uart/uart_component_esp_idf.cpp +9 -7
- esphome/components/uart/uart_component_host.cpp +11 -8
- esphome/components/uart/uart_component_libretiny.cpp +8 -6
- esphome/components/uart/uart_component_rp2040.cpp +8 -6
- esphome/components/udp/udp_component.cpp +9 -5
- esphome/components/ufire_ec/ufire_ec.cpp +5 -3
- esphome/components/ufire_ise/ufire_ise.cpp +1 -1
- esphome/components/ultrasonic/ultrasonic_sensor.cpp +5 -3
- esphome/components/update/__init__.py +1 -0
- esphome/components/update/update_entity.cpp +1 -1
- esphome/components/update/update_entity.h +0 -3
- esphome/components/uponor_smatrix/climate/uponor_smatrix_climate.cpp +1 -1
- esphome/components/uponor_smatrix/sensor/uponor_smatrix_sensor.cpp +4 -2
- esphome/components/uponor_smatrix/uponor_smatrix.cpp +2 -1
- esphome/components/uptime/sensor/uptime_timestamp_sensor.cpp +1 -1
- esphome/components/usb_host/__init__.py +64 -0
- esphome/components/usb_host/usb_host.h +116 -0
- esphome/components/usb_host/usb_host_client.cpp +394 -0
- esphome/components/usb_host/usb_host_component.cpp +35 -0
- esphome/components/usb_uart/__init__.py +134 -0
- esphome/components/usb_uart/ch34x.cpp +80 -0
- esphome/components/usb_uart/cp210x.cpp +126 -0
- esphome/components/usb_uart/usb_uart.cpp +328 -0
- esphome/components/usb_uart/usb_uart.h +151 -0
- esphome/components/valve/__init__.py +1 -0
- esphome/components/veml3235/veml3235.cpp +13 -9
- esphome/components/veml7700/veml7700.cpp +10 -6
- esphome/components/voice_assistant/voice_assistant.cpp +7 -7
- esphome/components/wake_on_lan/wake_on_lan.cpp +1 -1
- esphome/components/waveshare_epaper/waveshare_epaper.cpp +1 -1
- esphome/components/web_server/server_index_v2.h +632 -630
- esphome/components/web_server/server_index_v3.h +411 -409
- esphome/components/web_server/web_server.cpp +5 -3
- esphome/components/web_server_base/web_server_base.cpp +1 -1
- esphome/components/web_server_idf/__init__.py +0 -2
- esphome/components/web_server_idf/utils.cpp +1 -1
- esphome/components/web_server_idf/web_server_idf.cpp +7 -3
- esphome/components/web_server_idf/web_server_idf.h +7 -0
- esphome/components/weikai/__init__.py +2 -0
- esphome/components/weikai/weikai.cpp +24 -22
- esphome/components/weikai_i2c/weikai_i2c.cpp +14 -9
- esphome/components/weikai_spi/weikai_spi.cpp +11 -6
- esphome/components/wiegand/wiegand.cpp +1 -1
- esphome/components/wifi/wifi_component.cpp +50 -37
- esphome/components/wifi/wifi_component.h +7 -4
- esphome/components/wifi/wifi_component_esp32_arduino.cpp +2 -2
- esphome/components/wifi/wifi_component_esp8266.cpp +3 -3
- esphome/components/wifi/wifi_component_libretiny.cpp +4 -4
- esphome/components/wireguard/wireguard.cpp +21 -21
- esphome/components/wl_134/text_sensor.py +1 -2
- esphome/components/wled/wled_light_effect.cpp +1 -1
- esphome/components/x9c/x9c.cpp +5 -3
- esphome/components/xgzp68xx/xgzp68xx.cpp +8 -6
- esphome/components/xiaomi_cgd1/xiaomi_cgd1.cpp +4 -2
- esphome/components/xiaomi_cgdk2/xiaomi_cgdk2.cpp +4 -2
- esphome/components/xiaomi_cgg1/xiaomi_cgg1.cpp +4 -2
- esphome/components/xiaomi_hhccjcy10/xiaomi_hhccjcy10.cpp +1 -1
- esphome/components/xiaomi_lywsd02mmc/xiaomi_lywsd02mmc.cpp +4 -2
- esphome/components/xiaomi_lywsd03mmc/xiaomi_lywsd03mmc.cpp +4 -2
- esphome/components/xiaomi_mhoc401/xiaomi_mhoc401.cpp +4 -2
- esphome/components/xl9535/xl9535.cpp +2 -2
- esphome/components/xpt2046/touchscreen/xpt2046.cpp +12 -11
- esphome/components/xpt2046/touchscreen/xpt2046.h +2 -2
- esphome/config.py +3 -2
- esphome/config_validation.py +46 -17
- esphome/const.py +10 -1
- esphome/core/__init__.py +37 -18
- esphome/core/application.cpp +197 -8
- esphome/core/application.h +116 -6
- esphome/core/component.cpp +36 -15
- esphome/core/component.h +43 -13
- esphome/core/config.py +12 -0
- esphome/core/defines.h +10 -2
- esphome/core/entity_base.cpp +4 -16
- esphome/core/entity_base.h +27 -13
- esphome/core/helpers.cpp +1 -1
- esphome/core/helpers.h +5 -5
- esphome/core/log.h +2 -0
- esphome/core/log_const_en.h +4 -0
- esphome/core/scheduler.cpp +2 -2
- esphome/coroutine.py +3 -4
- esphome/cpp_generator.py +32 -32
- esphome/dashboard/core.py +2 -2
- esphome/dashboard/web_server.py +2 -2
- esphome/git.py +4 -4
- esphome/helpers.py +5 -6
- esphome/loader.py +8 -7
- esphome/log.py +7 -1
- esphome/platformio_api.py +2 -3
- esphome/storage_json.py +13 -5
- esphome/types.py +12 -13
- esphome/util.py +1 -2
- esphome/wizard.py +0 -16
- esphome/writer.py +5 -3
- esphome/yaml_util.py +6 -1
- esphome/zeroconf.py +1 -1
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/METADATA +12 -11
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/RECORD +746 -692
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/WHEEL +1 -1
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/entry_points.txt +0 -0
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/licenses/LICENSE +0 -0
- {esphome-2025.5.2.dist-info → esphome-2025.6.0b2.dist-info}/top_level.txt +0 -0
@@ -39,17 +39,14 @@ static const LogString *pm2005_get_measuring_mode_string(int status) {
|
|
39
39
|
static inline uint16_t get_sensor_value(const uint8_t *data, uint8_t i) { return data[i] * 0x100 + data[i + 1]; }
|
40
40
|
|
41
41
|
void PM2005Component::setup() {
|
42
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
42
43
|
if (this->sensor_type_ == PM2005) {
|
43
|
-
ESP_LOGCONFIG(TAG, "Setting up PM2005...");
|
44
|
-
|
45
44
|
this->situation_value_index_ = 3;
|
46
45
|
this->pm_1_0_value_index_ = 4;
|
47
46
|
this->pm_2_5_value_index_ = 6;
|
48
47
|
this->pm_10_0_value_index_ = 8;
|
49
48
|
this->measuring_value_index_ = 10;
|
50
49
|
} else {
|
51
|
-
ESP_LOGCONFIG(TAG, "Setting up PM2105...");
|
52
|
-
|
53
50
|
this->situation_value_index_ = 2;
|
54
51
|
this->pm_1_0_value_index_ = 3;
|
55
52
|
this->pm_2_5_value_index_ = 5;
|
@@ -58,7 +55,7 @@ void PM2005Component::setup() {
|
|
58
55
|
}
|
59
56
|
|
60
57
|
if (this->read(this->data_buffer_, 12) != i2c::ERROR_OK) {
|
61
|
-
ESP_LOGE(TAG,
|
58
|
+
ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL);
|
62
59
|
this->mark_failed();
|
63
60
|
return;
|
64
61
|
}
|
@@ -66,7 +63,7 @@ void PM2005Component::setup() {
|
|
66
63
|
|
67
64
|
void PM2005Component::update() {
|
68
65
|
if (this->read(this->data_buffer_, 12) != i2c::ERROR_OK) {
|
69
|
-
ESP_LOGW(TAG, "Read result failed
|
66
|
+
ESP_LOGW(TAG, "Read result failed");
|
70
67
|
this->status_set_warning();
|
71
68
|
return;
|
72
69
|
}
|
@@ -85,10 +82,10 @@ void PM2005Component::update() {
|
|
85
82
|
return;
|
86
83
|
}
|
87
84
|
|
88
|
-
uint16_t pm1 = get_sensor_value(this->data_buffer_, this->pm_1_0_value_index_);
|
89
|
-
uint16_t pm25 = get_sensor_value(this->data_buffer_, this->pm_2_5_value_index_);
|
90
|
-
uint16_t pm10 = get_sensor_value(this->data_buffer_, this->pm_10_0_value_index_);
|
91
|
-
uint16_t sensor_measuring_mode = get_sensor_value(this->data_buffer_, this->measuring_value_index_);
|
85
|
+
const uint16_t pm1 = get_sensor_value(this->data_buffer_, this->pm_1_0_value_index_);
|
86
|
+
const uint16_t pm25 = get_sensor_value(this->data_buffer_, this->pm_2_5_value_index_);
|
87
|
+
const uint16_t pm10 = get_sensor_value(this->data_buffer_, this->pm_10_0_value_index_);
|
88
|
+
const uint16_t sensor_measuring_mode = get_sensor_value(this->data_buffer_, this->measuring_value_index_);
|
92
89
|
ESP_LOGD(TAG, "PM1.0: %d, PM2.5: %d, PM10: %d, Measuring mode: %s.", pm1, pm25, pm10,
|
93
90
|
LOG_STR_ARG(pm2005_get_measuring_mode_string(sensor_measuring_mode)));
|
94
91
|
|
@@ -106,12 +103,14 @@ void PM2005Component::update() {
|
|
106
103
|
}
|
107
104
|
|
108
105
|
void PM2005Component::dump_config() {
|
109
|
-
ESP_LOGCONFIG(TAG,
|
110
|
-
|
106
|
+
ESP_LOGCONFIG(TAG,
|
107
|
+
"PM2005:\n"
|
108
|
+
" Type: PM2%u05",
|
109
|
+
this->sensor_type_ == PM2105);
|
111
110
|
|
112
111
|
LOG_I2C_DEVICE(this);
|
113
112
|
if (this->is_failed()) {
|
114
|
-
ESP_LOGE(TAG,
|
113
|
+
ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL);
|
115
114
|
}
|
116
115
|
|
117
116
|
LOG_SENSOR(" ", "PM1.0", this->pm_1_0_sensor_);
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#include "pmsa003i.h"
|
2
|
-
#include "esphome/core/log.h"
|
3
2
|
#include "esphome/core/helpers.h"
|
3
|
+
#include "esphome/core/log.h"
|
4
4
|
#include <cstring>
|
5
5
|
|
6
6
|
namespace esphome {
|
@@ -19,7 +19,7 @@ static const uint8_t START_CHARACTER_2 = 0x4D;
|
|
19
19
|
static const uint8_t READ_DATA_RETRY_COUNT = 3;
|
20
20
|
|
21
21
|
void PMSA003IComponent::setup() {
|
22
|
-
ESP_LOGCONFIG(TAG, "
|
22
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
23
23
|
|
24
24
|
PM25AQIData data;
|
25
25
|
bool successful_read = this->read_data_(&data);
|
@@ -314,9 +314,5 @@ void PMSX003Component::parse_data_() {
|
|
314
314
|
this->status_clear_warning();
|
315
315
|
}
|
316
316
|
|
317
|
-
uint16_t PMSX003Component::get_16_bit_uint_(uint8_t start_index) {
|
318
|
-
return (uint16_t(this->data_[start_index]) << 8) | uint16_t(this->data_[start_index + 1]);
|
319
|
-
}
|
320
|
-
|
321
317
|
} // namespace pmsx003
|
322
318
|
} // namespace esphome
|
@@ -1,8 +1,9 @@
|
|
1
1
|
#pragma once
|
2
2
|
|
3
|
+
#include "esphome/core/component.h"
|
4
|
+
#include "esphome/core/helpers.h"
|
3
5
|
#include "esphome/components/sensor/sensor.h"
|
4
6
|
#include "esphome/components/uart/uart.h"
|
5
|
-
#include "esphome/core/component.h"
|
6
7
|
|
7
8
|
namespace esphome {
|
8
9
|
namespace pmsx003 {
|
@@ -77,7 +78,9 @@ class PMSX003Component : public uart::UARTDevice, public Component {
|
|
77
78
|
void parse_data_();
|
78
79
|
bool check_payload_length_(uint16_t payload_length);
|
79
80
|
void send_command_(PMSX0003Command cmd, uint16_t data);
|
80
|
-
uint16_t get_16_bit_uint_(uint8_t start_index)
|
81
|
+
uint16_t get_16_bit_uint_(uint8_t start_index) const {
|
82
|
+
return encode_uint16(this->data_[start_index], this->data_[start_index + 1]);
|
83
|
+
}
|
81
84
|
|
82
85
|
uint8_t data_[64];
|
83
86
|
uint8_t data_index_{0};
|
@@ -26,33 +26,31 @@ static const char *const TAG = "pmwcs3";
|
|
26
26
|
void PMWCS3Component::new_i2c_address(uint8_t address) {
|
27
27
|
if (!this->write_byte(PMWCS3_SET_I2C_ADDRESS, address)) {
|
28
28
|
this->status_set_warning();
|
29
|
-
ESP_LOGW(TAG, "
|
29
|
+
ESP_LOGW(TAG, "Setting I2C address failed (%d)", address);
|
30
30
|
return;
|
31
31
|
}
|
32
32
|
this->set_i2c_address(address); // Allows device to continue working until new firmware is written with new address.
|
33
|
-
ESP_LOGVV(TAG, "
|
33
|
+
ESP_LOGVV(TAG, "Set I2C address to %d", address);
|
34
34
|
this->status_clear_warning();
|
35
35
|
}
|
36
36
|
|
37
37
|
void PMWCS3Component::air_calibration() {
|
38
38
|
if (!this->write_bytes(PMWCS3_REG_CALIBRATE_AIR, nullptr, 0)) {
|
39
39
|
this->status_set_warning();
|
40
|
-
ESP_LOGW(TAG, "
|
40
|
+
ESP_LOGW(TAG, "Starting air calibration failed");
|
41
41
|
return;
|
42
42
|
}
|
43
|
-
ESP_LOGW(TAG, "
|
43
|
+
ESP_LOGW(TAG, "Running air calibration for 300s");
|
44
44
|
}
|
45
45
|
void PMWCS3Component::water_calibration() {
|
46
46
|
if (!this->write_bytes(PMWCS3_REG_CALIBRATE_WATER, nullptr, 0)) {
|
47
47
|
this->status_set_warning();
|
48
|
-
ESP_LOGW(TAG, "
|
48
|
+
ESP_LOGW(TAG, "Starting water calibration failed");
|
49
49
|
return;
|
50
50
|
}
|
51
|
-
ESP_LOGW(TAG, "
|
51
|
+
ESP_LOGW(TAG, "Running water calibration for 300s");
|
52
52
|
}
|
53
53
|
|
54
|
-
void PMWCS3Component::setup() { ESP_LOGCONFIG(TAG, "Setting up PMWCS3..."); }
|
55
|
-
|
56
54
|
void PMWCS3Component::update() { this->read_data_(); }
|
57
55
|
|
58
56
|
float PMWCS3Component::get_setup_priority() const { return setup_priority::DATA; }
|
@@ -61,10 +59,8 @@ void PMWCS3Component::dump_config() {
|
|
61
59
|
ESP_LOGCONFIG(TAG, "PMWCS3");
|
62
60
|
LOG_I2C_DEVICE(this);
|
63
61
|
if (this->is_failed()) {
|
64
|
-
ESP_LOGE(TAG,
|
62
|
+
ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL);
|
65
63
|
}
|
66
|
-
ESP_LOGI(TAG, "%s", this->is_failed() ? "FAILED" : "OK");
|
67
|
-
|
68
64
|
LOG_UPDATE_INTERVAL(this);
|
69
65
|
LOG_SENSOR(" ", "e25", this->e25_sensor_);
|
70
66
|
LOG_SENSOR(" ", "ec", this->ec_sensor_);
|
@@ -75,7 +71,7 @@ void PMWCS3Component::read_data_() {
|
|
75
71
|
/////// Super important !!!! first activate reading PMWCS3_REG_READ_START (if not, return always the same values) ////
|
76
72
|
if (!this->write_bytes(PMWCS3_REG_READ_START, nullptr, 0)) {
|
77
73
|
this->status_set_warning();
|
78
|
-
ESP_LOGVV(TAG, "
|
74
|
+
ESP_LOGVV(TAG, "Writing REG_READ_START failed");
|
79
75
|
return;
|
80
76
|
}
|
81
77
|
|
@@ -85,7 +81,7 @@ void PMWCS3Component::read_data_() {
|
|
85
81
|
uint8_t data[8];
|
86
82
|
float e25, ec, temperature, vwc;
|
87
83
|
if (!this->read_bytes(PMWCS3_REG_GET_DATA, (uint8_t *) &data, 8)) {
|
88
|
-
ESP_LOGVV(TAG, "
|
84
|
+
ESP_LOGVV(TAG, "Reading PMWCS3_REG_GET_DATA failed");
|
89
85
|
this->mark_failed();
|
90
86
|
return;
|
91
87
|
}
|
@@ -15,11 +15,11 @@ namespace pn532 {
|
|
15
15
|
static const char *const TAG = "pn532";
|
16
16
|
|
17
17
|
void PN532::setup() {
|
18
|
-
ESP_LOGCONFIG(TAG, "
|
18
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
19
19
|
|
20
20
|
// Get version data
|
21
21
|
if (!this->write_command_({PN532_COMMAND_VERSION_DATA})) {
|
22
|
-
ESP_LOGW(TAG, "Error sending version command, trying again
|
22
|
+
ESP_LOGW(TAG, "Error sending version command, trying again");
|
23
23
|
if (!this->write_command_({PN532_COMMAND_VERSION_DATA})) {
|
24
24
|
ESP_LOGE(TAG, "Error sending version command");
|
25
25
|
this->mark_failed();
|
@@ -208,21 +208,21 @@ void PN532::loop() {
|
|
208
208
|
}
|
209
209
|
}
|
210
210
|
} else if (next_task_ == CLEAN) {
|
211
|
-
ESP_LOGD(TAG, " Tag cleaning
|
211
|
+
ESP_LOGD(TAG, " Tag cleaning");
|
212
212
|
if (!this->clean_tag_(nfcid)) {
|
213
213
|
ESP_LOGE(TAG, " Tag was not fully cleaned successfully");
|
214
214
|
}
|
215
215
|
ESP_LOGD(TAG, " Tag cleaned!");
|
216
216
|
} else if (next_task_ == FORMAT) {
|
217
|
-
ESP_LOGD(TAG, " Tag formatting
|
217
|
+
ESP_LOGD(TAG, " Tag formatting");
|
218
218
|
if (!this->format_tag_(nfcid)) {
|
219
219
|
ESP_LOGE(TAG, "Error formatting tag as NDEF");
|
220
220
|
}
|
221
221
|
ESP_LOGD(TAG, " Tag formatted!");
|
222
222
|
} else if (next_task_ == WRITE) {
|
223
223
|
if (this->next_task_message_to_write_ != nullptr) {
|
224
|
-
ESP_LOGD(TAG, " Tag writing
|
225
|
-
ESP_LOGD(TAG, " Tag formatting
|
224
|
+
ESP_LOGD(TAG, " Tag writing");
|
225
|
+
ESP_LOGD(TAG, " Tag formatting");
|
226
226
|
if (!this->format_tag_(nfcid)) {
|
227
227
|
ESP_LOGE(TAG, " Tag could not be formatted for writing");
|
228
228
|
} else {
|
@@ -281,7 +281,7 @@ bool PN532::write_command_(const std::vector<uint8_t> &data) {
|
|
281
281
|
}
|
282
282
|
|
283
283
|
bool PN532::read_ack_() {
|
284
|
-
ESP_LOGV(TAG, "Reading ACK
|
284
|
+
ESP_LOGV(TAG, "Reading ACK");
|
285
285
|
|
286
286
|
std::vector<uint8_t> data;
|
287
287
|
if (!this->read_data(data, 6)) {
|
esphome/components/pn532/pn532.h
CHANGED
@@ -38,7 +38,7 @@ class PN532 : public PollingComponent {
|
|
38
38
|
float get_setup_priority() const override;
|
39
39
|
|
40
40
|
void loop() override;
|
41
|
-
void
|
41
|
+
void on_powerdown() override { powerdown(); }
|
42
42
|
|
43
43
|
void register_tag(PN532BinarySensor *tag) { this->binary_sensors_.push_back(tag); }
|
44
44
|
void register_ontag_trigger(nfc::NfcOnTagTrigger *trig) { this->triggers_ontag_.push_back(trig); }
|
@@ -830,7 +830,7 @@ void PN7150::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
830
830
|
|
831
831
|
switch (this->next_task_) {
|
832
832
|
case EP_CLEAN:
|
833
|
-
ESP_LOGD(TAG, " Tag cleaning
|
833
|
+
ESP_LOGD(TAG, " Tag cleaning");
|
834
834
|
if (this->clean_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
835
835
|
ESP_LOGE(TAG, " Tag cleaning incomplete");
|
836
836
|
}
|
@@ -838,7 +838,7 @@ void PN7150::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
838
838
|
break;
|
839
839
|
|
840
840
|
case EP_FORMAT:
|
841
|
-
ESP_LOGD(TAG, " Tag formatting
|
841
|
+
ESP_LOGD(TAG, " Tag formatting");
|
842
842
|
if (this->format_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
843
843
|
ESP_LOGE(TAG, "Error formatting tag as NDEF");
|
844
844
|
}
|
@@ -847,8 +847,8 @@ void PN7150::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
847
847
|
|
848
848
|
case EP_WRITE:
|
849
849
|
if (this->next_task_message_to_write_ != nullptr) {
|
850
|
-
ESP_LOGD(TAG, " Tag writing
|
851
|
-
ESP_LOGD(TAG, " Tag formatting
|
850
|
+
ESP_LOGD(TAG, " Tag writing");
|
851
|
+
ESP_LOGD(TAG, " Tag formatting");
|
852
852
|
if (this->format_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
853
853
|
ESP_LOGE(TAG, " Tag could not be formatted for writing");
|
854
854
|
} else {
|
@@ -854,7 +854,7 @@ void PN7160::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
854
854
|
|
855
855
|
switch (this->next_task_) {
|
856
856
|
case EP_CLEAN:
|
857
|
-
ESP_LOGD(TAG, " Tag cleaning
|
857
|
+
ESP_LOGD(TAG, " Tag cleaning");
|
858
858
|
if (this->clean_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
859
859
|
ESP_LOGE(TAG, " Tag cleaning incomplete");
|
860
860
|
}
|
@@ -862,7 +862,7 @@ void PN7160::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
862
862
|
break;
|
863
863
|
|
864
864
|
case EP_FORMAT:
|
865
|
-
ESP_LOGD(TAG, " Tag formatting
|
865
|
+
ESP_LOGD(TAG, " Tag formatting");
|
866
866
|
if (this->format_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
867
867
|
ESP_LOGE(TAG, "Error formatting tag as NDEF");
|
868
868
|
}
|
@@ -871,8 +871,8 @@ void PN7160::process_rf_intf_activated_oid_(nfc::NciMessage &rx) { // an endpoi
|
|
871
871
|
|
872
872
|
case EP_WRITE:
|
873
873
|
if (this->next_task_message_to_write_ != nullptr) {
|
874
|
-
ESP_LOGD(TAG, " Tag writing
|
875
|
-
ESP_LOGD(TAG, " Tag formatting
|
874
|
+
ESP_LOGD(TAG, " Tag writing");
|
875
|
+
ESP_LOGD(TAG, " Tag formatting");
|
876
876
|
if (this->format_endpoint_(working_endpoint.tag->get_uid()) != nfc::STATUS_OK) {
|
877
877
|
ESP_LOGE(TAG, " Tag could not be formatted for writing");
|
878
878
|
} else {
|
@@ -7,7 +7,7 @@ namespace power_supply {
|
|
7
7
|
static const char *const TAG = "power_supply";
|
8
8
|
|
9
9
|
void PowerSupply::setup() {
|
10
|
-
ESP_LOGCONFIG(TAG, "
|
10
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
11
11
|
|
12
12
|
this->pin_->setup();
|
13
13
|
this->pin_->digital_write(false);
|
@@ -17,8 +17,10 @@ void PowerSupply::setup() {
|
|
17
17
|
void PowerSupply::dump_config() {
|
18
18
|
ESP_LOGCONFIG(TAG, "Power Supply:");
|
19
19
|
LOG_PIN(" Pin: ", this->pin_);
|
20
|
-
ESP_LOGCONFIG(TAG,
|
21
|
-
|
20
|
+
ESP_LOGCONFIG(TAG,
|
21
|
+
" Time to enable: %" PRIu32 " ms\n"
|
22
|
+
" Keep on time: %.1f s",
|
23
|
+
this->enable_time_, this->keep_on_time_ / 1000.0f);
|
22
24
|
if (this->enable_on_boot_)
|
23
25
|
ESP_LOGCONFIG(TAG, " Enabled at startup: True");
|
24
26
|
}
|
@@ -50,7 +52,7 @@ void PowerSupply::unrequest_high_power() {
|
|
50
52
|
});
|
51
53
|
}
|
52
54
|
}
|
53
|
-
void PowerSupply::
|
55
|
+
void PowerSupply::on_powerdown() {
|
54
56
|
this->active_requests_ = 0;
|
55
57
|
this->pin_->digital_write(false);
|
56
58
|
}
|
@@ -2,13 +2,17 @@ import logging
|
|
2
2
|
|
3
3
|
import esphome.codegen as cg
|
4
4
|
from esphome.components.esp32 import (
|
5
|
+
CONF_CPU_FREQUENCY,
|
5
6
|
CONF_ENABLE_IDF_EXPERIMENTAL_FEATURES,
|
6
7
|
VARIANT_ESP32,
|
7
8
|
add_idf_sdkconfig_option,
|
8
9
|
get_esp32_variant,
|
9
|
-
only_on_variant,
|
10
10
|
)
|
11
|
-
from esphome.components.esp32.const import
|
11
|
+
from esphome.components.esp32.const import (
|
12
|
+
VARIANT_ESP32P4,
|
13
|
+
VARIANT_ESP32S2,
|
14
|
+
VARIANT_ESP32S3,
|
15
|
+
)
|
12
16
|
import esphome.config_validation as cv
|
13
17
|
from esphome.const import (
|
14
18
|
CONF_ADVANCED,
|
@@ -34,34 +38,46 @@ PsramComponent = psram_ns.class_("PsramComponent", cg.Component)
|
|
34
38
|
|
35
39
|
TYPE_QUAD = "quad"
|
36
40
|
TYPE_OCTAL = "octal"
|
41
|
+
TYPE_HEX = "hex"
|
42
|
+
|
43
|
+
SDK_MODES = {TYPE_QUAD: "QUAD", TYPE_OCTAL: "OCT", TYPE_HEX: "HEX"}
|
37
44
|
|
38
45
|
CONF_ENABLE_ECC = "enable_ecc"
|
39
46
|
|
40
47
|
SPIRAM_MODES = {
|
41
|
-
|
42
|
-
|
48
|
+
VARIANT_ESP32: (TYPE_QUAD,),
|
49
|
+
VARIANT_ESP32S2: (TYPE_QUAD,),
|
50
|
+
VARIANT_ESP32S3: (TYPE_QUAD, TYPE_OCTAL),
|
51
|
+
VARIANT_ESP32P4: (TYPE_HEX,),
|
43
52
|
}
|
44
53
|
|
54
|
+
|
45
55
|
SPIRAM_SPEEDS = {
|
46
|
-
|
47
|
-
|
48
|
-
|
56
|
+
VARIANT_ESP32: (40, 80, 120),
|
57
|
+
VARIANT_ESP32S2: (40, 80, 120),
|
58
|
+
VARIANT_ESP32S3: (40, 80, 120),
|
59
|
+
VARIANT_ESP32P4: (20, 100, 200),
|
49
60
|
}
|
50
61
|
|
51
62
|
|
52
63
|
def validate_psram_mode(config):
|
53
|
-
|
54
|
-
|
55
|
-
if
|
56
|
-
|
57
|
-
|
58
|
-
.get(CONF_ENABLE_IDF_EXPERIMENTAL_FEATURES)
|
59
|
-
):
|
60
|
-
_LOGGER.warning(
|
61
|
-
"120MHz PSRAM in octal mode is an experimental feature - use at your own risk"
|
64
|
+
esp32_config = fv.full_config.get()[PLATFORM_ESP32]
|
65
|
+
if config[CONF_SPEED] == "120MHZ":
|
66
|
+
if esp32_config[CONF_CPU_FREQUENCY] != "240MHZ":
|
67
|
+
raise cv.Invalid(
|
68
|
+
"PSRAM 120MHz requires 240MHz CPU frequency (set in esp32 component)"
|
62
69
|
)
|
63
|
-
|
64
|
-
|
70
|
+
if config[CONF_MODE] == TYPE_OCTAL:
|
71
|
+
if (
|
72
|
+
esp32_config[CONF_FRAMEWORK]
|
73
|
+
.get(CONF_ADVANCED, {})
|
74
|
+
.get(CONF_ENABLE_IDF_EXPERIMENTAL_FEATURES)
|
75
|
+
):
|
76
|
+
_LOGGER.warning(
|
77
|
+
"120MHz PSRAM in octal mode is an experimental feature - use at your own risk"
|
78
|
+
)
|
79
|
+
else:
|
80
|
+
raise cv.Invalid("PSRAM 120MHz is not supported in octal mode")
|
65
81
|
if config[CONF_MODE] != TYPE_OCTAL and config[CONF_ENABLE_ECC]:
|
66
82
|
raise cv.Invalid("ECC is only available in octal mode.")
|
67
83
|
if config[CONF_MODE] == TYPE_OCTAL:
|
@@ -73,23 +89,23 @@ def validate_psram_mode(config):
|
|
73
89
|
return config
|
74
90
|
|
75
91
|
|
76
|
-
|
77
|
-
|
92
|
+
def get_config_schema(config):
|
93
|
+
variant = get_esp32_variant()
|
94
|
+
speeds = [f"{s}MHZ" for s in SPIRAM_SPEEDS.get(variant, [])]
|
95
|
+
if not speeds:
|
96
|
+
return cv.Invalid("PSRAM is not supported on this chip")
|
97
|
+
modes = SPIRAM_MODES[variant]
|
98
|
+
return cv.Schema(
|
78
99
|
{
|
79
100
|
cv.GenerateID(): cv.declare_id(PsramComponent),
|
80
|
-
cv.Optional(CONF_MODE, default=
|
81
|
-
SPIRAM_MODES, lower=True
|
82
|
-
),
|
101
|
+
cv.Optional(CONF_MODE, default=modes[0]): cv.one_of(*modes, lower=True),
|
83
102
|
cv.Optional(CONF_ENABLE_ECC, default=False): cv.boolean,
|
84
|
-
cv.Optional(CONF_SPEED, default=
|
85
|
-
cv.frequency, cv.one_of(*SPIRAM_SPEEDS)
|
86
|
-
),
|
103
|
+
cv.Optional(CONF_SPEED, default=speeds[0]): cv.one_of(*speeds, upper=True),
|
87
104
|
}
|
88
|
-
)
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
)
|
105
|
+
)(config)
|
106
|
+
|
107
|
+
|
108
|
+
CONFIG_SCHEMA = get_config_schema
|
93
109
|
|
94
110
|
FINAL_VALIDATE_SCHEMA = validate_psram_mode
|
95
111
|
|
@@ -104,15 +120,23 @@ async def to_code(config):
|
|
104
120
|
add_idf_sdkconfig_option(
|
105
121
|
f"CONFIG_{get_esp32_variant().upper()}_SPIRAM_SUPPORT", True
|
106
122
|
)
|
123
|
+
add_idf_sdkconfig_option("CONFIG_SOC_SPIRAM_SUPPORTED", True)
|
107
124
|
add_idf_sdkconfig_option("CONFIG_SPIRAM", True)
|
108
125
|
add_idf_sdkconfig_option("CONFIG_SPIRAM_USE", True)
|
109
126
|
add_idf_sdkconfig_option("CONFIG_SPIRAM_USE_CAPS_ALLOC", True)
|
110
127
|
add_idf_sdkconfig_option("CONFIG_SPIRAM_IGNORE_NOTFOUND", True)
|
111
128
|
|
112
|
-
add_idf_sdkconfig_option(
|
113
|
-
|
114
|
-
|
115
|
-
|
129
|
+
add_idf_sdkconfig_option(
|
130
|
+
f"CONFIG_SPIRAM_MODE_{SDK_MODES[config[CONF_MODE]]}", True
|
131
|
+
)
|
132
|
+
|
133
|
+
# Remove MHz suffix, convert to int
|
134
|
+
speed = int(config[CONF_SPEED][:-3])
|
135
|
+
add_idf_sdkconfig_option(f"CONFIG_SPIRAM_SPEED_{speed}M", True)
|
136
|
+
add_idf_sdkconfig_option("CONFIG_SPIRAM_SPEED", speed)
|
137
|
+
if config[CONF_MODE] == TYPE_OCTAL and speed == 120:
|
138
|
+
add_idf_sdkconfig_option("CONFIG_ESPTOOLPY_FLASHFREQ_120M", True)
|
139
|
+
add_idf_sdkconfig_option("CONFIG_BOOTLOADER_FLASH_DC_AWARE", True)
|
116
140
|
if CORE.data[KEY_CORE][KEY_FRAMEWORK_VERSION] >= cv.Version(5, 4, 0):
|
117
141
|
add_idf_sdkconfig_option(
|
118
142
|
"CONFIG_SPIRAM_TIMING_TUNING_POINT_VIA_TEMPERATURE_SENSOR", True
|
@@ -156,7 +156,7 @@ pulse_counter_t HwPulseCounterStorage::read_raw_value() {
|
|
156
156
|
#endif // HAS_PCNT
|
157
157
|
|
158
158
|
void PulseCounterSensor::setup() {
|
159
|
-
ESP_LOGCONFIG(TAG, "
|
159
|
+
ESP_LOGCONFIG(TAG, "Running setup for '%s'", this->name_.c_str());
|
160
160
|
if (!this->storage_.pulse_counter_setup(this->pin_)) {
|
161
161
|
this->mark_failed();
|
162
162
|
return;
|
@@ -171,9 +171,12 @@ void PulseCounterSensor::set_total_pulses(uint32_t pulses) {
|
|
171
171
|
void PulseCounterSensor::dump_config() {
|
172
172
|
LOG_SENSOR("", "Pulse Counter", this);
|
173
173
|
LOG_PIN(" Pin: ", this->pin_);
|
174
|
-
ESP_LOGCONFIG(TAG,
|
175
|
-
|
176
|
-
|
174
|
+
ESP_LOGCONFIG(TAG,
|
175
|
+
" Rising Edge: %s\n"
|
176
|
+
" Falling Edge: %s\n"
|
177
|
+
" Filtering pulses shorter than %" PRIu32 " µs",
|
178
|
+
EDGE_MODE_TO_STRING[this->storage_.rising_edge_mode],
|
179
|
+
EDGE_MODE_TO_STRING[this->storage_.falling_edge_mode], this->storage_.filter_us);
|
177
180
|
LOG_UPDATE_INTERVAL(this);
|
178
181
|
}
|
179
182
|
|
@@ -8,11 +8,14 @@ namespace pvvx_mithermometer {
|
|
8
8
|
static const char *const TAG = "display.pvvx_mithermometer";
|
9
9
|
|
10
10
|
void PVVXDisplay::dump_config() {
|
11
|
-
ESP_LOGCONFIG(TAG,
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
11
|
+
ESP_LOGCONFIG(TAG,
|
12
|
+
"PVVX MiThermometer display:\n"
|
13
|
+
" MAC address : %s\n"
|
14
|
+
" Service UUID : %s\n"
|
15
|
+
" Characteristic UUID : %s\n"
|
16
|
+
" Auto clear : %s",
|
17
|
+
this->parent_->address_str().c_str(), this->service_uuid_.to_string().c_str(),
|
18
|
+
this->char_uuid_.to_string().c_str(), YESNO(this->auto_clear_enabled_));
|
16
19
|
#ifdef USE_TIME
|
17
20
|
ESP_LOGCONFIG(TAG, " Set time on connection: %s", YESNO(this->time_ != nullptr));
|
18
21
|
#endif
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#include "pylontech.h"
|
2
|
-
#include "esphome/core/log.h"
|
3
2
|
#include "esphome/core/helpers.h"
|
3
|
+
#include "esphome/core/log.h"
|
4
4
|
|
5
5
|
namespace esphome {
|
6
6
|
namespace pylontech {
|
@@ -26,7 +26,7 @@ void PylontechComponent::dump_config() {
|
|
26
26
|
}
|
27
27
|
|
28
28
|
void PylontechComponent::setup() {
|
29
|
-
ESP_LOGCONFIG(TAG, "
|
29
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
30
30
|
while (this->available() != 0) {
|
31
31
|
this->read();
|
32
32
|
}
|
@@ -10,8 +10,10 @@ static const char *const TAG = "pylontech.sensor";
|
|
10
10
|
PylontechSensor::PylontechSensor(int8_t bat_num) { this->bat_num_ = bat_num; }
|
11
11
|
|
12
12
|
void PylontechSensor::dump_config() {
|
13
|
-
ESP_LOGCONFIG(TAG,
|
14
|
-
|
13
|
+
ESP_LOGCONFIG(TAG,
|
14
|
+
"Pylontech Sensor:\n"
|
15
|
+
" Battery %d",
|
16
|
+
this->bat_num_);
|
15
17
|
LOG_SENSOR(" ", "Voltage", this->voltage_sensor_);
|
16
18
|
LOG_SENSOR(" ", "Current", this->current_sensor_);
|
17
19
|
LOG_SENSOR(" ", "Temperature", this->temperature_sensor_);
|
@@ -10,8 +10,10 @@ static const char *const TAG = "pylontech.textsensor";
|
|
10
10
|
PylontechTextSensor::PylontechTextSensor(int8_t bat_num) { this->bat_num_ = bat_num; }
|
11
11
|
|
12
12
|
void PylontechTextSensor::dump_config() {
|
13
|
-
ESP_LOGCONFIG(TAG,
|
14
|
-
|
13
|
+
ESP_LOGCONFIG(TAG,
|
14
|
+
"Pylontech Text Sensor:\n"
|
15
|
+
" Battery %d",
|
16
|
+
this->bat_num_);
|
15
17
|
LOG_TEXT_SENSOR(" ", "Base state", this->base_state_text_sensor_);
|
16
18
|
LOG_TEXT_SENSOR(" ", "Voltage state", this->voltage_state_text_sensor_);
|
17
19
|
LOG_TEXT_SENSOR(" ", "Current state", this->current_state_text_sensor_);
|
@@ -64,8 +64,10 @@ void PZEMAC::on_modbus_data(const std::vector<uint8_t> &data) {
|
|
64
64
|
|
65
65
|
void PZEMAC::update() { this->send(PZEM_CMD_READ_IN_REGISTERS, 0, PZEM_REGISTER_COUNT); }
|
66
66
|
void PZEMAC::dump_config() {
|
67
|
-
ESP_LOGCONFIG(TAG,
|
68
|
-
|
67
|
+
ESP_LOGCONFIG(TAG,
|
68
|
+
"PZEMAC:\n"
|
69
|
+
" Address: 0x%02X",
|
70
|
+
this->address_);
|
69
71
|
LOG_SENSOR("", "Voltage", this->voltage_sensor_);
|
70
72
|
LOG_SENSOR("", "Current", this->current_sensor_);
|
71
73
|
LOG_SENSOR("", "Power", this->power_sensor_);
|