Compare commits
7 Commits
api_reboot
...
p4_remote_
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
123d4c3e0d | ||
|
|
4f1953c581 | ||
|
|
5bdf5c1bf3 | ||
|
|
fa27c0b8f1 | ||
|
|
69fec85cc1 | ||
|
|
aa26e2bffd | ||
|
|
af1a4d8a0a |
@@ -146,6 +146,7 @@ esphome/components/esp32_ble_client/* @jesserockz
|
|||||||
esphome/components/esp32_ble_server/* @Rapsssito @clydebarrow @jesserockz
|
esphome/components/esp32_ble_server/* @Rapsssito @clydebarrow @jesserockz
|
||||||
esphome/components/esp32_camera_web_server/* @ayufan
|
esphome/components/esp32_camera_web_server/* @ayufan
|
||||||
esphome/components/esp32_can/* @Sympatron
|
esphome/components/esp32_can/* @Sympatron
|
||||||
|
esphome/components/esp32_hosted/* @swoboda1337
|
||||||
esphome/components/esp32_improv/* @jesserockz
|
esphome/components/esp32_improv/* @jesserockz
|
||||||
esphome/components/esp32_rmt/* @jesserockz
|
esphome/components/esp32_rmt/* @jesserockz
|
||||||
esphome/components/esp32_rmt_led_strip/* @jesserockz
|
esphome/components/esp32_rmt_led_strip/* @jesserockz
|
||||||
|
|||||||
125
esphome/components/esp32_hosted/__init__.py
Normal file
125
esphome/components/esp32_hosted/__init__.py
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
import os
|
||||||
|
|
||||||
|
from esphome import pins
|
||||||
|
import esphome.codegen as cg
|
||||||
|
from esphome.components import esp32
|
||||||
|
import esphome.config_validation as cv
|
||||||
|
from esphome.const import (
|
||||||
|
CONF_CLK_PIN,
|
||||||
|
CONF_ID,
|
||||||
|
CONF_RESET_PIN,
|
||||||
|
CONF_VARIANT,
|
||||||
|
KEY_CORE,
|
||||||
|
KEY_FRAMEWORK_VERSION,
|
||||||
|
)
|
||||||
|
from esphome.core import CORE
|
||||||
|
|
||||||
|
CODEOWNERS = ["@swoboda1337"]
|
||||||
|
AUTO_LOAD = ["esp32"]
|
||||||
|
|
||||||
|
esp32_hosted_ns = cg.esphome_ns.namespace("esp32_hosted")
|
||||||
|
ESP32Hosted = esp32_hosted_ns.class_("ESP32Hosted", cg.Component)
|
||||||
|
|
||||||
|
CONF_ACTIVE_HIGH = "active_high"
|
||||||
|
CONF_CMD_PIN = "cmd_pin"
|
||||||
|
CONF_D0_PIN = "d0_pin"
|
||||||
|
CONF_D1_PIN = "d1_pin"
|
||||||
|
CONF_D2_PIN = "d2_pin"
|
||||||
|
CONF_D3_PIN = "d3_pin"
|
||||||
|
CONF_SLOT = "slot"
|
||||||
|
|
||||||
|
VARIANTS_WITHOUT_WIFI = {
|
||||||
|
esp32.VARIANT_ESP32H2,
|
||||||
|
esp32.VARIANT_ESP32P4,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
CONFIG_SCHEMA = cv.All(
|
||||||
|
cv.Schema(
|
||||||
|
{
|
||||||
|
cv.GenerateID(): cv.declare_id(ESP32Hosted),
|
||||||
|
cv.Required(CONF_VARIANT): cv.one_of(*esp32.VARIANTS, upper=True),
|
||||||
|
cv.Optional(CONF_ACTIVE_HIGH, default=True): cv.boolean,
|
||||||
|
cv.Required(CONF_CLK_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_CMD_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_D0_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_D1_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_D2_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_D3_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Required(CONF_RESET_PIN): pins.internal_gpio_output_pin_number,
|
||||||
|
cv.Optional(CONF_SLOT, default=1): cv.int_range(min=0, max=1),
|
||||||
|
}
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
async def to_code(config):
|
||||||
|
var = cg.new_Pvariable(config[CONF_ID])
|
||||||
|
await cg.register_component(var, config)
|
||||||
|
|
||||||
|
framework_ver: cv.Version = CORE.data[KEY_CORE][KEY_FRAMEWORK_VERSION]
|
||||||
|
|
||||||
|
if config[CONF_ACTIVE_HIGH]:
|
||||||
|
esp32.add_idf_sdkconfig_option("CONFIG_ESP_HOSTED_SDIO_RESET_ACTIVE_HIGH", True)
|
||||||
|
else:
|
||||||
|
esp32.add_idf_sdkconfig_option("CONFIG_ESP_HOSTED_SDIO_RESET_ACTIVE_LOW", True)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_SLAVE_IDF_TARGET_{config[CONF_VARIANT]}", # NOLINT
|
||||||
|
True,
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_SDIO_SLOT_{config[CONF_SLOT]}", True
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_CLK_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_CLK_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_CMD_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_CMD_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_D0_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_D0_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_D1_4BIT_BUS_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_D1_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_D2_4BIT_BUS_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_D2_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
f"CONFIG_ESP_HOSTED_PRIV_SDIO_PIN_D3_4BIT_BUS_SLOT_{config[CONF_SLOT]}",
|
||||||
|
config[CONF_D3_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_idf_sdkconfig_option(
|
||||||
|
"CONFIG_ESP_HOSTED_SDIO_GPIO_RESET_SLAVE", # NOLINT
|
||||||
|
config[CONF_RESET_PIN],
|
||||||
|
)
|
||||||
|
|
||||||
|
os.environ["ESP_IDF_VERSION"] = f"{framework_ver.major}.{framework_ver.minor}"
|
||||||
|
|
||||||
|
if config[CONF_VARIANT] not in VARIANTS_WITHOUT_WIFI:
|
||||||
|
esp32.add_idf_component(
|
||||||
|
name="esp_wifi_remote",
|
||||||
|
repo="https://github.com/espressif/esp-wifi-remote.git",
|
||||||
|
path="components/esp_wifi_remote",
|
||||||
|
ref="wifi_remote-v0.10.2",
|
||||||
|
)
|
||||||
|
|
||||||
|
esp32.add_extra_script(
|
||||||
|
"post",
|
||||||
|
"esp32_hosted.py",
|
||||||
|
os.path.join(os.path.dirname(__file__), "esp32_hosted.py.script"),
|
||||||
|
)
|
||||||
53
esphome/components/esp32_hosted/esp32_hosted.cpp
Normal file
53
esphome/components/esp32_hosted/esp32_hosted.cpp
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
#include "esp32_hosted.h"
|
||||||
|
#include "esphome/core/log.h"
|
||||||
|
|
||||||
|
#ifdef USE_ESP32
|
||||||
|
|
||||||
|
#ifdef USE_ESP32_BLE
|
||||||
|
#include <esp_bluedroid_hci.h>
|
||||||
|
#include <hosted_hci_bluedroid.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace esp32_hosted {
|
||||||
|
|
||||||
|
static const char *const TAG = "esp32_hosted";
|
||||||
|
|
||||||
|
void ESP32Hosted::setup() {
|
||||||
|
ESP_LOGCONFIG(TAG, "Setting up ESP32 Hosted...");
|
||||||
|
|
||||||
|
#ifdef USE_ESP32_BLE
|
||||||
|
// Initialize Bluetooth if esp32_ble component is enabled
|
||||||
|
this->init_bluetooth_();
|
||||||
|
#else
|
||||||
|
ESP_LOGD(TAG, "Bluetooth support disabled (esp32_ble not included)");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void ESP32Hosted::dump_config() { ESP_LOGCONFIG(TAG, "ESP32 Hosted:"); }
|
||||||
|
|
||||||
|
#ifdef USE_ESP32_BLE
|
||||||
|
void ESP32Hosted::init_bluetooth_() {
|
||||||
|
ESP_LOGD(TAG, "Initializing Bluetooth...");
|
||||||
|
|
||||||
|
// Initialize TRANSPORT first
|
||||||
|
hosted_hci_bluedroid_open();
|
||||||
|
|
||||||
|
// Get HCI driver operations
|
||||||
|
esp_bluedroid_hci_driver_operations_t operations = {
|
||||||
|
.send = hosted_hci_bluedroid_send,
|
||||||
|
.check_send_available = hosted_hci_bluedroid_check_send_available,
|
||||||
|
.register_host_callback = hosted_hci_bluedroid_register_host_callback,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Attach HCI driver
|
||||||
|
esp_bluedroid_attach_hci_driver(&operations);
|
||||||
|
|
||||||
|
ESP_LOGD(TAG, "Bluetooth initialized successfully");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} // namespace esp32_hosted
|
||||||
|
} // namespace esphome
|
||||||
|
|
||||||
|
#endif // USE_ESP32
|
||||||
26
esphome/components/esp32_hosted/esp32_hosted.h
Normal file
26
esphome/components/esp32_hosted/esp32_hosted.h
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "esphome/core/component.h"
|
||||||
|
#include "esphome/core/helpers.h"
|
||||||
|
|
||||||
|
#ifdef USE_ESP32
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace esp32_hosted {
|
||||||
|
|
||||||
|
class ESP32Hosted : public Component {
|
||||||
|
public:
|
||||||
|
void setup() override;
|
||||||
|
void dump_config() override;
|
||||||
|
float get_setup_priority() const override { return setup_priority::HARDWARE; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
#ifdef USE_ESP32_BLE
|
||||||
|
void init_bluetooth_();
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace esp32_hosted
|
||||||
|
} // namespace esphome
|
||||||
|
|
||||||
|
#endif // USE_ESP32
|
||||||
12
esphome/components/esp32_hosted/esp32_hosted.py.script
Normal file
12
esphome/components/esp32_hosted/esp32_hosted.py.script
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
# pylint: disable=E0602
|
||||||
|
Import("env") # noqa
|
||||||
|
|
||||||
|
# Workaround whole archive issue
|
||||||
|
if "__LIB_DEPS" in env and "libespressif__esp_hosted.a" in env["__LIB_DEPS"]:
|
||||||
|
env.Append(
|
||||||
|
LINKFLAGS=[
|
||||||
|
"-Wl,--whole-archive",
|
||||||
|
env["BUILD_DIR"] + "/esp-idf/espressif__esp_hosted/libespressif__esp_hosted.a",
|
||||||
|
"-Wl,--no-whole-archive",
|
||||||
|
]
|
||||||
|
)
|
||||||
@@ -11,3 +11,10 @@ dependencies:
|
|||||||
path: components/mdns
|
path: components/mdns
|
||||||
rules:
|
rules:
|
||||||
- if: "idf_version >=5.0"
|
- if: "idf_version >=5.0"
|
||||||
|
esp_wifi_remote:
|
||||||
|
git: https://github.com/espressif/esp-wifi-remote.git
|
||||||
|
version: wifi_remote-v0.10.2
|
||||||
|
path: components/esp_wifi_remote
|
||||||
|
rules:
|
||||||
|
- if: "idf_version >=5.0"
|
||||||
|
- if: "target in [esp32h2, esp32p4]"
|
||||||
|
|||||||
15
tests/components/esp32_hosted/common.yaml
Normal file
15
tests/components/esp32_hosted/common.yaml
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
esp32_hosted:
|
||||||
|
variant: ESP32C6
|
||||||
|
slot: 1
|
||||||
|
active_high: true
|
||||||
|
reset_pin: GPIO15
|
||||||
|
cmd_pin: GPIO13
|
||||||
|
clk_pin: GPIO12
|
||||||
|
d0_pin: GPIO11
|
||||||
|
d1_pin: GPIO10
|
||||||
|
d2_pin: GPIO9
|
||||||
|
d3_pin: GPIO8
|
||||||
|
|
||||||
|
wifi:
|
||||||
|
ssid: MySSID
|
||||||
|
password: password1
|
||||||
1
tests/components/esp32_hosted/test.esp32-p4-idf.yaml
Normal file
1
tests/components/esp32_hosted/test.esp32-p4-idf.yaml
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<<: !include common.yaml
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
esphome:
|
||||||
|
name: componenttestesp32p4idf
|
||||||
|
friendly_name: $component_name
|
||||||
|
|
||||||
|
esp32:
|
||||||
|
board: esp32-p4-evboard
|
||||||
|
framework:
|
||||||
|
type: esp-idf
|
||||||
|
|
||||||
|
logger:
|
||||||
|
level: VERY_VERBOSE
|
||||||
|
|
||||||
|
packages:
|
||||||
|
component_under_test: !include
|
||||||
|
file: $component_test_file
|
||||||
|
vars:
|
||||||
|
component_test_file: $component_test_file
|
||||||
Reference in New Issue
Block a user