Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[sdk] add air purifier example #174

Merged
merged 1 commit into from
Nov 7, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 17 additions & 0 deletions project/realtek_amebaz2_v0_example/GCC-RELEASE/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ OTAR_FILE = $(CHIPDIR)/examples/ota-requestor-app/ameba/build/chip/codegen/clust
OTAR_ZAP = $(CHIPDIR)/examples/ota-requestor-app/ota-requestor-common/ota-requestor-app.zap
CHEF_FILE = $(CHIPDIR)/examples/chef/ameba/build/chip/codegen/cluster-file.txt
CHEF_ZAP = $(CHIPDIR)/examples/chef/devices/$(SAMPLE_NAME).zap
AIR_PURIFIER_FILE = $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip/codegen/cluster-file.txt
AIR_PURIFIER_ZAP = $(CHIPDIR)/examples/air-purifier-app/air-purifier-common/air-purifier-app.zap

.PHONY: toolchain
toolchain:
Expand Down Expand Up @@ -100,6 +102,14 @@ $(CHEF_FILE): $(CHEF_ZAP)
@python3 $(CHIPDIR)/src/app/zap_cluster_list.py --zap_file $^ > $(CHIPDIR)/examples/chef-app/ameba/build/chip/codegen/cluster-file.txt
@python3 $(MATTER_TOOLDIR)/codegen_helpers/parse_clusters.py --cluster_file $@ --chip_path $(CHIPDIR)

$(AIR_PURIFIER_FILE): $(AIR_PURIFIER_ZAP)
@mkdir -p $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip/codegen/zap-generated
@python3 $(CHIPDIR)/scripts/tools/zap/generate.py --no-prettify-output --templates src/app/zap-templates/matter-idl-server.json --output-dir examples/air-purifier-app/ameba/build/chip/codegen/zap-generated $^
@python3 $(CHIPDIR)/scripts/tools/zap/generate.py --no-prettify-output --templates src/app/zap-templates/app-templates.json --output-dir examples/air-purifier-app/ameba/build/chip/codegen/zap-generated $^
@python3 $(CHIPDIR)/scripts/codegen.py --generator cpp-app --output-dir $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip/codegen --expected-outputs $(MATTER_TOOLDIR)/codegen_helpers/expected.outputs $(CHIPDIR)/examples/air-purifier-app/air-purifier-common/air-purifier-app.matter
@python3 $(CHIPDIR)/src/app/zap_cluster_list.py --zap_file $^ > $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip/codegen/cluster-file.txt
@python3 $(MATTER_TOOLDIR)/codegen_helpers/parse_clusters.py --cluster_file $@ --chip_path $(CHIPDIR)

.PHONY: all_clusters
all_clusters: toolchain $(ALL_CLUSTERS_FILE)
$(MAKE) -f lib_chip.mk all
Expand All @@ -125,6 +135,11 @@ chef: toolchain $(CHEF_FILE)
$(MAKE) -f lib_chip_chef_core.mk all
$(MAKE) -f lib_chip_chef_main.mk all

.PHONY: air_purifier
air_purifier: toolchain $(AIR_PURIFIER_FILE)
$(MAKE) -f lib_chip_air_purifier_core.mk all
$(MAKE) -f lib_chip_air_purifier_main.mk all

.PHONY: is_matter
is_matter: toolchain
cp partition_matter.json partition.json
Expand All @@ -142,6 +157,8 @@ clean_matter_libs:
@$(MAKE) -f lib_chip_otar_core.mk clean
@$(MAKE) -f lib_chip_chef_main.mk clean
@$(MAKE) -f lib_chip_chef_core.mk clean
@$(MAKE) -f lib_chip_air_purifier_main.mk clean
@$(MAKE) -f lib_chip_air_purifier_core.mk clean

.PHONY: clean_matter
clean_matter:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,273 @@

SHELL = /bin/bash

# Initialize tool chain
# -------------------------------------------------------------------
BASEDIR := $(shell pwd)
AMEBAZ2_TOOLDIR = $(BASEDIR)/../../../component/soc/realtek/8710c/misc/iar_utility
CHIPDIR = $(BASEDIR)/../../../third_party/connectedhomeip
OUTPUT_DIR = $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip
MATTER_TOOLDIR = $(BASEDIR)/../../../tools/matter

OS := $(shell uname)

CROSS_COMPILE = $(ARM_GCC_TOOLCHAIN)/arm-none-eabi-

