esphome 2025.6.2__py3-none-any.whl → 2025.7.0__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 +1 -3
- esphome/codegen.py +2 -0
- esphome/components/ac_dimmer/ac_dimmer.cpp +6 -6
- esphome/components/adc/__init__.py +25 -1
- esphome/components/adc/adc_sensor.h +11 -11
- esphome/components/adc/adc_sensor_common.cpp +1 -1
- esphome/components/adc/adc_sensor_esp32.cpp +16 -8
- esphome/components/ade7880/ade7880.h +0 -2
- esphome/components/ads1115/ads1115.h +0 -1
- esphome/components/ads1118/ads1118.h +0 -1
- esphome/components/ags10/ags10.h +0 -2
- esphome/components/aic3204/aic3204.h +0 -1
- esphome/components/alarm_control_panel/__init__.py +5 -2
- esphome/components/alpha3/alpha3.h +0 -1
- esphome/components/am43/cover/am43_cover.h +0 -1
- esphome/components/am43/sensor/am43_sensor.h +0 -1
- esphome/components/analog_threshold/analog_threshold_binary_sensor.h +0 -2
- esphome/components/anova/anova.cpp +5 -1
- esphome/components/anova/anova.h +0 -1
- esphome/components/apds9960/apds9960.cpp +1 -1
- esphome/components/api/__init__.py +57 -21
- esphome/components/api/api_connection.cpp +344 -539
- esphome/components/api/api_connection.h +224 -141
- esphome/components/api/api_frame_helper.cpp +91 -127
- esphome/components/api/api_frame_helper.h +64 -54
- esphome/components/api/api_pb2.cpp +1837 -9044
- esphome/components/api/api_pb2.h +532 -685
- esphome/components/api/api_pb2_dump.cpp +4432 -0
- esphome/components/api/api_pb2_service.cpp +184 -425
- esphome/components/api/api_pb2_service.h +13 -6
- esphome/components/api/api_server.cpp +131 -167
- esphome/components/api/api_server.h +38 -10
- esphome/components/api/client.py +10 -4
- esphome/components/api/custom_api_device.h +8 -0
- esphome/components/api/list_entities.cpp +37 -104
- esphome/components/api/list_entities.h +33 -23
- esphome/components/api/proto.h +532 -26
- esphome/components/api/subscribe_state.cpp +23 -29
- esphome/components/api/subscribe_state.h +26 -19
- esphome/components/api/user_services.h +2 -0
- esphome/components/as3935_spi/as3935_spi.h +0 -2
- esphome/components/as5600/as5600.h +0 -1
- esphome/components/async_tcp/__init__.py +14 -5
- esphome/components/atc_mithermometer/atc_mithermometer.h +0 -1
- esphome/components/atm90e32/atm90e32.cpp +2 -1
- esphome/components/audio/audio_decoder.cpp +1 -1
- esphome/components/audio/audio_transfer_buffer.cpp +2 -2
- esphome/components/b_parasite/b_parasite.h +0 -1
- esphome/components/bedjet/bedjet_hub.cpp +5 -1
- esphome/components/bedjet/climate/bedjet_climate.cpp +5 -1
- esphome/components/beken_spi_led_strip/led_strip.cpp +4 -2
- esphome/components/bh1750/bh1750.cpp +5 -5
- esphome/components/binary_sensor/__init__.py +82 -5
- esphome/components/binary_sensor/automation.h +19 -1
- esphome/components/binary_sensor/binary_sensor.cpp +12 -30
- esphome/components/binary_sensor/binary_sensor.h +11 -25
- esphome/components/binary_sensor/filter.cpp +29 -24
- esphome/components/binary_sensor/filter.h +20 -10
- esphome/components/ble_client/output/ble_binary_output.h +0 -1
- esphome/components/ble_client/sensor/ble_rssi_sensor.cpp +5 -1
- esphome/components/ble_client/sensor/ble_rssi_sensor.h +0 -1
- esphome/components/ble_client/sensor/ble_sensor.cpp +5 -1
- esphome/components/ble_client/sensor/ble_sensor.h +0 -1
- esphome/components/ble_client/switch/ble_switch.h +0 -1
- esphome/components/ble_client/text_sensor/ble_text_sensor.cpp +5 -1
- esphome/components/ble_client/text_sensor/ble_text_sensor.h +0 -1
- esphome/components/ble_presence/ble_presence_device.h +0 -1
- esphome/components/ble_rssi/ble_rssi_sensor.h +0 -1
- esphome/components/ble_scanner/ble_scanner.h +0 -1
- esphome/components/bluetooth_proxy/bluetooth_connection.h +9 -2
- esphome/components/bluetooth_proxy/bluetooth_proxy.cpp +16 -6
- esphome/components/bluetooth_proxy/bluetooth_proxy.h +8 -2
- esphome/components/bme680/sensor.py +1 -1
- esphome/components/bmp581/bmp581.h +0 -2
- esphome/components/button/__init__.py +5 -2
- esphome/components/camera/__init__.py +1 -0
- esphome/components/camera/camera.cpp +22 -0
- esphome/components/camera/camera.h +80 -0
- esphome/components/canbus/__init__.py +1 -0
- esphome/components/cap1188/cap1188.h +0 -1
- esphome/components/captive_portal/__init__.py +12 -2
- esphome/components/captive_portal/captive_portal.cpp +12 -2
- esphome/components/captive_portal/captive_portal.h +5 -2
- esphome/components/ccs811/ccs811.h +0 -2
- esphome/components/climate/__init__.py +5 -2
- esphome/components/cm1106/sensor.py +2 -2
- esphome/components/const/__init__.py +2 -0
- esphome/components/copy/binary_sensor/copy_binary_sensor.h +0 -1
- esphome/components/copy/button/copy_button.h +0 -1
- esphome/components/copy/cover/copy_cover.h +0 -1
- esphome/components/copy/fan/copy_fan.h +0 -1
- esphome/components/copy/lock/copy_lock.h +0 -1
- esphome/components/copy/number/copy_number.h +0 -1
- esphome/components/copy/select/copy_select.h +0 -1
- esphome/components/copy/sensor/copy_sensor.h +0 -1
- esphome/components/copy/switch/copy_switch.h +0 -1
- esphome/components/copy/text/copy_text.h +0 -1
- esphome/components/copy/text_sensor/copy_text_sensor.h +0 -1
- esphome/components/cover/__init__.py +5 -2
- esphome/components/cs5460a/cs5460a.h +0 -1
- esphome/components/datetime/__init__.py +4 -2
- esphome/components/debug/__init__.py +20 -0
- esphome/components/debug/debug_esp32.cpp +2 -0
- esphome/components/deep_sleep/__init__.py +43 -9
- esphome/components/demo/__init__.py +2 -2
- esphome/components/display/display.cpp +4 -3
- esphome/components/display/display.h +0 -2
- esphome/components/display/display_buffer.cpp +1 -1
- esphome/components/ds2484/__init__.py +1 -0
- esphome/components/ds2484/ds2484.cpp +209 -0
- esphome/components/ds2484/ds2484.h +43 -0
- esphome/components/ds2484/one_wire.py +37 -0
- esphome/components/duty_time/duty_time_sensor.h +0 -1
- esphome/components/ens160_base/ens160_base.h +0 -1
- esphome/components/es7210/es7210.h +0 -1
- esphome/components/es7243e/es7243e.h +0 -1
- esphome/components/es8156/es8156.h +0 -1
- esphome/components/es8311/es8311.h +0 -1
- esphome/components/es8388/es8388.h +0 -1
- esphome/components/esp32/__init__.py +103 -135
- esphome/components/esp32/core.cpp +0 -4
- esphome/components/esp32/gpio.h +1 -1
- esphome/components/esp32/helpers.cpp +69 -0
- esphome/components/esp32_ble/ble.cpp +5 -6
- esphome/components/esp32_ble/ble.h +29 -14
- esphome/components/esp32_ble/ble_event.h +6 -6
- esphome/components/esp32_ble_client/ble_client_base.cpp +21 -6
- esphome/components/esp32_ble_client/ble_client_base.h +24 -9
- esphome/components/esp32_ble_tracker/__init__.py +2 -8
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.cpp +5 -5
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.h +11 -7
- esphome/components/esp32_camera/__init__.py +112 -98
- esphome/components/esp32_camera/esp32_camera.cpp +41 -31
- esphome/components/esp32_camera/esp32_camera.h +35 -30
- esphome/components/esp32_camera_web_server/__init__.py +2 -1
- esphome/components/esp32_camera_web_server/camera_web_server.cpp +8 -8
- esphome/components/esp32_camera_web_server/camera_web_server.h +3 -3
- esphome/components/esp32_hall/sensor.py +2 -21
- esphome/components/esp32_hosted/__init__.py +101 -0
- esphome/components/esp32_hosted/esp32_hosted.py.script +12 -0
- esphome/components/esp32_improv/esp32_improv_component.cpp +3 -0
- esphome/components/esp32_rmt/__init__.py +0 -58
- esphome/components/esp32_rmt_led_strip/led_strip.cpp +77 -63
- esphome/components/esp32_rmt_led_strip/led_strip.h +11 -17
- esphome/components/esp32_rmt_led_strip/light.py +14 -76
- esphome/components/esp32_touch/esp32_touch.h +174 -28
- esphome/components/esp32_touch/esp32_touch_common.cpp +162 -0
- esphome/components/esp32_touch/esp32_touch_v1.cpp +240 -0
- esphome/components/esp32_touch/esp32_touch_v2.cpp +397 -0
- esphome/components/esp8266/__init__.py +2 -0
- esphome/components/esp8266/gpio.cpp +10 -10
- esphome/components/esp8266/helpers.cpp +31 -0
- esphome/components/esp_ldo/__init__.py +10 -8
- esphome/components/esp_ldo/esp_ldo.h +3 -0
- esphome/components/esphome/ota/__init__.py +1 -0
- esphome/components/esphome/ota/ota_esphome.cpp +24 -19
- esphome/components/ethernet/__init__.py +42 -23
- esphome/components/ethernet/esp_eth_phy_jl1101.c +0 -16
- esphome/components/ethernet/ethernet_component.cpp +69 -29
- esphome/components/ethernet/ethernet_component.h +18 -10
- esphome/components/event/__init__.py +5 -2
- esphome/components/ezo/ezo.h +0 -1
- esphome/components/ezo_pmp/ezo_pmp.h +0 -1
- esphome/components/fan/__init__.py +5 -2
- esphome/components/fan/fan.cpp +4 -0
- esphome/components/feedback/feedback_cover.h +0 -1
- esphome/components/font/__init__.py +92 -82
- esphome/components/font/font.cpp +9 -2
- esphome/components/font/font.h +20 -5
- esphome/components/fs3000/fs3000.h +0 -1
- esphome/components/gcja5/gcja5.h +0 -1
- esphome/components/gl_r01_i2c/__init__.py +0 -0
- esphome/components/gl_r01_i2c/gl_r01_i2c.cpp +68 -0
- esphome/components/gl_r01_i2c/gl_r01_i2c.h +22 -0
- esphome/components/gl_r01_i2c/sensor.py +36 -0
- esphome/components/gp8403/gp8403.h +0 -1
- esphome/components/gpio/binary_sensor/__init__.py +39 -1
- esphome/components/gpio/binary_sensor/gpio_binary_sensor.cpp +77 -3
- esphome/components/gpio/binary_sensor/gpio_binary_sensor.h +40 -0
- esphome/components/grove_gas_mc_v2/grove_gas_mc_v2.h +0 -2
- esphome/components/he60r/he60r.h +0 -1
- esphome/components/heatpumpir/climate.py +2 -1
- esphome/components/heatpumpir/heatpumpir.cpp +1 -0
- esphome/components/heatpumpir/heatpumpir.h +1 -0
- esphome/components/honeywellabp2_i2c/honeywellabp2.h +0 -1
- esphome/components/host/__init__.py +3 -1
- esphome/components/host/helpers.cpp +57 -0
- esphome/components/http_request/__init__.py +19 -1
- esphome/components/http_request/http_request.h +1 -1
- esphome/components/http_request/http_request_arduino.cpp +0 -1
- esphome/components/http_request/http_request_arduino.h +1 -0
- esphome/components/http_request/http_request_idf.cpp +0 -1
- esphome/components/http_request/ota/ota_http_request.cpp +1 -1
- esphome/components/http_request/update/http_request_update.cpp +35 -16
- esphome/components/hydreon_rgxx/hydreon_rgxx.cpp +3 -9
- esphome/components/hydreon_rgxx/sensor.py +1 -1
- esphome/components/i2c/__init__.py +23 -11
- esphome/components/i2c/i2c_bus.h +8 -1
- esphome/components/i2c/i2c_bus_arduino.cpp +4 -3
- esphome/components/i2c/i2c_bus_arduino.h +6 -3
- esphome/components/i2c/i2c_bus_esp_idf.h +5 -3
- esphome/components/i2c_device/i2c_device.h +0 -1
- esphome/components/i2s_audio/__init__.py +2 -10
- esphome/components/i2s_audio/i2s_audio.cpp +1 -5
- esphome/components/i2s_audio/media_player/__init__.py +2 -2
- esphome/components/i2s_audio/speaker/__init__.py +1 -1
- esphome/components/i2s_audio/speaker/i2s_audio_speaker.cpp +2 -2
- esphome/components/iaqcore/iaqcore.h +0 -2
- esphome/components/image/__init__.py +123 -24
- esphome/components/improv_serial/improv_serial_component.cpp +0 -4
- esphome/components/ina219/ina219.cpp +7 -0
- esphome/components/ina219/ina219.h +1 -0
- esphome/components/ina260/ina260.h +0 -2
- esphome/components/inkbird_ibsth1_mini/inkbird_ibsth1_mini.h +0 -1
- esphome/components/inkplate6/display.py +15 -0
- esphome/components/inkplate6/inkplate.cpp +2 -2
- esphome/components/integration/integration_sensor.h +0 -1
- esphome/components/internal_temperature/internal_temperature.cpp +8 -27
- esphome/components/internal_temperature/sensor.py +0 -26
- esphome/components/interval/interval.h +0 -2
- esphome/components/json/__init__.py +1 -1
- esphome/components/json/json_util.cpp +56 -63
- esphome/components/ld2410/button/__init__.py +3 -3
- esphome/components/ld2410/button/factory_reset_button.cpp +9 -0
- esphome/components/ld2410/button/{reset_button.h → factory_reset_button.h} +2 -2
- esphome/components/ld2410/ld2410.cpp +421 -268
- esphome/components/ld2410/ld2410.h +44 -146
- esphome/components/ld2410/number/__init__.py +2 -2
- esphome/components/ld2410/sensor.py +1 -1
- esphome/components/ld2410/switch/__init__.py +1 -1
- esphome/components/ld2420/binary_sensor/ld2420_binary_sensor.cpp +2 -2
- esphome/components/ld2420/button/reconfig_buttons.cpp +1 -1
- esphome/components/ld2420/ld2420.cpp +252 -147
- esphome/components/ld2420/ld2420.h +52 -126
- esphome/components/ld2420/number/__init__.py +2 -2
- esphome/components/ld2420/number/gate_config_number.cpp +1 -1
- esphome/components/ld2420/select/operating_mode_select.cpp +1 -1
- esphome/components/ld2420/sensor/__init__.py +6 -2
- esphome/components/ld2420/sensor/ld2420_sensor.cpp +2 -2
- esphome/components/ld2420/sensor/ld2420_sensor.h +1 -1
- esphome/components/ld2420/text_sensor/text_sensor.cpp +2 -2
- esphome/components/ld2450/button/__init__.py +3 -3
- esphome/components/ld2450/button/factory_reset_button.cpp +9 -0
- esphome/components/ld2450/button/{reset_button.h → factory_reset_button.h} +2 -2
- esphome/components/ld2450/ld2450.cpp +384 -232
- esphome/components/ld2450/ld2450.h +60 -69
- esphome/components/ld2450/switch/__init__.py +1 -1
- esphome/components/ledc/ledc_output.cpp +1 -63
- esphome/components/libretiny/__init__.py +5 -3
- esphome/components/libretiny/const.py +5 -0
- esphome/components/libretiny/generate_components.py +1 -0
- esphome/components/libretiny/helpers.cpp +35 -0
- esphome/components/libretiny/lt_component.cpp +5 -3
- esphome/components/light/__init__.py +4 -2
- esphome/components/light/addressable_light.h +3 -3
- esphome/components/light/light_call.cpp +180 -243
- esphome/components/light/light_call.h +72 -20
- esphome/components/light/light_color_values.h +14 -14
- esphome/components/light/light_json_schema.cpp +17 -16
- esphome/components/light/light_state.h +15 -13
- esphome/components/light/transformers.h +2 -2
- esphome/components/ln882x/__init__.py +52 -0
- esphome/components/ln882x/boards.py +285 -0
- esphome/components/lock/__init__.py +5 -2
- esphome/components/logger/__init__.py +40 -3
- esphome/components/logger/logger.cpp +47 -12
- esphome/components/logger/logger.h +80 -49
- esphome/components/logger/logger_esp32.cpp +3 -3
- esphome/components/lps22/__init__.py +0 -0
- esphome/components/lps22/lps22.cpp +75 -0
- esphome/components/lps22/lps22.h +27 -0
- esphome/components/lps22/sensor.py +58 -0
- esphome/components/ltr390/ltr390.h +0 -1
- esphome/components/ltr501/ltr501.h +0 -1
- esphome/components/ltr_als_ps/ltr_als_ps.h +0 -1
- esphome/components/lvgl/__init__.py +1 -1
- esphome/components/lvgl/schemas.py +66 -6
- esphome/components/lvgl/styles.py +24 -16
- esphome/components/lvgl/widgets/__init__.py +12 -2
- esphome/components/lvgl/widgets/lv_bar.py +40 -19
- esphome/components/lvgl/widgets/meter.py +20 -13
- esphome/components/m5stack_8angle/light/m5stack_8angle_light.cpp +1 -1
- esphome/components/max9611/max9611.h +0 -1
- esphome/components/mcp23016/__init__.py +1 -1
- esphome/components/mcp23xxx_base/__init__.py +1 -1
- esphome/components/mcp4461/__init__.py +1 -1
- esphome/components/mcp4461/output/__init__.py +3 -2
- esphome/components/mcp9600/mcp9600.h +0 -2
- esphome/components/md5/md5.cpp +3 -3
- esphome/components/md5/md5.h +1 -6
- esphome/components/mdns/__init__.py +22 -11
- esphome/components/media_player/__init__.py +4 -3
- esphome/components/micro_wake_word/__init__.py +1 -5
- esphome/components/micro_wake_word/streaming_model.cpp +2 -2
- esphome/components/microphone/microphone.cpp +7 -9
- esphome/components/microphone/microphone.h +0 -2
- esphome/components/mipi_spi/display.py +1 -0
- esphome/components/mmc5603/mmc5603.cpp +1 -1
- esphome/components/modbus/modbus.cpp +33 -15
- esphome/components/modbus/modbus.h +9 -0
- esphome/components/modbus_controller/__init__.py +42 -10
- esphome/components/modbus_controller/modbus_controller.cpp +92 -11
- esphome/components/modbus_controller/modbus_controller.h +61 -7
- esphome/components/mopeka_pro_check/mopeka_pro_check.h +0 -1
- esphome/components/mopeka_std_check/mopeka_std_check.h +0 -1
- esphome/components/mpl3115a2/mpl3115a2.h +0 -2
- esphome/components/mqtt/__init__.py +16 -0
- esphome/components/mqtt/mqtt_alarm_control_panel.cpp +2 -1
- esphome/components/mqtt/mqtt_backend.h +2 -1
- esphome/components/mqtt/mqtt_backend_esp32.cpp +132 -47
- esphome/components/mqtt/mqtt_backend_esp32.h +106 -4
- esphome/components/mqtt/mqtt_binary_sensor.cpp +1 -0
- esphome/components/mqtt/mqtt_button.cpp +4 -1
- esphome/components/mqtt/mqtt_client.cpp +17 -9
- esphome/components/mqtt/mqtt_client.h +8 -3
- esphome/components/mqtt/mqtt_climate.cpp +6 -4
- esphome/components/mqtt/mqtt_component.cpp +3 -1
- esphome/components/mqtt/mqtt_cover.cpp +1 -0
- esphome/components/mqtt/mqtt_date.cpp +4 -3
- esphome/components/mqtt/mqtt_datetime.cpp +7 -6
- esphome/components/mqtt/mqtt_event.cpp +6 -3
- esphome/components/mqtt/mqtt_fan.cpp +1 -0
- esphome/components/mqtt/mqtt_light.cpp +8 -4
- esphome/components/mqtt/mqtt_lock.cpp +3 -1
- esphome/components/mqtt/mqtt_number.cpp +1 -0
- esphome/components/mqtt/mqtt_select.cpp +2 -1
- esphome/components/mqtt/mqtt_sensor.cpp +3 -1
- esphome/components/mqtt/mqtt_switch.cpp +3 -1
- esphome/components/mqtt/mqtt_text.cpp +1 -0
- esphome/components/mqtt/mqtt_text_sensor.cpp +3 -1
- esphome/components/mqtt/mqtt_time.cpp +4 -3
- esphome/components/mqtt/mqtt_update.cpp +1 -0
- esphome/components/mqtt/mqtt_valve.cpp +3 -1
- esphome/components/ms8607/ms8607.cpp +1 -1
- esphome/components/ms8607/ms8607.h +0 -1
- esphome/components/neopixelbus/light.py +4 -1
- esphome/components/neopixelbus/neopixelbus_light.h +1 -1
- esphome/components/network/__init__.py +4 -1
- esphome/components/network/ip_address.h +1 -0
- esphome/components/nextion/__init__.py +16 -0
- esphome/components/nextion/base_component.py +1 -0
- esphome/components/nextion/binary_sensor/nextion_binarysensor.cpp +1 -1
- esphome/components/nextion/display.py +14 -4
- esphome/components/nextion/nextion.cpp +166 -101
- esphome/components/nextion/nextion.h +84 -53
- esphome/components/nextion/nextion_commands.cpp +11 -10
- esphome/components/nextion/nextion_component.cpp +28 -28
- esphome/components/nextion/nextion_component.h +53 -18
- esphome/components/nextion/nextion_component_base.h +3 -0
- esphome/components/nextion/nextion_upload.cpp +36 -0
- esphome/components/nextion/nextion_upload_arduino.cpp +10 -35
- esphome/components/nextion/nextion_upload_idf.cpp +9 -33
- esphome/components/nextion/sensor/nextion_sensor.cpp +1 -1
- esphome/components/nextion/switch/nextion_switch.cpp +1 -1
- esphome/components/nextion/text_sensor/nextion_textsensor.cpp +1 -1
- esphome/components/nfc/nfc.cpp +3 -22
- esphome/components/nfc/nfc.h +3 -3
- esphome/components/number/__init__.py +5 -2
- esphome/components/online_image/__init__.py +9 -1
- esphome/components/online_image/online_image.cpp +17 -7
- esphome/components/online_image/online_image.h +10 -2
- esphome/components/opentherm/opentherm.cpp +7 -12
- esphome/components/opentherm/output/output.cpp +1 -1
- esphome/components/openthread/__init__.py +47 -40
- esphome/components/openthread/const.py +1 -0
- esphome/components/openthread/openthread_esp.cpp +27 -5
- esphome/components/opt3001/__init__.py +0 -0
- esphome/components/opt3001/opt3001.cpp +122 -0
- esphome/components/opt3001/opt3001.h +27 -0
- esphome/components/opt3001/sensor.py +35 -0
- esphome/components/ota/__init__.py +17 -0
- esphome/components/ota/ota_backend.h +27 -1
- esphome/components/ota/ota_backend_arduino_esp32.cpp +12 -2
- esphome/components/ota/ota_backend_arduino_esp32.h +3 -0
- esphome/components/ota/ota_backend_arduino_esp8266.cpp +18 -4
- esphome/components/ota/ota_backend_arduino_esp8266.h +3 -0
- esphome/components/ota/ota_backend_arduino_libretiny.cpp +12 -2
- esphome/components/ota/ota_backend_arduino_libretiny.h +3 -0
- esphome/components/ota/ota_backend_arduino_rp2040.cpp +9 -2
- esphome/components/ota/ota_backend_arduino_rp2040.h +3 -0
- esphome/components/ota/ota_backend_esp_idf.cpp +10 -16
- esphome/components/ota/ota_backend_esp_idf.h +1 -0
- esphome/components/packages/__init__.py +5 -2
- esphome/components/packet_transport/binary_sensor.py +61 -4
- esphome/components/packet_transport/packet_transport.cpp +34 -1
- esphome/components/packet_transport/packet_transport.h +11 -5
- esphome/components/pcf8574/__init__.py +1 -1
- esphome/components/pi4ioe5v6408/__init__.py +84 -0
- esphome/components/pi4ioe5v6408/pi4ioe5v6408.cpp +171 -0
- esphome/components/pi4ioe5v6408/pi4ioe5v6408.h +70 -0
- esphome/components/pmsa003i/pmsa003i.h +0 -1
- esphome/components/pmsx003/pmsx003.h +0 -1
- esphome/components/pn7150/pn7150.cpp +7 -7
- esphome/components/pn7150/pn7150.h +0 -1
- esphome/components/pn7160/pn7160.cpp +7 -7
- esphome/components/pn7160/pn7160.h +0 -1
- esphome/components/preferences/syncer.h +2 -0
- esphome/components/prometheus/prometheus_handler.h +1 -1
- esphome/components/psram/psram.cpp +0 -20
- esphome/components/pulse_counter/pulse_counter_sensor.h +0 -1
- esphome/components/pulse_meter/pulse_meter_sensor.cpp +8 -4
- esphome/components/pulse_width/pulse_width.h +0 -1
- esphome/components/pvvx_mithermometer/display/pvvx_display.cpp +0 -4
- esphome/components/pvvx_mithermometer/display/pvvx_display.h +0 -2
- esphome/components/pvvx_mithermometer/pvvx_mithermometer.h +0 -1
- esphome/components/qr_code/__init__.py +13 -10
- esphome/components/qwiic_pir/qwiic_pir.h +0 -1
- esphome/components/radon_eye_ble/radon_eye_listener.cpp +1 -1
- esphome/components/rc522/rc522.h +0 -1
- esphome/components/rdm6300/rdm6300.h +0 -2
- esphome/components/remote_base/__init__.py +7 -5
- esphome/components/remote_base/remote_base.cpp +24 -21
- esphome/components/remote_base/remote_base.h +3 -26
- esphome/components/remote_receiver/__init__.py +40 -46
- esphome/components/remote_receiver/remote_receiver.h +4 -18
- esphome/components/remote_receiver/remote_receiver_esp32.cpp +0 -87
- esphome/components/remote_receiver/remote_receiver_esp8266.cpp +1 -1
- esphome/components/remote_transmitter/__init__.py +42 -43
- esphome/components/remote_transmitter/remote_transmitter.h +2 -14
- esphome/components/remote_transmitter/remote_transmitter_esp32.cpp +0 -77
- esphome/components/resistance/resistance_sensor.h +0 -1
- esphome/components/rp2040/__init__.py +2 -0
- esphome/components/rp2040/helpers.cpp +55 -0
- esphome/components/rp2040_pio_led_strip/led_strip.cpp +2 -2
- esphome/components/rpi_dpi_rgb/rpi_dpi_rgb.cpp +0 -4
- esphome/components/rtttl/__init__.py +4 -4
- esphome/components/rtttl/rtttl.cpp +10 -1
- esphome/components/ruuvitag/ruuvitag.h +0 -1
- esphome/components/safe_mode/safe_mode.cpp +2 -0
- esphome/components/safe_mode/safe_mode.h +4 -1
- esphome/components/scd30/scd30.h +0 -1
- esphome/components/scd30/sensor.py +2 -2
- esphome/components/scd4x/scd4x.cpp +61 -54
- esphome/components/scd4x/scd4x.h +17 -15
- esphome/components/scd4x/sensor.py +4 -4
- esphome/components/script/script.h +0 -2
- esphome/components/sdp3x/sensor.py +1 -1
- esphome/components/select/__init__.py +5 -2
- esphome/components/sen5x/sen5x.h +0 -1
- esphome/components/senseair/senseair.h +0 -1
- esphome/components/sensor/__init__.py +4 -2
- esphome/components/sensor/filter.cpp +1 -1
- esphome/components/sensor/sensor.cpp +12 -6
- esphome/components/sensor/sensor.h +13 -5
- esphome/components/servo/servo.cpp +2 -2
- esphome/components/servo/servo.h +0 -1
- esphome/components/sfa30/sfa30.h +0 -1
- esphome/components/sgp30/sgp30.h +0 -1
- esphome/components/sgp4x/sgp4x.h +0 -1
- esphome/components/shelly_dimmer/stm32flash.cpp +1 -2
- esphome/components/sht4x/sht4x.h +0 -1
- esphome/components/sm300d2/sm300d2.h +0 -2
- esphome/components/smt100/sensor.py +8 -4
- esphome/components/smt100/smt100.cpp +5 -5
- esphome/components/smt100/smt100.h +3 -3
- esphome/components/sn74hc595/__init__.py +1 -1
- esphome/components/sn74hc595/sn74hc595.cpp +5 -4
- esphome/components/sntp/sntp_component.cpp +9 -3
- esphome/components/sntp/time.py +2 -0
- esphome/components/socket/__init__.py +17 -0
- esphome/components/spi/__init__.py +27 -6
- esphome/components/spi/spi.cpp +3 -2
- esphome/components/spi/spi.h +9 -3
- esphome/components/spi/spi_arduino.cpp +3 -5
- esphome/components/spi/spi_esp_idf.cpp +40 -21
- esphome/components/spi_led_strip/spi_led_strip.cpp +1 -1
- esphome/components/sps30/sps30.h +0 -1
- esphome/components/ssd1306_base/ssd1306_base.cpp +1 -1
- esphome/components/st7701s/st7701s.cpp +0 -4
- esphome/components/status/status_binary_sensor.h +0 -2
- esphome/components/substitutions/__init__.py +81 -21
- esphome/components/substitutions/jinja.py +99 -0
- esphome/components/sun/sun.cpp +3 -4
- esphome/components/switch/__init__.py +5 -2
- esphome/components/switch/binary_sensor/switch_binary_sensor.h +0 -1
- esphome/components/sx126x/__init__.py +317 -0
- esphome/components/sx126x/automation.h +62 -0
- esphome/components/sx126x/packet_transport/__init__.py +26 -0
- esphome/components/sx126x/packet_transport/sx126x_transport.cpp +26 -0
- esphome/components/sx126x/packet_transport/sx126x_transport.h +25 -0
- esphome/components/sx126x/sx126x.cpp +523 -0
- esphome/components/sx126x/sx126x.h +140 -0
- esphome/components/sx126x/sx126x_reg.h +163 -0
- esphome/components/sx127x/__init__.py +325 -0
- esphome/components/sx127x/automation.h +62 -0
- esphome/components/sx127x/packet_transport/__init__.py +26 -0
- esphome/components/sx127x/packet_transport/sx127x_transport.cpp +26 -0
- esphome/components/sx127x/packet_transport/sx127x_transport.h +25 -0
- esphome/components/sx127x/sx127x.cpp +498 -0
- esphome/components/sx127x/sx127x.h +128 -0
- esphome/components/sx127x/sx127x_reg.h +295 -0
- esphome/components/syslog/esphome_syslog.cpp +5 -3
- esphome/components/syslog/esphome_syslog.h +1 -1
- esphome/components/tca9555/__init__.py +1 -1
- esphome/components/template/binary_sensor/template_binary_sensor.cpp +1 -9
- esphome/components/text/__init__.py +5 -2
- esphome/components/text_sensor/__init__.py +5 -2
- esphome/components/thermostat/thermostat_climate.cpp +34 -31
- esphome/components/thermostat/thermostat_climate.h +43 -39
- esphome/components/time/__init__.py +16 -2
- esphome/components/time/real_time_clock.cpp +4 -0
- esphome/components/time/real_time_clock.h +5 -1
- esphome/components/tlc5971/tlc5971.cpp +4 -1
- esphome/components/tmp1075/tmp1075.h +0 -2
- esphome/components/tof10120/tof10120_sensor.h +0 -1
- esphome/components/tormatic/tormatic_cover.h +0 -1
- esphome/components/total_daily_energy/total_daily_energy.h +0 -1
- esphome/components/tsl2591/tsl2591.cpp +1 -1
- esphome/components/ttp229_bsf/ttp229_bsf.h +0 -1
- esphome/components/ttp229_lsf/ttp229_lsf.h +0 -1
- esphome/components/tx20/tx20.cpp +2 -2
- esphome/components/uart/__init__.py +18 -0
- esphome/components/uart/uart_component_esp_idf.cpp +1 -5
- esphome/components/update/__init__.py +5 -2
- esphome/components/update/update_entity.h +8 -0
- esphome/components/usb_host/__init__.py +5 -2
- esphome/components/usb_host/usb_host_client.cpp +10 -10
- esphome/components/usb_uart/cp210x.cpp +1 -1
- esphome/components/usb_uart/usb_uart.cpp +41 -44
- esphome/components/usb_uart/usb_uart.h +4 -3
- esphome/components/valve/__init__.py +5 -2
- esphome/components/vbus/vbus.h +0 -1
- esphome/components/veml3235/veml3235.h +0 -1
- esphome/components/veml7700/veml7700.h +0 -1
- esphome/components/vl53l0x/vl53l0x_sensor.h +0 -1
- esphome/components/voice_assistant/voice_assistant.cpp +4 -4
- esphome/components/watchdog/watchdog.cpp +0 -4
- esphome/components/waveshare_epaper/waveshare_epaper.cpp +6 -6
- esphome/components/web_server/__init__.py +34 -19
- esphome/components/web_server/ota/__init__.py +32 -0
- esphome/components/web_server/ota/ota_web_server.cpp +210 -0
- esphome/components/web_server/ota/ota_web_server.h +26 -0
- esphome/components/web_server/web_server.cpp +324 -439
- esphome/components/web_server/web_server.h +33 -23
- esphome/components/web_server/web_server_v1.cpp +4 -5
- esphome/components/web_server_base/__init__.py +5 -2
- esphome/components/web_server_base/web_server_base.cpp +2 -94
- esphome/components/web_server_base/web_server_base.h +5 -25
- esphome/components/web_server_idf/multipart.cpp +254 -0
- esphome/components/web_server_idf/multipart.h +86 -0
- esphome/components/web_server_idf/utils.cpp +32 -0
- esphome/components/web_server_idf/utils.h +10 -0
- esphome/components/web_server_idf/web_server_idf.cpp +164 -16
- esphome/components/web_server_idf/web_server_idf.h +11 -10
- esphome/components/wiegand/wiegand.cpp +2 -2
- esphome/components/wifi/__init__.py +18 -0
- esphome/components/wifi/wifi_component.cpp +17 -22
- esphome/components/wifi/wifi_component.h +27 -23
- esphome/components/wifi/wifi_component_esp32_arduino.cpp +52 -59
- esphome/components/wifi/wifi_component_esp8266.cpp +46 -46
- esphome/components/wifi/wifi_component_esp_idf.cpp +35 -36
- esphome/components/wifi/wifi_component_libretiny.cpp +26 -27
- esphome/components/wifi/wifi_component_pico_w.cpp +3 -3
- esphome/components/wifi_info/wifi_info_text_sensor.cpp +6 -6
- esphome/components/wireguard/__init__.py +2 -11
- esphome/components/xiaomi_ble/xiaomi_ble.cpp +13 -1
- esphome/components/xiaomi_ble/xiaomi_ble.h +1 -0
- esphome/components/xiaomi_cgd1/xiaomi_cgd1.h +0 -1
- esphome/components/xiaomi_cgdk2/xiaomi_cgdk2.h +0 -1
- esphome/components/xiaomi_cgg1/xiaomi_cgg1.h +0 -1
- esphome/components/xiaomi_cgpr1/xiaomi_cgpr1.h +0 -1
- esphome/components/xiaomi_gcls002/xiaomi_gcls002.h +0 -1
- esphome/components/xiaomi_hhccjcy01/xiaomi_hhccjcy01.h +0 -1
- esphome/components/xiaomi_hhccjcy10/xiaomi_hhccjcy10.h +0 -1
- esphome/components/xiaomi_hhccpot002/xiaomi_hhccpot002.h +0 -1
- esphome/components/xiaomi_jqjcy01ym/xiaomi_jqjcy01ym.h +0 -1
- esphome/components/xiaomi_lywsd02/xiaomi_lywsd02.h +0 -1
- esphome/components/xiaomi_lywsd02mmc/xiaomi_lywsd02mmc.h +0 -1
- esphome/components/xiaomi_lywsd03mmc/xiaomi_lywsd03mmc.h +0 -1
- esphome/components/xiaomi_lywsdcgq/xiaomi_lywsdcgq.h +0 -1
- esphome/components/xiaomi_mhoc303/xiaomi_mhoc303.h +0 -1
- esphome/components/xiaomi_mhoc401/xiaomi_mhoc401.h +0 -1
- esphome/components/xiaomi_miscale/xiaomi_miscale.h +0 -1
- esphome/components/xiaomi_mjyd02yla/xiaomi_mjyd02yla.h +0 -1
- esphome/components/xiaomi_mue4094rt/xiaomi_mue4094rt.h +0 -1
- esphome/components/xiaomi_rtcgq02lm/xiaomi_rtcgq02lm.h +0 -1
- esphome/components/xiaomi_wx08zm/xiaomi_wx08zm.h +0 -1
- esphome/components/xiaomi_xmwsdj04mmc/__init__.py +0 -0
- esphome/components/xiaomi_xmwsdj04mmc/sensor.py +77 -0
- esphome/components/xiaomi_xmwsdj04mmc/xiaomi_xmwsdj04mmc.cpp +77 -0
- esphome/components/xiaomi_xmwsdj04mmc/xiaomi_xmwsdj04mmc.h +36 -0
- esphome/components/zio_ultrasonic/zio_ultrasonic.h +0 -2
- esphome/components/zyaura/zyaura.h +0 -1
- esphome/config.py +88 -22
- esphome/config_helpers.py +74 -1
- esphome/config_validation.py +12 -1
- esphome/const.py +65 -10
- esphome/core/__init__.py +18 -2
- esphome/core/application.cpp +169 -10
- esphome/core/application.h +145 -165
- esphome/core/area.h +19 -0
- esphome/core/automation.h +58 -9
- esphome/core/color.cpp +3 -5
- esphome/core/color.h +16 -16
- esphome/core/component.cpp +156 -22
- esphome/core/component.h +98 -4
- esphome/core/component_iterator.cpp +11 -9
- esphome/core/component_iterator.h +12 -10
- esphome/core/config.py +155 -6
- esphome/core/controller.cpp +4 -2
- esphome/core/controller.h +1 -1
- esphome/core/datatypes.h +2 -2
- esphome/core/defines.h +17 -2
- esphome/core/device.h +20 -0
- esphome/core/entity_base.cpp +20 -15
- esphome/core/entity_base.h +76 -0
- esphome/core/entity_helpers.py +168 -1
- esphome/core/event_pool.h +81 -0
- esphome/core/helpers.cpp +75 -230
- esphome/core/helpers.h +165 -105
- esphome/core/lock_free_queue.h +151 -0
- esphome/core/log.cpp +2 -2
- esphome/core/log.h +2 -0
- esphome/core/optional.h +5 -0
- esphome/core/ring_buffer.cpp +2 -2
- esphome/core/scheduler.cpp +275 -103
- esphome/core/scheduler.h +154 -17
- esphome/core/time.cpp +5 -5
- esphome/core/time.h +5 -5
- esphome/cpp_generator.py +17 -0
- esphome/cpp_helpers.py +0 -22
- esphome/cpp_types.py +3 -1
- esphome/dashboard/entries.py +1 -1
- esphome/dashboard/util/text.py +5 -21
- esphome/dashboard/web_server.py +9 -1
- esphome/helpers.py +47 -0
- esphome/loader.py +15 -1
- esphome/pins.py +14 -8
- esphome/platformio_api.py +2 -0
- esphome/wizard.py +17 -4
- esphome/writer.py +44 -3
- esphome/yaml_util.py +0 -2
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/METADATA +10 -9
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/RECORD +639 -580
- esphome/components/api/api_pb2_size.h +0 -361
- esphome/components/esp32_ble/ble_event_pool.h +0 -72
- esphome/components/esp32_ble/queue.h +0 -85
- esphome/components/esp32_hall/esp32_hall.cpp +0 -25
- esphome/components/esp32_hall/esp32_hall.h +0 -23
- esphome/components/esp32_touch/esp32_touch.cpp +0 -355
- esphome/components/ld2410/button/reset_button.cpp +0 -9
- esphome/components/ld2450/button/reset_button.cpp +0 -9
- esphome/components/openthread/tlv.py +0 -65
- /esphome/{dashboard/enum.py → enum.py} +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/WHEEL +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/entry_points.txt +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/licenses/LICENSE +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import esphome.codegen as cg
|
|
2
|
+
from esphome.components.packet_transport import (
|
|
3
|
+
PacketTransport,
|
|
4
|
+
new_packet_transport,
|
|
5
|
+
transport_schema,
|
|
6
|
+
)
|
|
7
|
+
import esphome.config_validation as cv
|
|
8
|
+
from esphome.cpp_types import PollingComponent
|
|
9
|
+
|
|
10
|
+
from .. import CONF_SX127X_ID, SX127x, SX127xListener, sx127x_ns
|
|
11
|
+
|
|
12
|
+
SX127xTransport = sx127x_ns.class_(
|
|
13
|
+
"SX127xTransport", PacketTransport, PollingComponent, SX127xListener
|
|
14
|
+
)
|
|
15
|
+
|
|
16
|
+
CONFIG_SCHEMA = transport_schema(SX127xTransport).extend(
|
|
17
|
+
{
|
|
18
|
+
cv.GenerateID(CONF_SX127X_ID): cv.use_id(SX127x),
|
|
19
|
+
}
|
|
20
|
+
)
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
async def to_code(config):
|
|
24
|
+
var, _ = await new_packet_transport(config)
|
|
25
|
+
sx127x = await cg.get_variable(config[CONF_SX127X_ID])
|
|
26
|
+
cg.add(var.set_parent(sx127x))
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
#include "esphome/core/log.h"
|
|
2
|
+
#include "esphome/core/application.h"
|
|
3
|
+
#include "sx127x_transport.h"
|
|
4
|
+
|
|
5
|
+
namespace esphome {
|
|
6
|
+
namespace sx127x {
|
|
7
|
+
|
|
8
|
+
static const char *const TAG = "sx127x_transport";
|
|
9
|
+
|
|
10
|
+
void SX127xTransport::setup() {
|
|
11
|
+
PacketTransport::setup();
|
|
12
|
+
this->parent_->register_listener(this);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
void SX127xTransport::update() {
|
|
16
|
+
PacketTransport::update();
|
|
17
|
+
this->updated_ = true;
|
|
18
|
+
this->resend_data_ = true;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
void SX127xTransport::send_packet(const std::vector<uint8_t> &buf) const { this->parent_->transmit_packet(buf); }
|
|
22
|
+
|
|
23
|
+
void SX127xTransport::on_packet(const std::vector<uint8_t> &packet, float rssi, float snr) { this->process_(packet); }
|
|
24
|
+
|
|
25
|
+
} // namespace sx127x
|
|
26
|
+
} // namespace esphome
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include "esphome/core/component.h"
|
|
4
|
+
#include "esphome/components/sx127x/sx127x.h"
|
|
5
|
+
#include "esphome/components/packet_transport/packet_transport.h"
|
|
6
|
+
#include <vector>
|
|
7
|
+
|
|
8
|
+
namespace esphome {
|
|
9
|
+
namespace sx127x {
|
|
10
|
+
|
|
11
|
+
class SX127xTransport : public packet_transport::PacketTransport, public Parented<SX127x>, public SX127xListener {
|
|
12
|
+
public:
|
|
13
|
+
void setup() override;
|
|
14
|
+
void update() override;
|
|
15
|
+
void on_packet(const std::vector<uint8_t> &packet, float rssi, float snr) override;
|
|
16
|
+
float get_setup_priority() const override { return setup_priority::AFTER_WIFI; }
|
|
17
|
+
|
|
18
|
+
protected:
|
|
19
|
+
void send_packet(const std::vector<uint8_t> &buf) const override;
|
|
20
|
+
bool should_send() override { return true; }
|
|
21
|
+
size_t get_max_packet_size() override { return this->parent_->get_max_packet_size(); }
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
} // namespace sx127x
|
|
25
|
+
} // namespace esphome
|
|
@@ -0,0 +1,498 @@
|
|
|
1
|
+
#include "sx127x.h"
|
|
2
|
+
#include "esphome/core/hal.h"
|
|
3
|
+
#include "esphome/core/log.h"
|
|
4
|
+
|
|
5
|
+
namespace esphome {
|
|
6
|
+
namespace sx127x {
|
|
7
|
+
|
|
8
|
+
static const char *const TAG = "sx127x";
|
|
9
|
+
static const uint32_t FXOSC = 32000000u;
|
|
10
|
+
static const uint16_t RAMP[16] = {3400, 2000, 1000, 500, 250, 125, 100, 62, 50, 40, 31, 25, 20, 15, 12, 10};
|
|
11
|
+
static const uint32_t BW_HZ[22] = {2604, 3125, 3906, 5208, 6250, 7812, 10416, 12500, 15625, 20833, 25000,
|
|
12
|
+
31250, 41666, 50000, 62500, 83333, 100000, 125000, 166666, 200000, 250000, 500000};
|
|
13
|
+
static const uint8_t BW_LORA[22] = {BW_7_8, BW_7_8, BW_7_8, BW_7_8, BW_7_8, BW_7_8, BW_10_4, BW_15_6,
|
|
14
|
+
BW_15_6, BW_20_8, BW_31_3, BW_31_3, BW_41_7, BW_62_5, BW_62_5, BW_125_0,
|
|
15
|
+
BW_125_0, BW_125_0, BW_250_0, BW_250_0, BW_250_0, BW_500_0};
|
|
16
|
+
static const uint8_t BW_FSK_OOK[22] = {RX_BW_2_6, RX_BW_3_1, RX_BW_3_9, RX_BW_5_2, RX_BW_6_3, RX_BW_7_8,
|
|
17
|
+
RX_BW_10_4, RX_BW_12_5, RX_BW_15_6, RX_BW_20_8, RX_BW_25_0, RX_BW_31_3,
|
|
18
|
+
RX_BW_41_7, RX_BW_50_0, RX_BW_62_5, RX_BW_83_3, RX_BW_100_0, RX_BW_125_0,
|
|
19
|
+
RX_BW_166_7, RX_BW_200_0, RX_BW_250_0, RX_BW_250_0};
|
|
20
|
+
static const int32_t RSSI_OFFSET_HF = 157;
|
|
21
|
+
static const int32_t RSSI_OFFSET_LF = 164;
|
|
22
|
+
|
|
23
|
+
uint8_t SX127x::read_register_(uint8_t reg) {
|
|
24
|
+
this->enable();
|
|
25
|
+
this->write_byte(reg & 0x7F);
|
|
26
|
+
uint8_t value = this->read_byte();
|
|
27
|
+
this->disable();
|
|
28
|
+
return value;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
void SX127x::write_register_(uint8_t reg, uint8_t value) {
|
|
32
|
+
this->enable();
|
|
33
|
+
this->write_byte(reg | 0x80);
|
|
34
|
+
this->write_byte(value);
|
|
35
|
+
this->disable();
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
void SX127x::read_fifo_(std::vector<uint8_t> &packet) {
|
|
39
|
+
this->enable();
|
|
40
|
+
this->write_byte(REG_FIFO & 0x7F);
|
|
41
|
+
this->read_array(packet.data(), packet.size());
|
|
42
|
+
this->disable();
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
void SX127x::write_fifo_(const std::vector<uint8_t> &packet) {
|
|
46
|
+
this->enable();
|
|
47
|
+
this->write_byte(REG_FIFO | 0x80);
|
|
48
|
+
this->write_array(packet.data(), packet.size());
|
|
49
|
+
this->disable();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
void SX127x::setup() {
|
|
53
|
+
ESP_LOGCONFIG(TAG, "Running setup");
|
|
54
|
+
|
|
55
|
+
// setup reset
|
|
56
|
+
this->rst_pin_->setup();
|
|
57
|
+
|
|
58
|
+
// setup dio0
|
|
59
|
+
if (this->dio0_pin_) {
|
|
60
|
+
this->dio0_pin_->setup();
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// start spi
|
|
64
|
+
this->spi_setup();
|
|
65
|
+
|
|
66
|
+
// configure rf
|
|
67
|
+
this->configure();
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
void SX127x::configure() {
|
|
71
|
+
// toggle chip reset
|
|
72
|
+
this->rst_pin_->digital_write(false);
|
|
73
|
+
delayMicroseconds(1000);
|
|
74
|
+
this->rst_pin_->digital_write(true);
|
|
75
|
+
delayMicroseconds(10000);
|
|
76
|
+
|
|
77
|
+
// check silicon version to make sure hw is ok
|
|
78
|
+
if (this->read_register_(REG_VERSION) != 0x12) {
|
|
79
|
+
this->mark_failed();
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// enter sleep mode
|
|
84
|
+
this->set_mode_(MOD_FSK, MODE_SLEEP);
|
|
85
|
+
|
|
86
|
+
// set freq
|
|
87
|
+
uint64_t frf = ((uint64_t) this->frequency_ << 19) / FXOSC;
|
|
88
|
+
this->write_register_(REG_FRF_MSB, (uint8_t) ((frf >> 16) & 0xFF));
|
|
89
|
+
this->write_register_(REG_FRF_MID, (uint8_t) ((frf >> 8) & 0xFF));
|
|
90
|
+
this->write_register_(REG_FRF_LSB, (uint8_t) ((frf >> 0) & 0xFF));
|
|
91
|
+
|
|
92
|
+
// enter standby mode
|
|
93
|
+
this->set_mode_(MOD_FSK, MODE_STDBY);
|
|
94
|
+
|
|
95
|
+
// run image cal
|
|
96
|
+
this->run_image_cal();
|
|
97
|
+
|
|
98
|
+
// go back to sleep
|
|
99
|
+
this->set_mode_sleep();
|
|
100
|
+
|
|
101
|
+
// config pa
|
|
102
|
+
if (this->pa_pin_ == PA_PIN_BOOST) {
|
|
103
|
+
this->pa_power_ = std::max(this->pa_power_, (uint8_t) 2);
|
|
104
|
+
this->pa_power_ = std::min(this->pa_power_, (uint8_t) 17);
|
|
105
|
+
this->write_register_(REG_PA_CONFIG, (this->pa_power_ - 2) | this->pa_pin_ | PA_MAX_POWER);
|
|
106
|
+
} else {
|
|
107
|
+
this->pa_power_ = std::min(this->pa_power_, (uint8_t) 14);
|
|
108
|
+
this->write_register_(REG_PA_CONFIG, (this->pa_power_ - 0) | this->pa_pin_ | PA_MAX_POWER);
|
|
109
|
+
}
|
|
110
|
+
if (this->modulation_ != MOD_LORA) {
|
|
111
|
+
this->write_register_(REG_PA_RAMP, this->pa_ramp_ | this->shaping_);
|
|
112
|
+
} else {
|
|
113
|
+
this->write_register_(REG_PA_RAMP, this->pa_ramp_);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// configure modem
|
|
117
|
+
if (this->modulation_ != MOD_LORA) {
|
|
118
|
+
this->configure_fsk_ook_();
|
|
119
|
+
} else {
|
|
120
|
+
this->configure_lora_();
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// switch to rx or sleep
|
|
124
|
+
if (this->rx_start_) {
|
|
125
|
+
this->set_mode_rx();
|
|
126
|
+
} else {
|
|
127
|
+
this->set_mode_sleep();
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
void SX127x::configure_fsk_ook_() {
|
|
132
|
+
// set the channel bw
|
|
133
|
+
this->write_register_(REG_RX_BW, BW_FSK_OOK[this->bandwidth_]);
|
|
134
|
+
|
|
135
|
+
// set fdev
|
|
136
|
+
uint32_t fdev = std::min((this->deviation_ * 4096) / 250000, (uint32_t) 0x3FFF);
|
|
137
|
+
this->write_register_(REG_FDEV_MSB, (uint8_t) ((fdev >> 8) & 0xFF));
|
|
138
|
+
this->write_register_(REG_FDEV_LSB, (uint8_t) ((fdev >> 0) & 0xFF));
|
|
139
|
+
|
|
140
|
+
// set bitrate
|
|
141
|
+
uint64_t bitrate = (FXOSC + this->bitrate_ / 2) / this->bitrate_; // round up
|
|
142
|
+
this->write_register_(REG_BITRATE_MSB, (uint8_t) ((bitrate >> 8) & 0xFF));
|
|
143
|
+
this->write_register_(REG_BITRATE_LSB, (uint8_t) ((bitrate >> 0) & 0xFF));
|
|
144
|
+
|
|
145
|
+
// configure rx and afc
|
|
146
|
+
uint8_t trigger = (this->preamble_detect_ > 0) ? TRIGGER_PREAMBLE : TRIGGER_RSSI;
|
|
147
|
+
this->write_register_(REG_AFC_FEI, AFC_AUTO_CLEAR_ON);
|
|
148
|
+
if (this->modulation_ == MOD_FSK) {
|
|
149
|
+
this->write_register_(REG_RX_CONFIG, AFC_AUTO_ON | AGC_AUTO_ON | trigger);
|
|
150
|
+
} else {
|
|
151
|
+
this->write_register_(REG_RX_CONFIG, AGC_AUTO_ON | trigger);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
// configure packet mode
|
|
155
|
+
if (this->packet_mode_) {
|
|
156
|
+
uint8_t crc_mode = (this->crc_enable_) ? CRC_ON : CRC_OFF;
|
|
157
|
+
this->write_register_(REG_FIFO_THRESH, TX_START_FIFO_EMPTY);
|
|
158
|
+
if (this->payload_length_ > 0) {
|
|
159
|
+
this->write_register_(REG_PAYLOAD_LENGTH_LSB, this->payload_length_);
|
|
160
|
+
this->write_register_(REG_PACKET_CONFIG_1, crc_mode | FIXED_LENGTH);
|
|
161
|
+
} else {
|
|
162
|
+
this->write_register_(REG_PAYLOAD_LENGTH_LSB, this->get_max_packet_size() - 1);
|
|
163
|
+
this->write_register_(REG_PACKET_CONFIG_1, crc_mode | VARIABLE_LENGTH);
|
|
164
|
+
}
|
|
165
|
+
this->write_register_(REG_PACKET_CONFIG_2, PACKET_MODE);
|
|
166
|
+
} else {
|
|
167
|
+
this->write_register_(REG_PACKET_CONFIG_2, CONTINUOUS_MODE);
|
|
168
|
+
}
|
|
169
|
+
this->write_register_(REG_DIO_MAPPING1, DIO0_MAPPING_00);
|
|
170
|
+
|
|
171
|
+
// config bit synchronizer
|
|
172
|
+
uint8_t polarity = (this->preamble_polarity_ == 0xAA) ? PREAMBLE_AA : PREAMBLE_55;
|
|
173
|
+
if (!this->sync_value_.empty()) {
|
|
174
|
+
uint8_t size = this->sync_value_.size() - 1;
|
|
175
|
+
this->write_register_(REG_SYNC_CONFIG, AUTO_RESTART_PLL_LOCK | polarity | SYNC_ON | size);
|
|
176
|
+
for (uint32_t i = 0; i < this->sync_value_.size(); i++) {
|
|
177
|
+
this->write_register_(REG_SYNC_VALUE1 + i, this->sync_value_[i]);
|
|
178
|
+
}
|
|
179
|
+
} else {
|
|
180
|
+
this->write_register_(REG_SYNC_CONFIG, AUTO_RESTART_PLL_LOCK | polarity);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
// config preamble detector
|
|
184
|
+
if (this->preamble_detect_ > 0) {
|
|
185
|
+
uint8_t size = (this->preamble_detect_ - 1) << PREAMBLE_DETECTOR_SIZE_SHIFT;
|
|
186
|
+
uint8_t tol = this->preamble_errors_ << PREAMBLE_DETECTOR_TOL_SHIFT;
|
|
187
|
+
this->write_register_(REG_PREAMBLE_DETECT, PREAMBLE_DETECTOR_ON | size | tol);
|
|
188
|
+
} else {
|
|
189
|
+
this->write_register_(REG_PREAMBLE_DETECT, PREAMBLE_DETECTOR_OFF);
|
|
190
|
+
}
|
|
191
|
+
this->write_register_(REG_PREAMBLE_SIZE_MSB, this->preamble_size_ >> 16);
|
|
192
|
+
this->write_register_(REG_PREAMBLE_SIZE_LSB, this->preamble_size_ & 0xFF);
|
|
193
|
+
|
|
194
|
+
// config sync generation and setup ook threshold
|
|
195
|
+
uint8_t bitsync = this->bitsync_ ? BIT_SYNC_ON : BIT_SYNC_OFF;
|
|
196
|
+
this->write_register_(REG_OOK_PEAK, bitsync | OOK_THRESH_STEP_0_5 | OOK_THRESH_PEAK);
|
|
197
|
+
this->write_register_(REG_OOK_AVG, OOK_AVG_RESERVED | OOK_THRESH_DEC_1_8);
|
|
198
|
+
|
|
199
|
+
// set rx floor
|
|
200
|
+
this->write_register_(REG_OOK_FIX, 256 + int(this->rx_floor_ * 2.0));
|
|
201
|
+
this->write_register_(REG_RSSI_THRESH, std::abs(int(this->rx_floor_ * 2.0)));
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
void SX127x::configure_lora_() {
|
|
205
|
+
// config modem
|
|
206
|
+
uint8_t header_mode = this->payload_length_ > 0 ? IMPLICIT_HEADER : EXPLICIT_HEADER;
|
|
207
|
+
uint8_t crc_mode = (this->crc_enable_) ? RX_PAYLOAD_CRC_ON : RX_PAYLOAD_CRC_OFF;
|
|
208
|
+
uint8_t spreading_factor = this->spreading_factor_ << SPREADING_FACTOR_SHIFT;
|
|
209
|
+
this->write_register_(REG_MODEM_CONFIG1, BW_LORA[this->bandwidth_] | this->coding_rate_ | header_mode);
|
|
210
|
+
this->write_register_(REG_MODEM_CONFIG2, spreading_factor | crc_mode);
|
|
211
|
+
|
|
212
|
+
// config fifo and payload length
|
|
213
|
+
this->write_register_(REG_FIFO_TX_BASE_ADDR, 0x00);
|
|
214
|
+
this->write_register_(REG_FIFO_RX_BASE_ADDR, 0x00);
|
|
215
|
+
this->write_register_(REG_PAYLOAD_LENGTH, std::max(this->payload_length_, (uint32_t) 1));
|
|
216
|
+
|
|
217
|
+
// config preamble
|
|
218
|
+
if (this->preamble_size_ >= 6) {
|
|
219
|
+
this->write_register_(REG_PREAMBLE_LEN_MSB, this->preamble_size_ >> 16);
|
|
220
|
+
this->write_register_(REG_PREAMBLE_LEN_LSB, this->preamble_size_ & 0xFF);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// optimize detection
|
|
224
|
+
float duration = 1000.0f * std::pow(2, this->spreading_factor_) / BW_HZ[this->bandwidth_];
|
|
225
|
+
if (duration > 16) {
|
|
226
|
+
this->write_register_(REG_MODEM_CONFIG3, MODEM_AGC_AUTO_ON | LOW_DATA_RATE_OPTIMIZE_ON);
|
|
227
|
+
} else {
|
|
228
|
+
this->write_register_(REG_MODEM_CONFIG3, MODEM_AGC_AUTO_ON);
|
|
229
|
+
}
|
|
230
|
+
if (this->spreading_factor_ == 6) {
|
|
231
|
+
this->write_register_(REG_DETECT_OPTIMIZE, 0xC5);
|
|
232
|
+
this->write_register_(REG_DETECT_THRESHOLD, 0x0C);
|
|
233
|
+
} else {
|
|
234
|
+
this->write_register_(REG_DETECT_OPTIMIZE, 0xC3);
|
|
235
|
+
this->write_register_(REG_DETECT_THRESHOLD, 0x0A);
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
// config sync word
|
|
239
|
+
if (!this->sync_value_.empty()) {
|
|
240
|
+
this->write_register_(REG_SYNC_WORD, this->sync_value_[0]);
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
size_t SX127x::get_max_packet_size() {
|
|
245
|
+
if (this->payload_length_ > 0) {
|
|
246
|
+
return this->payload_length_;
|
|
247
|
+
}
|
|
248
|
+
if (this->modulation_ == MOD_LORA) {
|
|
249
|
+
return 256;
|
|
250
|
+
} else {
|
|
251
|
+
return 64;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
SX127xError SX127x::transmit_packet(const std::vector<uint8_t> &packet) {
|
|
256
|
+
if (this->payload_length_ > 0 && this->payload_length_ != packet.size()) {
|
|
257
|
+
ESP_LOGE(TAG, "Packet size does not match config");
|
|
258
|
+
return SX127xError::INVALID_PARAMS;
|
|
259
|
+
}
|
|
260
|
+
if (packet.empty() || packet.size() > this->get_max_packet_size()) {
|
|
261
|
+
ESP_LOGE(TAG, "Packet size out of range");
|
|
262
|
+
return SX127xError::INVALID_PARAMS;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
SX127xError ret = SX127xError::NONE;
|
|
266
|
+
if (this->modulation_ == MOD_LORA) {
|
|
267
|
+
this->set_mode_standby();
|
|
268
|
+
if (this->payload_length_ == 0) {
|
|
269
|
+
this->write_register_(REG_PAYLOAD_LENGTH, packet.size());
|
|
270
|
+
}
|
|
271
|
+
this->write_register_(REG_IRQ_FLAGS, 0xFF);
|
|
272
|
+
this->write_register_(REG_FIFO_ADDR_PTR, 0);
|
|
273
|
+
this->write_fifo_(packet);
|
|
274
|
+
this->set_mode_tx();
|
|
275
|
+
} else {
|
|
276
|
+
this->set_mode_standby();
|
|
277
|
+
if (this->payload_length_ == 0) {
|
|
278
|
+
this->write_register_(REG_FIFO, packet.size());
|
|
279
|
+
}
|
|
280
|
+
this->write_fifo_(packet);
|
|
281
|
+
this->set_mode_tx();
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
// wait until transmit completes, typically the delay will be less than 100 ms
|
|
285
|
+
uint32_t start = millis();
|
|
286
|
+
while (!this->dio0_pin_->digital_read()) {
|
|
287
|
+
if (millis() - start > 4000) {
|
|
288
|
+
ESP_LOGE(TAG, "Transmit packet failure");
|
|
289
|
+
ret = SX127xError::TIMEOUT;
|
|
290
|
+
break;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
if (this->rx_start_) {
|
|
294
|
+
this->set_mode_rx();
|
|
295
|
+
} else {
|
|
296
|
+
this->set_mode_sleep();
|
|
297
|
+
}
|
|
298
|
+
return ret;
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
void SX127x::call_listeners_(const std::vector<uint8_t> &packet, float rssi, float snr) {
|
|
302
|
+
for (auto &listener : this->listeners_) {
|
|
303
|
+
listener->on_packet(packet, rssi, snr);
|
|
304
|
+
}
|
|
305
|
+
this->packet_trigger_->trigger(packet, rssi, snr);
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
void SX127x::loop() {
|
|
309
|
+
if (this->dio0_pin_ == nullptr || !this->dio0_pin_->digital_read()) {
|
|
310
|
+
return;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
if (this->modulation_ == MOD_LORA) {
|
|
314
|
+
uint8_t status = this->read_register_(REG_IRQ_FLAGS);
|
|
315
|
+
this->write_register_(REG_IRQ_FLAGS, 0xFF);
|
|
316
|
+
if ((status & PAYLOAD_CRC_ERROR) == 0) {
|
|
317
|
+
uint8_t bytes = this->read_register_(REG_NB_RX_BYTES);
|
|
318
|
+
uint8_t addr = this->read_register_(REG_FIFO_RX_CURR_ADDR);
|
|
319
|
+
uint8_t rssi = this->read_register_(REG_PKT_RSSI_VALUE);
|
|
320
|
+
int8_t snr = (int8_t) this->read_register_(REG_PKT_SNR_VALUE);
|
|
321
|
+
this->packet_.resize(bytes);
|
|
322
|
+
this->write_register_(REG_FIFO_ADDR_PTR, addr);
|
|
323
|
+
this->read_fifo_(this->packet_);
|
|
324
|
+
if (this->frequency_ > 700000000) {
|
|
325
|
+
this->call_listeners_(this->packet_, (float) rssi - RSSI_OFFSET_HF, (float) snr / 4);
|
|
326
|
+
} else {
|
|
327
|
+
this->call_listeners_(this->packet_, (float) rssi - RSSI_OFFSET_LF, (float) snr / 4);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
} else if (this->packet_mode_) {
|
|
331
|
+
uint8_t payload_length = this->payload_length_;
|
|
332
|
+
if (payload_length == 0) {
|
|
333
|
+
payload_length = this->read_register_(REG_FIFO);
|
|
334
|
+
}
|
|
335
|
+
this->packet_.resize(payload_length);
|
|
336
|
+
this->read_fifo_(this->packet_);
|
|
337
|
+
this->call_listeners_(this->packet_, 0.0f, 0.0f);
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
void SX127x::run_image_cal() {
|
|
342
|
+
if (this->modulation_ == MOD_LORA) {
|
|
343
|
+
this->set_mode_(MOD_FSK, MODE_SLEEP);
|
|
344
|
+
this->set_mode_(MOD_FSK, MODE_STDBY);
|
|
345
|
+
}
|
|
346
|
+
if (this->auto_cal_) {
|
|
347
|
+
this->write_register_(REG_IMAGE_CAL, IMAGE_CAL_START | AUTO_IMAGE_CAL_ON | TEMP_THRESHOLD_10C);
|
|
348
|
+
} else {
|
|
349
|
+
this->write_register_(REG_IMAGE_CAL, IMAGE_CAL_START);
|
|
350
|
+
}
|
|
351
|
+
uint32_t start = millis();
|
|
352
|
+
while (this->read_register_(REG_IMAGE_CAL) & IMAGE_CAL_RUNNING) {
|
|
353
|
+
if (millis() - start > 20) {
|
|
354
|
+
ESP_LOGE(TAG, "Image cal failure");
|
|
355
|
+
this->mark_failed();
|
|
356
|
+
break;
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
if (this->modulation_ == MOD_LORA) {
|
|
360
|
+
this->set_mode_(this->modulation_, MODE_SLEEP);
|
|
361
|
+
this->set_mode_(this->modulation_, MODE_STDBY);
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
void SX127x::set_mode_(uint8_t modulation, uint8_t mode) {
|
|
366
|
+
uint32_t start = millis();
|
|
367
|
+
this->write_register_(REG_OP_MODE, modulation | mode);
|
|
368
|
+
while (true) {
|
|
369
|
+
uint8_t curr = this->read_register_(REG_OP_MODE) & MODE_MASK;
|
|
370
|
+
if ((curr == mode) || (mode == MODE_RX && curr == MODE_RX_FS)) {
|
|
371
|
+
if (mode == MODE_SLEEP) {
|
|
372
|
+
this->write_register_(REG_OP_MODE, modulation | mode);
|
|
373
|
+
}
|
|
374
|
+
break;
|
|
375
|
+
}
|
|
376
|
+
if (millis() - start > 20) {
|
|
377
|
+
ESP_LOGE(TAG, "Set mode failure");
|
|
378
|
+
this->mark_failed();
|
|
379
|
+
break;
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
void SX127x::set_mode_rx() {
|
|
385
|
+
this->set_mode_(this->modulation_, MODE_RX);
|
|
386
|
+
if (this->modulation_ == MOD_LORA) {
|
|
387
|
+
this->write_register_(REG_IRQ_FLAGS_MASK, 0x00);
|
|
388
|
+
this->write_register_(REG_DIO_MAPPING1, DIO0_MAPPING_00);
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
void SX127x::set_mode_tx() {
|
|
393
|
+
this->set_mode_(this->modulation_, MODE_TX);
|
|
394
|
+
if (this->modulation_ == MOD_LORA) {
|
|
395
|
+
this->write_register_(REG_IRQ_FLAGS_MASK, 0x00);
|
|
396
|
+
this->write_register_(REG_DIO_MAPPING1, DIO0_MAPPING_01);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
void SX127x::set_mode_standby() { this->set_mode_(this->modulation_, MODE_STDBY); }
|
|
401
|
+
|
|
402
|
+
void SX127x::set_mode_sleep() { this->set_mode_(this->modulation_, MODE_SLEEP); }
|
|
403
|
+
|
|
404
|
+
void SX127x::dump_config() {
|
|
405
|
+
ESP_LOGCONFIG(TAG, "SX127x:");
|
|
406
|
+
LOG_PIN(" CS Pin: ", this->cs_);
|
|
407
|
+
LOG_PIN(" RST Pin: ", this->rst_pin_);
|
|
408
|
+
LOG_PIN(" DIO0 Pin: ", this->dio0_pin_);
|
|
409
|
+
const char *pa_pin = "RFO";
|
|
410
|
+
if (this->pa_pin_ == PA_PIN_BOOST) {
|
|
411
|
+
pa_pin = "BOOST";
|
|
412
|
+
}
|
|
413
|
+
ESP_LOGCONFIG(TAG,
|
|
414
|
+
" Auto Cal: %s\n"
|
|
415
|
+
" Frequency: %" PRIu32 " Hz\n"
|
|
416
|
+
" Bandwidth: %" PRIu32 " Hz\n"
|
|
417
|
+
" PA Pin: %s\n"
|
|
418
|
+
" PA Power: %" PRIu8 " dBm\n"
|
|
419
|
+
" PA Ramp: %" PRIu16 " us",
|
|
420
|
+
TRUEFALSE(this->auto_cal_), this->frequency_, BW_HZ[this->bandwidth_], pa_pin, this->pa_power_,
|
|
421
|
+
RAMP[this->pa_ramp_]);
|
|
422
|
+
if (this->modulation_ == MOD_FSK) {
|
|
423
|
+
ESP_LOGCONFIG(TAG, " Deviation: %" PRIu32 " Hz", this->deviation_);
|
|
424
|
+
}
|
|
425
|
+
if (this->modulation_ == MOD_LORA) {
|
|
426
|
+
const char *cr = "4/8";
|
|
427
|
+
if (this->coding_rate_ == CODING_RATE_4_5) {
|
|
428
|
+
cr = "4/5";
|
|
429
|
+
} else if (this->coding_rate_ == CODING_RATE_4_6) {
|
|
430
|
+
cr = "4/6";
|
|
431
|
+
} else if (this->coding_rate_ == CODING_RATE_4_7) {
|
|
432
|
+
cr = "4/7";
|
|
433
|
+
}
|
|
434
|
+
ESP_LOGCONFIG(TAG,
|
|
435
|
+
" Modulation: LORA\n"
|
|
436
|
+
" Preamble Size: %" PRIu16 "\n"
|
|
437
|
+
" Spreading Factor: %" PRIu8 "\n"
|
|
438
|
+
" Coding Rate: %s\n"
|
|
439
|
+
" CRC Enable: %s",
|
|
440
|
+
this->preamble_size_, this->spreading_factor_, cr, TRUEFALSE(this->crc_enable_));
|
|
441
|
+
if (this->payload_length_ > 0) {
|
|
442
|
+
ESP_LOGCONFIG(TAG, " Payload Length: %" PRIu32, this->payload_length_);
|
|
443
|
+
}
|
|
444
|
+
if (!this->sync_value_.empty()) {
|
|
445
|
+
ESP_LOGCONFIG(TAG, " Sync Value: 0x%02x", this->sync_value_[0]);
|
|
446
|
+
}
|
|
447
|
+
} else {
|
|
448
|
+
const char *shaping = "NONE";
|
|
449
|
+
if (this->modulation_ == MOD_FSK) {
|
|
450
|
+
if (this->shaping_ == GAUSSIAN_BT_0_3) {
|
|
451
|
+
shaping = "GAUSSIAN_BT_0_3";
|
|
452
|
+
} else if (this->shaping_ == GAUSSIAN_BT_0_5) {
|
|
453
|
+
shaping = "GAUSSIAN_BT_0_5";
|
|
454
|
+
} else if (this->shaping_ == GAUSSIAN_BT_1_0) {
|
|
455
|
+
shaping = "GAUSSIAN_BT_1_0";
|
|
456
|
+
}
|
|
457
|
+
} else {
|
|
458
|
+
if (this->shaping_ == CUTOFF_BR_X_2) {
|
|
459
|
+
shaping = "CUTOFF_BR_X_2";
|
|
460
|
+
} else if (this->shaping_ == CUTOFF_BR_X_1) {
|
|
461
|
+
shaping = "CUTOFF_BR_X_1";
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
ESP_LOGCONFIG(TAG,
|
|
465
|
+
" Shaping: %s\n"
|
|
466
|
+
" Modulation: %s\n"
|
|
467
|
+
" Bitrate: %" PRIu32 "b/s\n"
|
|
468
|
+
" Bitsync: %s\n"
|
|
469
|
+
" Rx Start: %s\n"
|
|
470
|
+
" Rx Floor: %.1f dBm\n"
|
|
471
|
+
" Packet Mode: %s",
|
|
472
|
+
shaping, this->modulation_ == MOD_FSK ? "FSK" : "OOK", this->bitrate_, TRUEFALSE(this->bitsync_),
|
|
473
|
+
TRUEFALSE(this->rx_start_), this->rx_floor_, TRUEFALSE(this->packet_mode_));
|
|
474
|
+
if (this->packet_mode_) {
|
|
475
|
+
ESP_LOGCONFIG(TAG, " CRC Enable: %s", TRUEFALSE(this->crc_enable_));
|
|
476
|
+
}
|
|
477
|
+
if (this->payload_length_ > 0) {
|
|
478
|
+
ESP_LOGCONFIG(TAG, " Payload Length: %" PRIu32, this->payload_length_);
|
|
479
|
+
}
|
|
480
|
+
if (!this->sync_value_.empty()) {
|
|
481
|
+
ESP_LOGCONFIG(TAG, " Sync Value: 0x%s", format_hex(this->sync_value_).c_str());
|
|
482
|
+
}
|
|
483
|
+
if (this->preamble_size_ > 0 || this->preamble_detect_ > 0) {
|
|
484
|
+
ESP_LOGCONFIG(TAG,
|
|
485
|
+
" Preamble Polarity: 0x%X\n"
|
|
486
|
+
" Preamble Size: %" PRIu16 "\n"
|
|
487
|
+
" Preamble Detect: %" PRIu8 "\n"
|
|
488
|
+
" Preamble Errors: %" PRIu8,
|
|
489
|
+
this->preamble_polarity_, this->preamble_size_, this->preamble_detect_, this->preamble_errors_);
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
if (this->is_failed()) {
|
|
493
|
+
ESP_LOGE(TAG, "Configuring SX127x failed");
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
|
|
497
|
+
} // namespace sx127x
|
|
498
|
+
} // namespace esphome
|