/* This example code is in the Public Domain (or CC0 licensed, at your option.) Unless required by applicable law or agreed to in writing, this software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */ #include #include #include #include #include #include #include #include static const char *TAG = "app_main"; int light_endpoint_id = 0; static void app_event_cb(const ChipDeviceEvent *event, intptr_t arg) { if (event->Type == chip::DeviceLayer::DeviceEventType::PublicEventTypes::kInterfaceIpAddressChanged) { #if !CHIP_DEVICE_CONFIG_ENABLE_THREAD chip::app::DnssdServer::Instance().StartServer(); esp_route_hook_init(esp_netif_get_handle_from_ifkey("WIFI_STA_DEF")); #endif } ESP_LOGI(TAG, "Current free heap: %zu", heap_caps_get_free_size(MALLOC_CAP_8BIT)); } static esp_err_t app_attribute_update_cb(esp_matter_callback_type_t type, int endpoint_id, int cluster_id, int attribute_id, esp_matter_attr_val_t val, void *priv_data) { esp_err_t err = ESP_OK; if (type == ESP_MATTER_CALLBACK_TYPE_PRE_ATTRIBUTE) { /* Driver update */ err = app_driver_attribute_update(endpoint_id, cluster_id, attribute_id, val); } else if (type == ESP_MATTER_CALLBACK_TYPE_POST_ATTRIBUTE) { /* Other ecosystems update */ } return err; } extern "C" void app_main() { esp_err_t err = ESP_OK; /* Initialize the ESP NVS layer */ nvs_flash_init(); /* Initialize matter callback */ esp_matter_attribute_callback_set(app_attribute_update_cb, NULL); light_endpoint_id = 1; /* This is from zap-generated/endpoint_config.h */ /* Initialize driver */ app_driver_init(); /* Matter start */ err = esp_matter_start(app_event_cb); if (err != ESP_OK) { ESP_LOGE(TAG, "Matter start failed: %d", err); } app_qrcode_print(); app_driver_attribute_set_defaults(); #if CONFIG_ENABLE_CHIP_SHELL esp_matter_console_diagnostics_register_commands(); esp_matter_console_init(); #endif }