# Compilation tools
AR = $(CROSS_COMPILE)ar
CC = $(CROSS_COMPILE)gcc
AS = $(CROSS_COMPILE)as
NM = $(CROSS_COMPILE)nm
LD = $(CROSS_COMPILE)gcc
GDB = $(CROSS_COMPILE)gdb
OBJCOPY = $(CROSS_COMPILE)objcopy
OBJDUMP = $(CROSS_COMPILE)objdump

OS := $(shell uname)

# Initialize target name and target object files
# -------------------------------------------------------------------

OBJ_DIR=$(TARGET)/Debug/obj
BIN_DIR=$(TARGET)/Debug/bin
INFO_DIR=$(TARGET)/Debug/info

# Include folder list
# -------------------------------------------------------------------

INCLUDES =
INCLUDES += -I$(BASEDIR)/../inc

INCLUDES += -I$(BASEDIR)/../../../component/common/api
INCLUDES += -I$(BASEDIR)/../../../component/common/api/at_cmd
INCLUDES += -I$(BASEDIR)/../../../component/common/api/platform
INCLUDES += -I$(BASEDIR)/../../../component/common/api/wifi
INCLUDES += -I$(BASEDIR)/../../../component/common/api/wifi/rtw_wpa_supplicant/src
INCLUDES += -I$(BASEDIR)/../../../component/common/api/wifi/rtw_wpa_supplicant/src/crypto
INCLUDES += -I$(BASEDIR)/../../../component/common/api/network/include
INCLUDES += -I$(BASEDIR)/../../../component/common/application
INCLUDES += -I$(BASEDIR)/../../../component/common/application/mqtt/MQTTClient
INCLUDES += -I$(BASEDIR)/../../../component/common/example
INCLUDES += -I$(BASEDIR)/../../../component/common/file_system
INCLUDES += -I$(BASEDIR)/../../../component/common/file_system/dct
INCLUDES += -I$(BASEDIR)/../../../component/common/file_system/fatfs
INCLUDES += -I$(BASEDIR)/../../../component/common/file_system/fatfs/r0.10c/include
INCLUDES += -I$(BASEDIR)/../../../component/common/file_system/ftl
INCLUDES += -I$(BASEDIR)/../../../component/common/utilities
INCLUDES += -I$(BASEDIR)/../../../component/common/mbed/hal
INCLUDES += -I$(BASEDIR)/../../../component/common/mbed/hal_ext
INCLUDES += -I$(BASEDIR)/../../../component/common/mbed/targets/hal/rtl8710c
INCLUDES += -I$(BASEDIR)/../../../component/common/network
INCLUDES += -I$(BASEDIR)/../../../component/common/network/coap/include
INCLUDES += -I$(BASEDIR)/../../../component/common/network/libcoap/include
INCLUDES += -I$(BASEDIR)/../../../component/common/network/http2/nghttp2-1.31.0/includes
INCLUDES += -I$(BASEDIR)/../../../component/common/network/lwip/lwip_v2.1.2/src/include
INCLUDES += -I$(BASEDIR)/../../../component/common/network/lwip/lwip_v2.1.2/src/include/lwip
INCLUDES += -I$(BASEDIR)/../../../component/common/network/lwip/lwip_v2.1.2/port/realtek
INCLUDES += -I$(BASEDIR)/../../../component/common/network/lwip/lwip_v2.1.2/port/realtek/freertos
INCLUDES += -I$(BASEDIR)/../../../component/common/network/ssl/mbedtls-matter/include
INCLUDES += -I$(BASEDIR)/../../../component/common/network/ssl/mbedtls-matter/include/mbedtls
#INCLUDES += -I$(BASEDIR)/../../../component/common/network/ssl/ssl_ram_map/rom
INCLUDES += -I$(BASEDIR)/../../../component/common/drivers/wlan/realtek/include
INCLUDES += -I$(BASEDIR)/../../../component/common/drivers/wlan/realtek/src/osdep
INCLUDES += -I$(BASEDIR)/../../../component/common/drivers/wlan/realtek/src/core/option
INCLUDES += -I$(BASEDIR)/../../../component/common/test
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/app
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/bluetooth/gap
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/bluetooth/profile
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/bluetooth/profile/client
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/bluetooth/profile/server
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/os
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/platform
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/inc/stack
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/lib
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/src
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/src/data_uart
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/src/hci
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/src/os
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/amebaz2/src/vendor_cmd
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/ble_central
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/ble_peripheral
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/ble_scatternet
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_fuzz_test
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_ota_central_client
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_datatrans
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/cmd
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/common
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/gap
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/inc
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/inc/amebaz2
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/model
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/model/realtek
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/platform
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/profile
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/lib/utility
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/provisioner
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/device
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/api/common
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/api/provisioner
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/api/device
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh/api
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_provisioner_rtk_demo
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_provisioner_rtk_demo/inc
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_device_rtk_demo
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_multiple_profile/device_multiple_profile
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_multiple_profile/provisioner_multiple_profile
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_multiple_profile/bt_mesh_device_matter
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_mesh_test
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/src/mcu/module/data_uart_cmd
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/src/app/hrp/gap
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/board/common/inc
INCLUDES += -I$(BASEDIR)/../../../component/common/bluetooth/realtek/sdk/example/bt_airsync_config
INCLUDES += -I$(BASEDIR)/../../../component/common/media/rtp_codec
INCLUDES += -I$(BASEDIR)/../../../component/common/media/mmfv2
INCLUDES += -I$(BASEDIR)/../../../component/common/application/airsync/1.0.4

INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/cmsis/rtl8710c/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/cmsis/rtl8710c/lib/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/fwlib/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/fwlib/lib/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/cmsis/cmsis-core/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/app/rtl_printf/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/app/shell
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/app/stdio_port
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/misc/utilities/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/mbed-drivers/include
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/misc/platform
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/misc/driver
INCLUDES += -I$(BASEDIR)/../../../component/soc/realtek/8710c/misc/os

INCLUDES += -I$(BASEDIR)/../../../component/os/freertos
INCLUDES += -I$(BASEDIR)/../../../component/os/freertos/freertos_v10.0.1/Source/include
INCLUDES += -I$(BASEDIR)/../../../component/os/freertos/freertos_v10.0.1/Source/portable/GCC/ARM_RTL8710C
INCLUDES += -I$(BASEDIR)/../../../component/os/os_dep/include

INCLUDES += -I$(BASEDIR)/../../../component/common/application/matter/common/bluetooth
INCLUDES += -I$(BASEDIR)/../../../component/common/application/matter/common/bluetooth/bt_matter_adapter
INCLUDES += -I$(BASEDIR)/../../../component/common/application/matter/common/mbedtls
INCLUDES += -I$(BASEDIR)/../../../component/common/application/matter/common/port

# CHIP Include folder list
# -------------------------------------------------------------------
INCLUDES += -I$(CHIPDIR)/config/ameba
INCLUDES += -I$(CHIPDIR)/src/include/platform/Ameba
INCLUDES += -I$(CHIPDIR)/src/include
INCLUDES += -I$(CHIPDIR)/src/lib
INCLUDES += -I$(CHIPDIR)/src
INCLUDES += -I$(CHIPDIR)/src/system
INCLUDES += -I$(CHIPDIR)/src/app
INCLUDES += -I$(CHIPDIR)/third_party/nlassert/repo/include
INCLUDES += -I$(CHIPDIR)/third_party/nlio/repo/include
INCLUDES += -I$(CHIPDIR)/third_party/nlunit-test/repo/src

# Compile options
# -------------------------------------------------------------------

CFLAGS =
CFLAGS += -march=armv8-m.main+dsp -mthumb -mcmse -mfloat-abi=soft -D__thumb2__ -g -gdwarf-3 -Os
CFLAGS += -D__ARM_ARCH_8M_MAIN__=1 -gdwarf-3 -fstack-usage -fdata-sections -ffunction-sections
CFLAGS += -fdiagnostics-color=always -Wall -Wpointer-arith -Wno-write-strings
CFLAGS += -Wno-maybe-uninitialized -c -MMD
CFLAGS += -DCONFIG_PLATFORM_8710C -DCONFIG_BUILD_RAM=1
CFLAGS += -DV8M_STKOVF
#for time64
ifdef SYSTEM_TIME64_MAKE_OPTION
CFLAGS += -DCONFIG_SYSTEM_TIME64=1
CFLAGS += -include time64.h
else
CFLAGS += -DCONFIG_SYSTEM_TIME64=0
endif

# for matter blemgr adapter
#CFLAGS += -DCONFIG_MATTER_BLEMGR_ADAPTER=1

# CHIP options
# -------------------------------------------------------------------
CFLAGS += -DCHIP_PROJECT=1
CFLAGS += -DCHIP_DEVICE_LAYER_TARGET=Ameba
CFLAGS += -DMBEDTLS_CONFIG_FILE=\"mbedtls_config.h\"

CFLAGS += -DLWIP_IPV6_ND=1
CFLAGS += -DLWIP_IPV6_SCOPES=0
CFLAGS += -DLWIP_PBUF_FROM_CUSTOM_POOLS=0
CFLAGS += -DLWIP_IPV6_ROUTE_TABLE_SUPPORT=1

