Page 1 of 1

building failure

Posted: Fri Feb 28, 2025 10:35 am
by ravencarcass
Hello,
I've big problems with the light example. I would build the project but then did he gave me the following failure. I don't know what I'm doing wrong. I had this multiple times an it makes me angery that I don't know what is wrong.

Code: Select all

[1420/1429] Building CXX object esp-idf/m...CMakeFiles/__idf_main.dir/app_main.cpp.obj
FAILED: esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj 
/home/robbe/.espressif/tools/riscv32-esp-elf/esp-14.2.0_20241119/riscv32-esp-elf/bin/riscv32-esp-elf-g++ -DESP_PLATFORM -DIDF_VER=\"v5.4\" -DMBEDTLS_CONFIG_FILE=\"mbedtls/esp_config.h\" -DMD5_ENABLED=1 -DSERIAL_FLASHER_BOOT_HOLD_TIME_MS=50 -DSERIAL_FLASHER_RESET_HOLD_TIME_MS=100 -DSOC_MMU_PAGE_SIZE=CONFIG_MMU_PAGE_SIZE -DSOC_XTAL_FREQ_MHZ=CONFIG_XTAL_FREQ -DUNITY_INCLUDE_CONFIG_H -D_GLIBCXX_HAVE_POSIX_SEMAPHORE -D_GLIBCXX_USE_POSIX_SEMAPHORE -D_GNU_SOURCE -D_POSIX_READER_WRITER_LOCKS -I/home/robbe/esp/light/build/config -I/home/robbe/esp/light/main -I/home/robbe/esp/esp-matter/examples/common/utils -I/home/robbe/esp/esp-idf/components/newlib/platform_include -I/home/robbe/esp/esp-idf/components/freertos/config/include -I/home/robbe/esp/esp-idf/components/freertos/config/include/freertos -I/home/robbe/esp/esp-idf/components/freertos/config/riscv/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/portable/riscv/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/portable/riscv/include/freertos -I/home/robbe/esp/esp-idf/components/freertos/esp_additions/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/include/soc -I/home/robbe/esp/esp-idf/components/esp_hw_support/include/soc/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_hw_support/dma/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/ldo/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/debug_probe/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/. -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/private_include -I/home/robbe/esp/esp-idf/components/heap/include -I/home/robbe/esp/esp-idf/components/heap/tlsf -I/home/robbe/esp/esp-idf/components/log/include -I/home/robbe/esp/esp-idf/components/soc/include -I/home/robbe/esp/esp-idf/components/soc/esp32c6 -I/home/robbe/esp/esp-idf/components/soc/esp32c6/include -I/home/robbe/esp/esp-idf/components/soc/esp32c6/register -I/home/robbe/esp/esp-idf/components/hal/platform_port/include -I/home/robbe/esp/esp-idf/components/hal/esp32c6/include -I/home/robbe/esp/esp-idf/components/hal/include -I/home/robbe/esp/esp-idf/components/esp_rom/include -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6/include/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_common/include -I/home/robbe/esp/esp-idf/components/esp_system/include -I/home/robbe/esp/esp-idf/components/esp_system/port/soc -I/home/robbe/esp/esp-idf/components/esp_system/port/include/riscv -I/home/robbe/esp/esp-idf/components/esp_system/port/include/private -I/home/robbe/esp/esp-idf/components/riscv/include -I/home/robbe/esp/esp-idf/components/lwip/include -I/home/robbe/esp/esp-idf/components/lwip/include/apps -I/home/robbe/esp/esp-idf/components/lwip/include/apps/sntp -I/home/robbe/esp/esp-idf/components/lwip/lwip/src/include -I/home/robbe/esp/esp-idf/components/lwip/port/include -I/home/robbe/esp/esp-idf/components/lwip/port/freertos/include -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include/arch -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include/sys -I/home/robbe/esp/light/managed_components/espressif__esp_bsp_devkit/include -I/home/robbe/esp/esp-idf/components/driver/deprecated -I/home/robbe/esp/esp-idf/components/driver/i2c/include -I/home/robbe/esp/esp-idf/components/driver/touch_sensor/include -I/home/robbe/esp/esp-idf/components/driver/twai/include -I/home/robbe/esp/esp-idf/components/esp_pm/include -I/home/robbe/esp/esp-idf/components/esp_ringbuf/include -I/home/robbe/esp/esp-idf/components/esp_driver_gpio/include -I/home/robbe/esp/esp-idf/components/esp_driver_pcnt/include -I/home/robbe/esp/esp-idf/components/esp_driver_gptimer/include -I/home/robbe/esp/esp-idf/components/esp_driver_spi/include -I/home/robbe/esp/esp-idf/components/esp_driver_mcpwm/include -I/home/robbe/esp/esp-idf/components/esp_driver_ana_cmpr/include -I/home/robbe/esp/esp-idf/components/esp_driver_i2s/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdmmc/include -I/home/robbe/esp/esp-idf/components/sdmmc/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdspi/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdio/include -I/home/robbe/esp/esp-idf/components/esp_driver_dac/include -I/home/robbe/esp/esp-idf/components/esp_driver_rmt/include -I/home/robbe/esp/esp-idf/components/esp_driver_tsens/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdm/include -I/home/robbe/esp/esp-idf/components/esp_driver_i2c/include -I/home/robbe/esp/esp-idf/components/esp_driver_uart/include -I/home/robbe/esp/esp-idf/components/vfs/include -I/home/robbe/esp/esp-idf/components/esp_driver_ledc/include -I/home/robbe/esp/esp-idf/components/esp_driver_parlio/include -I/home/robbe/esp/esp-idf/components/esp_driver_usb_serial_jtag/include -I/home/robbe/esp/esp-idf/components/spiffs/include -I/home/robbe/esp/esp-idf/components/esp_partition/include -I/home/robbe/esp/esp-idf/components/fatfs/diskio -I/home/robbe/esp/esp-idf/components/fatfs/src -I/home/robbe/esp/esp-idf/components/fatfs/vfs -I/home/robbe/esp/esp-idf/components/wear_levelling/include -I/home/robbe/esp/light/managed_components/espressif__button/include -I/home/robbe/esp/esp-idf/components/esp_adc/include -I/home/robbe/esp/esp-idf/components/esp_adc/interface -I/home/robbe/esp/esp-idf/components/esp_adc/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_adc/deprecated/include -I/home/robbe/esp/light/managed_components/espressif__led_indicator/include -I/home/robbe/esp/light/managed_components/espressif__led_strip/include -I/home/robbe/esp/light/managed_components/espressif__led_strip/interface -I/home/robbe/esp/esp-idf/components/mbedtls/port/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/library -I/home/robbe/esp/esp-idf/components/mbedtls/esp_crt_bundle/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/everest/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/p256-m -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/p256-m/p256-m -I/home/robbe/esp/esp-idf/components/esp_app_format/include -I/home/robbe/esp/esp-idf/components/esp_bootloader_format/include -I/home/robbe/esp/esp-idf/components/app_update/include -I/home/robbe/esp/esp-idf/components/bootloader_support/include -I/home/robbe/esp/esp-idf/components/bootloader_support/bootloader_flash/include -I/home/robbe/esp/esp-idf/components/efuse/include -I/home/robbe/esp/esp-idf/components/efuse/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_mm/include -I/home/robbe/esp/esp-idf/components/spi_flash/include -I/home/robbe/esp/esp-idf/components/esp_security/include -I/home/robbe/esp/esp-idf/components/pthread/include -I/home/robbe/esp/esp-idf/components/esp_timer/include -I/home/robbe/esp/esp-idf/components/app_trace/include -I/home/robbe/esp/esp-idf/components/esp_event/include -I/home/robbe/esp/esp-idf/components/nvs_flash/include -I/home/robbe/esp/esp-idf/components/esp_phy/include -I/home/robbe/esp/esp-idf/components/esp_phy/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_vfs_console/include -I/home/robbe/esp/esp-idf/components/esp_netif/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/port/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/esp_supplicant/include -I/home/robbe/esp/esp-idf/components/esp_coex/include -I/home/robbe/esp/esp-idf/components/esp_wifi/include -I/home/robbe/esp/esp-idf/components/esp_wifi/include/local -I/home/robbe/esp/esp-idf/components/esp_wifi/wifi_apps/include -I/home/robbe/esp/esp-idf/components/esp_wifi/wifi_apps/nan_app/include -I/home/robbe/esp/esp-idf/components/bt/include/esp32c6/include -I/home/robbe/esp/esp-idf/components/bt/common/osi/include -I/home/robbe/esp/esp-idf/components/bt/common/api/include/api -I/home/robbe/esp/esp-idf/components/bt/common/btc/profile/esp/blufi/include -I/home/robbe/esp/esp-idf/components/bt/common/btc/profile/esp/include -I/home/robbe/esp/esp-idf/components/bt/common/hci_log/include -I/home/robbe/esp/esp-idf/components/bt/porting/include -I/home/robbe/esp/esp-idf/components/bt/porting/npl/freertos/include -I/home/robbe/esp/esp-idf/components/bt/porting/transport/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/ans/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/bas/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/dis/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/gap/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/gatt/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/hr/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/htp/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/ias/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/ipss/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/lls/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/prox/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/cts/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/tps/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/hid/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/sps/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/services/cte/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/util/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/store/ram/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/host/store/config/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/porting/nimble/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/port/include -I/home/robbe/esp/esp-idf/components/bt/host/nimble/nimble/nimble/transport/include -I/home/robbe/esp/esp-idf/components/unity/include -I/home/robbe/esp/esp-idf/components/unity/unity/src -I/home/robbe/esp/esp-idf/components/cmock/CMock/src -I/home/robbe/esp/esp-idf/components/console -I/home/robbe/esp/esp-idf/components/http_parser -I/home/robbe/esp/esp-idf/components/esp-tls -I/home/robbe/esp/esp-idf/components/esp-tls/esp-tls-crypto -I/home/robbe/esp/esp-idf/components/esp_driver_isp/include -I/home/robbe/esp/esp-idf/components/esp_driver_cam/include -I/home/robbe/esp/esp-idf/components/esp_driver_cam/interface -I/home/robbe/esp/esp-idf/components/esp_driver_jpeg/include -I/home/robbe/esp/esp-idf/components/esp_driver_ppa/include -I/home/robbe/esp/esp-idf/components/esp_eth/include -I/home/robbe/esp/esp-idf/components/esp_gdbstub/include -I/home/robbe/esp/esp-idf/components/esp_hid/include -I/home/robbe/esp/esp-idf/components/tcp_transport/include -I/home/robbe/esp/esp-idf/components/esp_http_client/include -I/home/robbe/esp/esp-idf/components/esp_http_server/include -I/home/robbe/esp/esp-idf/components/esp_https_ota/include -I/home/robbe/esp/esp-idf/components/esp_https_server/include -I/home/robbe/esp/esp-idf/components/esp_psram/include -I/home/robbe/esp/esp-idf/components/esp_lcd/include -I/home/robbe/esp/esp-idf/components/esp_lcd/interface -I/home/robbe/esp/esp-idf/components/protobuf-c/protobuf-c -I/home/robbe/esp/esp-idf/components/protocomm/include/common -I/home/robbe/esp/esp-idf/components/protocomm/include/security -I/home/robbe/esp/esp-idf/components/protocomm/include/transports -I/home/robbe/esp/esp-idf/components/protocomm/include/crypto/srp6a -I/home/robbe/esp/esp-idf/components/protocomm/proto-c -I/home/robbe/esp/esp-idf/components/esp_local_ctrl/include -I/home/robbe/esp/esp-idf/components/espcoredump/include -I/home/robbe/esp/esp-idf/components/espcoredump/include/port/riscv -I/home/robbe/esp/esp-idf/components/idf_test/include -I/home/robbe/esp/esp-idf/components/idf_test/include/esp32c6 -I/home/robbe/esp/esp-idf/components/ieee802154/include -I/home/robbe/esp/esp-idf/components/json/cJSON -I/home/robbe/esp/esp-idf/components/mqtt/esp-mqtt/include -I/home/robbe/esp/esp-idf/components/nvs_sec_provider/include -I/home/robbe/esp/esp-idf/components/rt/include -I/home/robbe/esp/esp-idf/components/wifi_provisioning/include -I/home/robbe/esp/light/managed_components/espressif__esp_delta_ota/include -I/home/robbe/esp/light/managed_components/espressif__esp_encrypted_img/include -I/home/robbe/esp/light/managed_components/espressif__rmaker_common/include -I/home/robbe/esp/light/managed_components/espressif__esp_diagnostics/include -I/home/robbe/esp/light/managed_components/espressif__cbor/port/include -I/home/robbe/esp/light/managed_components/espressif__esp_diag_data_store/src/rtc_store -I/home/robbe/esp/light/managed_components/espressif__esp_diag_data_store/include -I/home/robbe/esp/light/managed_components/espressif__esp_insights/include -I/home/robbe/esp/light/managed_components/espressif__mdns/include -I/home/robbe/esp/light/managed_components/espressif__esp-serial-flasher/include -I/home/robbe/esp/light/managed_components/espressif__esp-serial-flasher/port -I/home/robbe/esp/light/managed_components/espressif__esp_rcp_update/include -I/home/robbe/esp/light/managed_components/espressif__esp_secure_cert_mgr/include -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/src/platform/ESP32 -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/src/platform/OpenThread -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/src/include -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/src/lib -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/src -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/zzz_generated/app-common -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/examples/platform/esp32 -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/third_party/nlassert/repo/include -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/third_party/nlio/repo/include -I/home/robbe/esp/light/build/esp-idf/chip/src/include -I/home/robbe/esp/light/build/esp-idf/chip/include -I/home/robbe/esp/light/build/esp-idf/chip/gen/include -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/config/esp32 -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/config/esp32/../.. -I/home/robbe/esp/esp-matter/components/esp_matter_console -I/home/robbe/esp/esp-matter/components/esp_matter -I/home/robbe/esp/esp-matter/components/esp_matter/utils -I/home/robbe/esp/esp-matter/connectedhomeip/connectedhomeip/third_party/nlfaultinjection/include -I/home/robbe/esp/esp-matter/components/esp_matter/zap_common -I/home/robbe/esp/esp-matter/components/esp_matter_bridge -I/home/robbe/esp/esp-matter/examples/common/app_bridge -I/home/robbe/esp/esp-matter/examples/common/app_reset -I/home/robbe/esp/light/managed_components/espressif__json_generator/include -I/home/robbe/esp/light/managed_components/espressif__jsmn/include -I/home/robbe/esp/light/managed_components/espressif__json_parser/include -I/home/robbe/esp/esp-matter/components/esp_matter_rainmaker -march=rv32imac_zicsr_zifencei  -fdiagnostics-color=always -ffunction-sections -fdata-sections -Wall -Werror=all -Wno-error=unused-function -Wno-error=unused-variable -Wno-error=unused-but-set-variable -Wno-error=deprecated-declarations -Wextra -Wno-error=extra -Wno-unused-parameter -Wno-sign-compare -Wno-enum-conversion -gdwarf-4 -ggdb -nostartfiles -Og -fno-shrink-wrap -fmacro-prefix-map=/home/robbe/esp/light=. -fmacro-prefix-map=/home/robbe/esp/esp-idf=/IDF -fstrict-volatile-bitfields -fno-jump-tables -fno-tree-switch-conversion -Wno-error=uninitialized -Wno-error=maybe-uninitialized -Wno-missing-field-initializers -Wno-error=array-bounds -Wno-write-strings -Wno-format-nonliteral -Wno-format-security -std=gnu++2b -fno-exceptions -fno-rtti -fuse-cxa-atexit -std=gnu++17 -Os -DCHIP_HAVE_CONFIG_H -Wno-overloaded-virtual -DBUTTON_VER_MAJOR=3 -DBUTTON_VER_MINOR=5 -DBUTTON_VER_PATCH=0 -DLED_INDICATOR_VER_MAJOR=0 -DLED_INDICATOR_VER_MINOR=9 -DLED_INDICATOR_VER_PATCH=3 "-DCHIP_ADDRESS_RESOLVE_IMPL_INCLUDE_HEADER=<lib/address_resolve/AddressResolve_DefaultImpl.h>" -MD -MT esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj -MF esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj.d -o esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj -c /home/robbe/esp/light/main/app_main.cpp
/home/robbe/esp/light/main/app_main.cpp: In function 'void app_main()':
/home/robbe/esp/light/main/app_main.cpp:185:34: 
 *  The terminal process "ninja" terminated with exit code: 1. 