CFLAGS += -DCHIP_DEVICE_LAYER_NONE=0
CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_ZEPHYR_NET_IF=0
CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_BSD_IFADDRS=0
CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_ZEPHYR_SOCKET_EXTENSIONS=0

CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_LWIP=1
CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_SOCKETS=0
CFLAGS += -DCHIP_SYSTEM_CONFIG_USE_NETWORK_FRAMEWORK=0

CFLAGS += -DCHIP_SHELL_MAX_TOKENS=11
CFLAGS += -DCONFIG_ENABLE_AMEBA_FACTORY_DATA=0

CXXFLAGS += -DFD_SETSIZE=10

CXXFLAGS += -Wno-sign-compare
CXXFLAGS += -Wno-unused-function
CXXFLAGS += -Wno-unused-but-set-variable
CXXFLAGS += -Wno-unused-label
CXXFLAGS += -Wno-unused-variable
CXXFLAGS += -Wno-deprecated-declarations
CXXFLAGS += -Wno-unused-parameter
CXXFLAGS += -Wno-format

CXXFLAGS += -std=gnu++17
CXXFLAGS += -fno-rtti
CXXFLAGS += -Wno-format-nonliteral
CXXFLAGS += -Wno-format-security

CHIP_CFLAGS = $(CFLAGS)
CHIP_CFLAGS += $(INCLUDES)

CHIP_CXXFLAGS += $(CFLAGS)
CHIP_CXXFLAGS += $(CXXFLAGS)
CHIP_CXXFLAGS += $(INCLUDES)

#*****************************************************************************#
# RULES TO GENERATE TARGETS #
#*****************************************************************************#

# Define the Rules to build the core targets
all: GENERATE_NINJA

GENERATE_NINJA:
echo "INSTALL CHIP..." && \
echo $(BASEDIR) && \
if [ ! d "$(OUTPUT_DIR")" ]; then mkdir -p "$(OUTPUT_DIR)"; fi && \
echo > $(OUTPUT_DIR)/args.gn && \
echo "import(\"//args.gni\")" >> $(OUTPUT_DIR)/args.gn && \
echo target_cflags_c = [$(foreach word,$(CHIP_CFLAGS),\"$(word)\",)] | sed -e 's/=\"/=\\"/g;s/\"\"/\\"\"/g;' >> $(OUTPUT_DIR)/args.gn && \
echo target_cflags_cc = [$(foreach word,$(CHIP_CXXFLAGS),\"$(word)\",)] | sed -e 's/=\"/=\\"/g;s/\"\"/\\"\"/g;' >> $(OUTPUT_DIR)/args.gn && \
echo ameba_ar = \"arm-none-eabi-ar\" >> $(OUTPUT_DIR)/args.gn && \
echo ameba_cc = \"arm-none-eabi-gcc\" >> $(OUTPUT_DIR)/args.gn && \
echo ameba_cxx = \"arm-none-eabi-c++\" >> $(OUTPUT_DIR)/args.gn && \
echo ameba_cpu = \"ameba\" >> $(OUTPUT_DIR)/args.gn && \
echo chip_enable_ota_requestor = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_build_libshell = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_inet_config_enable_ipv4 = "false" >> $(OUTPUT_DIR)/args.gn && \
echo chip_support_enable_storage_api_audit = "false" >> $(OUTPUT_DIR)/args.gn && \
echo chip_use_transitional_commissionable_data_provider = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_logging = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_error_logging = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_progress_logging = "true" >> $(OUTPUT_DIR)/args.gn && \
echo chip_detail_logging = "false" >> $(OUTPUT_DIR)/args.gn && \
sed -i 's/chip_build_tests\ =\ true/chip_build_tests\ =\ false/g' $(CHIPDIR)/config/ameba/args.gni && \
mkdir -p $(CHIPDIR)/config/ameba/components/chip && \
cd $(CHIPDIR)/config/ameba/components/chip && gn gen --check --fail-on-unused-args $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip && \
cd $(CHIPDIR)/config/ameba/components/chip ; ninja -C $(CHIPDIR)/examples/air-purifier-app/ameba/build/chip :ameba && \
cp -f $(OUTPUT_DIR)/lib/* $(BASEDIR)/../../../component/soc/realtek/8710c/misc/bsp/lib/common/GCC

#*****************************************************************************#
# CLEAN GENERATED FILES #
#*****************************************************************************#
.PHONY: clean
clean:
echo "RM $(OUTPUT_DIR)"
rm -rf $(OUTPUT_DIR)

Loading