Re: building failure

Posted: Fri Feb 28, 2025 1:57 pm
by MicroController
There should be more compiler output telling you what the problem is somwhere below "/home/robbe/esp/light/main/app_main.cpp:185:34:"

Re: building failure

Posted: Sat Mar 01, 2025 4:20 pm
by ravencarcass
Hello, I've solved it on a way. I've only a new trouble.
After I could build it was I kind of curious with customize the existing code.
But their occured a fail like the one below, normally can I read multiple errors but this failure is somethings that I can't see where the fault is.
I don't know where I need to start:

The build terminal:

Code: Select all

*  Executing task: ninja  

[1/13] Performing build step for 'bootloader'
[1/1] cd /home/robbe/esp/light/build/bootloader/esp-idf/esptool_py && /home/robbe/.espressif/python_env/idf5.4_py3.10_env/bin/python /home/robbe/esp/esp-idf/components/partition_table/check_sizes.py --offset 0xc000 bootloader 0x0 /home/robbe/esp/light/build/bootloader/bootloader.bin
Bootloader binary size 0x55e0 bytes. 0x6a20 bytes (55%) free.
[2/11] Performing build step for 'chip_gn'
ninja: no work to do.
[3/9] Building CXX object esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj
FAILED: esp-idf/main/CMakeFiles/__idf_main.dir/app_main.cpp.obj 
ccache /home/robbe/.espressif/tools/riscv32-esp-elf/esp-14.2.0_20241119/riscv32-esp-elf/bin/riscv32-esp-elf-g++ -DESP_PLATFORM -DIDF_VER=\"v5.4\" -DMBEDTLS_CONFIG_FILE=\"mbedtls/esp_config.h\" -DMD5_ENABLED=1 -DSERIAL_FLASHER_BOOT_HOLD_TIME_MS=50 -DSERIAL_FLASHER_RESET_HOLD_TIME_MS=100 -DSOC_MMU_PAGE_SIZE=CONFIG_MMU_PAGE_SIZE -DSOC_XTAL_FREQ_MHZ=CONFIG_XTAL_FREQ -DUNITY_INCLUDE_CONFIG_H -D_GLIBCXX_HAVE_POSIX_SEMAPHORE -D_GLIBCXX_USE_POSIX_SEMAPHORE -D_GNU_SOURCE -D_POSIX_READER_WRITER_LOCKS -I/home/robbe/esp/light/build/config -I/home/robbe/esp/light/main -I/home/robbe/esp/esp-matter/examples/common/utils -I/home/robbe/esp/esp-idf/components/newlib/platform_include -I/home/robbe/esp/esp-idf/components/freertos/config/include -I/home/robbe/esp/esp-idf/components/freertos/config/include/freertos -I/home/robbe/esp/esp-idf/components/freertos/config/riscv/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/portable/riscv/include -I/home/robbe/esp/esp-idf/components/freertos/FreeRTOS-Kernel/portable/riscv/include/freertos -I/home/robbe/esp/esp-idf/components/freertos/esp_additions/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/include/soc -I/home/robbe/esp/esp-idf/components/esp_hw_support/include/soc/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_hw_support/dma/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/ldo/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/debug_probe/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/. -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_hw_support/port/esp32c6/private_include -I/home/robbe/esp/esp-idf/components/heap/include -I/home/robbe/esp/esp-idf/components/heap/tlsf -I/home/robbe/esp/esp-idf/components/log/include -I/home/robbe/esp/esp-idf/components/soc/include -I/home/robbe/esp/esp-idf/components/soc/esp32c6 -I/home/robbe/esp/esp-idf/components/soc/esp32c6/include -I/home/robbe/esp/esp-idf/components/soc/esp32c6/register -I/home/robbe/esp/esp-idf/components/hal/platform_port/include -I/home/robbe/esp/esp-idf/components/hal/esp32c6/include -I/home/robbe/esp/esp-idf/components/hal/include -I/home/robbe/esp/esp-idf/components/esp_rom/include -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6/include/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_rom/esp32c6 -I/home/robbe/esp/esp-idf/components/esp_common/include -I/home/robbe/esp/esp-idf/components/esp_system/include -I/home/robbe/esp/esp-idf/components/esp_system/port/soc -I/home/robbe/esp/esp-idf/components/esp_system/port/include/riscv -I/home/robbe/esp/esp-idf/components/esp_system/port/include/private -I/home/robbe/esp/esp-idf/components/riscv/include -I/home/robbe/esp/esp-idf/components/lwip/include -I/home/robbe/esp/esp-idf/components/lwip/include/apps -I/home/robbe/esp/esp-idf/components/lwip/include/apps/sntp -I/home/robbe/esp/esp-idf/components/lwip/lwip/src/include -I/home/robbe/esp/esp-idf/components/lwip/port/include -I/home/robbe/esp/esp-idf/components/lwip/port/freertos/include -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include/arch -I/home/robbe/esp/esp-idf/components/lwip/port/esp32xx/include/sys -I/home/robbe/esp/light/managed_components/espressif__esp_bsp_devkit/include -I/home/robbe/esp/esp-idf/components/driver/deprecated -I/home/robbe/esp/esp-idf/components/driver/i2c/include -I/home/robbe/esp/esp-idf/components/driver/touch_sensor/include -I/home/robbe/esp/esp-idf/components/driver/twai/include -I/home/robbe/esp/esp-idf/components/esp_pm/include -I/home/robbe/esp/esp-idf/components/esp_ringbuf/include -I/home/robbe/esp/esp-idf/components/esp_driver_gpio/include -I/home/robbe/esp/esp-idf/components/esp_driver_pcnt/include -I/home/robbe/esp/esp-idf/components/esp_driver_gptimer/include -I/home/robbe/esp/esp-idf/components/esp_driver_spi/include -I/home/robbe/esp/esp-idf/components/esp_driver_mcpwm/include -I/home/robbe/esp/esp-idf/components/esp_driver_ana_cmpr/include -I/home/robbe/esp/esp-idf/components/esp_driver_i2s/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdmmc/include -I/home/robbe/esp/esp-idf/components/sdmmc/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdspi/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdio/include -I/home/robbe/esp/esp-idf/components/esp_driver_dac/include -I/home/robbe/esp/esp-idf/components/esp_driver_rmt/include -I/home/robbe/esp/esp-idf/components/esp_driver_tsens/include -I/home/robbe/esp/esp-idf/components/esp_driver_sdm/include -I/home/robbe/esp/esp-idf/components/esp_driver_i2c/include -I/home/robbe/esp/esp-idf/components/esp_driver_uart/include -I/home/robbe/esp/esp-idf/components/vfs/include -I/home/robbe/esp/esp-idf/components/esp_driver_ledc/include -I/home/robbe/esp/esp-idf/components/esp_driver_parlio/include -I/home/robbe/esp/esp-idf/components/esp_driver_usb_serial_jtag/include -I/home/robbe/esp/esp-idf/components/spiffs/include -I/home/robbe/esp/esp-idf/components/esp_partition/include -I/home/robbe/esp/esp-idf/components/fatfs/diskio -I/home/robbe/esp/esp-idf/components/fatfs/src -I/home/robbe/esp/esp-idf/components/fatfs/vfs -I/home/robbe/esp/esp-idf/components/wear_levelling/include -I/home/robbe/esp/light/managed_components/espressif__button/include -I/home/robbe/esp/esp-idf/components/esp_adc/include -I/home/robbe/esp/esp-idf/components/esp_adc/interface -I/home/robbe/esp/esp-idf/components/esp_adc/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_adc/deprecated/include -I/home/robbe/esp/light/managed_components/espressif__led_indicator/include -I/home/robbe/esp/light/managed_components/espressif__led_strip/include -I/home/robbe/esp/light/managed_components/espressif__led_strip/interface -I/home/robbe/esp/esp-idf/components/mbedtls/port/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/library -I/home/robbe/esp/esp-idf/components/mbedtls/esp_crt_bundle/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/everest/include -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/p256-m -I/home/robbe/esp/esp-idf/components/mbedtls/mbedtls/3rdparty/p256-m/p256-m -I/home/robbe/esp/esp-idf/components/esp_app_format/include -I/home/robbe/esp/esp-idf/components/esp_bootloader_format/include -I/home/robbe/esp/esp-idf/components/app_update/include -I/home/robbe/esp/esp-idf/components/bootloader_support/include -I/home/robbe/esp/esp-idf/components/bootloader_support/bootloader_flash/include -I/home/robbe/esp/esp-idf/components/efuse/include -I/home/robbe/esp/esp-idf/components/efuse/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_mm/include -I/home/robbe/esp/esp-idf/components/spi_flash/include -I/home/robbe/esp/esp-idf/components/esp_security/include -I/home/robbe/esp/esp-idf/components/pthread/include -I/home/robbe/esp/esp-idf/components/esp_timer/include -I/home/robbe/esp/esp-idf/components/app_trace/include -I/home/robbe/esp/esp-idf/components/esp_event/include -I/home/robbe/esp/esp-idf/components/nvs_flash/include -I/home/robbe/esp/esp-idf/components/esp_phy/include -I/home/robbe/esp/esp-idf/components/esp_phy/esp32c6/include -I/home/robbe/esp/esp-idf/components/esp_vfs_console/include -I/home/robbe/esp/esp-idf/components/esp_netif/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/port/include -I/home/robbe/esp/esp-idf/components/wpa_supplicant/esp_supplicant/include -I/home/robbe/esp/esp-idf/components/esp_coex/include -I/home/robbe/esp/esp-idf/components/esp_wifi/include -I/home/robbe/esp/esp-idf/components/esp_wifi/include/local -I/home/robbe/esp/esp-idf/components/esp_wifi/wifi_apps/include -I/home/robbe/esp
 *  The terminal process "ninja" terminated with exit code: 1.
The main code:

Code: Select all

/*
   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 <esp_err.h>
#include <esp_log.h>
#include <nvs_flash.h>

#include <esp_matter.h>
#include <esp_matter_console.h>
#include <esp_matter_ota.h>

#include <common_macros.h>
#include <app_priv.h>
#include <app_reset.h>
#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
#include <platform/ESP32/OpenthreadLauncher.h>
#endif

#include <app/server/CommissioningWindowManager.h>
#include <app/server/Server.h>

#ifdef CONFIG_ENABLE_SET_CERT_DECLARATION_API
#include <esp_matter_providers.h>
#include <lib/support/Span.h>
#ifdef CONFIG_SEC_CERT_DAC_PROVIDER
#include <platform/ESP32/ESP32SecureCertDACProvider.h>
#elif defined(CONFIG_FACTORY_PARTITION_DAC_PROVIDER)
#include <platform/ESP32/ESP32FactoryDataProvider.h>
#endif
using namespace chip::DeviceLayer;
#endif

static const char *TAG = "app_main";
uint16_t light_endpoint_id = 0;

using namespace esp_matter;
using namespace esp_matter::attribute;
using namespace esp_matter::endpoint;
using namespace chip::app::Clusters;

constexpr auto k_timeout_seconds = 300;

#ifdef CONFIG_ENABLE_SET_CERT_DECLARATION_API
extern const uint8_t cd_start[] asm("_binary_certification_declaration_der_start");
extern const uint8_t cd_end[] asm("_binary_certification_declaration_der_end");

const chip::ByteSpan cdSpan(cd_start, static_cast<size_t>(cd_end - cd_start));
#endif // CONFIG_ENABLE_SET_CERT_DECLARATION_API

#if CONFIG_ENABLE_ENCRYPTED_OTA
extern const char decryption_key_start[] asm("_binary_esp_image_encryption_key_pem_start");
extern const char decryption_key_end[] asm("_binary_esp_image_encryption_key_pem_end");

static const char *s_decryption_key = decryption_key_start;
static const uint16_t s_decryption_key_len = decryption_key_end - decryption_key_start;
#endif // CONFIG_ENABLE_ENCRYPTED_OTA

static void app_event_cb(const ChipDeviceEvent *event, intptr_t arg)
{
    switch (event->Type) {
    case chip::DeviceLayer::DeviceEventType::kInterfaceIpAddressChanged:
        ESP_LOGI(TAG, "Interface IP Address changed");
        break;

    case chip::DeviceLayer::DeviceEventType::kCommissioningComplete:
        ESP_LOGI(TAG, "Commissioning complete");
        break;

    case chip::DeviceLayer::DeviceEventType::kFailSafeTimerExpired:
        ESP_LOGI(TAG, "Commissioning failed, fail safe timer expired");
        break;

    case chip::DeviceLayer::DeviceEventType::kCommissioningSessionStarted:
        ESP_LOGI(TAG, "Commissioning session started");
        break;

    case chip::DeviceLayer::DeviceEventType::kCommissioningSessionStopped:
        ESP_LOGI(TAG, "Commissioning session stopped");
        break;

    case chip::DeviceLayer::DeviceEventType::kCommissioningWindowOpened:
        ESP_LOGI(TAG, "Commissioning window opened");
        break;

    case chip::DeviceLayer::DeviceEventType::kCommissioningWindowClosed:
        ESP_LOGI(TAG, "Commissioning window closed");
        break;

    case chip::DeviceLayer::DeviceEventType::kFabricRemoved:
        {
            ESP_LOGI(TAG, "Fabric removed successfully");
            if (chip::Server::GetInstance().GetFabricTable().FabricCount() == 0)
            {
                chip::CommissioningWindowManager & commissionMgr = chip::Server::GetInstance().GetCommissioningWindowManager();
                constexpr auto kTimeoutSeconds = chip::System::Clock::Seconds16(k_timeout_seconds);
                if (!commissionMgr.IsCommissioningWindowOpen())
                {
                    /* After removing last fabric, this example does not remove the Wi-Fi credentials
                     * and still has IP connectivity so, only advertising on DNS-SD.
                     */
                    CHIP_ERROR err = commissionMgr.OpenBasicCommissioningWindow(kTimeoutSeconds,
                                                    chip::CommissioningWindowAdvertisement::kDnssdOnly);
                    if (err != CHIP_NO_ERROR)
                    {
                        ESP_LOGE(TAG, "Failed to open commissioning window, err:%" CHIP_ERROR_FORMAT, err.Format());
                    }
                }
            }
        break;
        }

    case chip::DeviceLayer::DeviceEventType::kFabricWillBeRemoved:
        ESP_LOGI(TAG, "Fabric will be removed");
        break;

    case chip::DeviceLayer::DeviceEventType::kFabricUpdated:
        ESP_LOGI(TAG, "Fabric is updated");
        break;

    case chip::DeviceLayer::DeviceEventType::kFabricCommitted:
        ESP_LOGI(TAG, "Fabric is committed");
        break;

    case chip::DeviceLayer::DeviceEventType::kBLEDeinitialized:
        ESP_LOGI(TAG, "BLE deinitialized and memory reclaimed");
        break;

    default:
        break;
    }
}

// This callback is invoked when clients interact with the Identify Cluster.
// In the callback implementation, an endpoint can identify itself. (e.g., by flashing an LED or light).
static esp_err_t app_identification_cb(identification::callback_type_t type, uint16_t endpoint_id, uint8_t effect_id,
                                       uint8_t effect_variant, void *priv_data)
{
    ESP_LOGI(TAG, "Identification callback: type: %u, effect: %u, variant: %u", type, effect_id, effect_variant);
    return ESP_OK;
}

// This callback is called for every attribute update. The callback implementation shall
// handle the desired attributes and return an appropriate error code. If the attribute
// is not of your interest, please do not return an error code and strictly return ESP_OK.
static esp_err_t app_attribute_update_cb(attribute::callback_type_t type, uint16_t endpoint_id, uint32_t cluster_id,
                                         uint32_t attribute_id, esp_matter_attr_val_t *val, void *priv_data)
{
    esp_err_t err = ESP_OK;

    if (type == PRE_UPDATE) {
        /* Driver update */
        app_driver_handle_t driver_handle = (app_driver_handle_t)priv_data;
        err = app_driver_attribute_update(driver_handle, endpoint_id, cluster_id, attribute_id, val);
    }

    return err;
}

extern "C" void app_main()
{
    esp_err_t err = ESP_OK;

    /* Initialize the ESP NVS layer */
    nvs_flash_init();

    /* Initialize driver */
    app_driver_handle_t light_handle = app_driver_light_init();
    app_driver_handle_t button_handle = app_driver_button_init();
    app_reset_button_register(button_handle);

    /* Create a Matter node and add the mandatory Root Node device type on endpoint 0 */
    node::config_t node_config;

    // node handle can be used to add/modify other endpoints.
    node_t *node = node::create(&node_config, app_attribute_update_cb, app_identification_cb);
    ABORT_APP_ON_FAILURE(node != nullptr, ESP_LOGE(TAG, "Failed to create Matter node"));

    /*extended_color_light::config_t light_config;
    light_config.on_off.on_off = DEFAULT_POWER;
    light_config.on_off.lighting.start_up_on_off = nullptr;
    light_config.level_control.current_level = DEFAULT_BRIGHTNESS;
    light_config.level_control.on_level = DEFAULT_BRIGHTNESS;
    light_config.level_control.lighting.start_up_current_level = DEFAULT_BRIGHTNESS;
    light_config.color_control.color_mode = (uint8_t)ColorControl::ColorMode::kColorTemperature;
    light_config.color_control.enhanced_color_mode = (uint8_t)ColorControl::ColorMode::kColorTemperature;
    light_config.color_control.color_temperature.startup_color_temperature_mireds = nullptr;*/
    
    // endpoint handles can be used to add/modify clusters.
    //endpoint_t *endpoint = extended_color_light::create(node, &light_config, ENDPOINT_FLAG_NONE, light_handle);
    //ABORT_APP_ON_FAILURE(endpoint != nullptr, ESP_LOGE(TAG, "Failed to create extended color light endpoint"));

    //light_endpoint_id = endpoint::get_id(endpoint);
    //ESP_LOGI(TAG, "Light created with endpoint_id %d", light_endpoint_id);

    dimmable_light::config_t motor_horizontal;
    motor_horizontal.level_control.current_level = DEFAULT_BRIGHTNESS;
    motor_horizontal.level_control.on_level = DEFAULT_BRIGHTNESS;
    motor_horizontal.level_control.lighting.start_up_current_level = DEFAULT_BRIGHTNESS;

    endpoint_t *endpoint_mot_hor = dimmable_light::create(node, &motor_horizontal, ENDPOINT_FLAG_NONE, NULL);
    //ABORT_APP_ON_FAILURE(endpoint_mot_hor != nullptr, ESP_LOGE(TAG, "Failed to create horizontal motor endpoint"));
    
    mot_hor_endpoint_id = endpoint::get_id(endpoint_mot_hor);
    //ESP_LOGI(TAG, "motor horizontal created with mot_hor_endpoint_id %d", mot_hor_endpoint_id );


    

    //attribute_t *current_HorizonLevel_attribute = attribute::get(mot_hor_endpoint_id, LevelControl::Id, LevelControl::Attributes::CurrentLevel::Id);
    //attribute::set_deferred_persistence(current_HorizonLevel_attribute);


    /* Mark deferred persistence for some attributes that might be changed rapidly 
    attribute_t *current_level_attribute = attribute::get(light_endpoint_id, LevelControl::Id, LevelControl::Attributes::CurrentLevel::Id);
    attribute::set_deferred_persistence(current_level_attribute);

    attribute_t *current_x_attribute = attribute::get(light_endpoint_id, ColorControl::Id, ColorControl::Attributes::CurrentX::Id);
    attribute::set_deferred_persistence(current_x_attribute);
    attribute_t *current_y_attribute = attribute::get(light_endpoint_id, ColorControl::Id, ColorControl::Attributes::CurrentY::Id);
    attribute::set_deferred_persistence(current_y_attribute);
    attribute_t *color_temp_attribute = attribute::get(light_endpoint_id, ColorControl::Id, ColorControl::Attributes::ColorTemperatureMireds::Id);
    attribute::set_deferred_persistence(color_temp_attribute);*/

#if CHIP_DEVICE_CONFIG_ENABLE_THREAD && CHIP_DEVICE_CONFIG_ENABLE_WIFI_STATION
    // Enable secondary network interface
    secondary_network_interface::config_t secondary_network_interface_config;
    endpoint = endpoint::secondary_network_interface::create(node, &secondary_network_interface_config, ENDPOINT_FLAG_NONE, nullptr);
    ABORT_APP_ON_FAILURE(endpoint != nullptr, ESP_LOGE(TAG, "Failed to create secondary network interface endpoint"));
#endif


#if CHIP_DEVICE_CONFIG_ENABLE_THREAD
    /* Set OpenThread platform config */
    esp_openthread_platform_config_t config = {
        .radio_config = ESP_OPENTHREAD_DEFAULT_RADIO_CONFIG(),
        .host_config = ESP_OPENTHREAD_DEFAULT_HOST_CONFIG(),
        .port_config = ESP_OPENTHREAD_DEFAULT_PORT_CONFIG(),
    };
    set_openthread_platform_config(&config);
#endif

#ifdef CONFIG_ENABLE_SET_CERT_DECLARATION_API
    auto * dac_provider = get_dac_provider();
#ifdef CONFIG_SEC_CERT_DAC_PROVIDER
    static_cast<ESP32SecureCertDACProvider *>(dac_provider)->SetCertificationDeclaration(cdSpan);
#elif defined(CONFIG_FACTORY_PARTITION_DAC_PROVIDER)
    static_cast<ESP32FactoryDataProvider *>(dac_provider)->SetCertificationDeclaration(cdSpan);
#endif
#endif // CONFIG_ENABLE_SET_CERT_DECLARATION_API

    /* Matter start */
    err = esp_matter::start(app_event_cb);
    ABORT_APP_ON_FAILURE(err == ESP_OK, ESP_LOGE(TAG, "Failed to start Matter, err:%d", err));

    /* Starting driver with default values */
    app_driver_light_set_defaults(light_endpoint_id);

#if CONFIG_ENABLE_ENCRYPTED_OTA
    err = esp_matter_ota_requestor_encrypted_init(s_decryption_key, s_decryption_key_len);
    ABORT_APP_ON_FAILURE(err == ESP_OK, ESP_LOGE(TAG, "Failed to initialized the encrypted OTA, err: %d", err));
#endif // CONFIG_ENABLE_ENCRYPTED_OTA

#if CONFIG_ENABLE_CHIP_SHELL
    esp_matter::console::diagnostics_register_commands();
    esp_matter::console::wifi_register_commands();
    esp_matter::console::factoryreset_register_commands();
#if CONFIG_OPENTHREAD_CLI
    esp_matter::console::otcli_register_commands();
#endif
    esp_matter::console::init();
#endif
}