Skip to content

Commit 19771ed

Browse files
marius-alex-tachedoru91restyled-commits
authored
[NXP] Initial support for K32W1 (project-chip#28777)
* [NXP] Introducing Matter support for K32W1 Additional information: * SDK: 2.12.5 K32W148-EVK, downloadable from https://mcuxpresso.nxp.com * MCU overview: https://www.nxp.com/products/wireless/multiprotocol-mcus/secure-and-ultra-low-power-mcu-for-matter-over-thread-and-bluetooth-le-5-3:K32W148 Signed-off-by: Doru Gucea <doru-cristian.gucea@nxp.com> Signed-off-by: Marius Tache <marius.tache@nxp.com> * [NXP] Add CI/CV support for K32W1 Signed-off-by: Marius Tache <marius.tache@nxp.com> * [NXP] Bump ot-nxp submodule Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W] Add OPENTHREAD_PLATFORM_CORE_CONFIG_FILE define Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Fix misspell Signed-off-by: Marius Tache <marius.tache@nxp.com> * Restyled by whitespace * Restyled by clang-format * Restyled by gn * Restyled by prettier-markdown * Restyled by autopep8 * Restyled by isort * [K32W1] Fix lint errors Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Removed deprecated class Signed-off-by: Marius Tache <marius.tache@nxp.com> * Restyled by clang-format * [test] Update testdata/all_targets_linux_x64 with K32W1 targets Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W] Fix target names in workflow Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Remove deprecated commented sections Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Add missing # to reference targets in README Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Fix spelling errors Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Update CSR crypto flag usage Signed-off-by: Marius Tache <marius.tache@nxp.com> * [K32W1] Remove ResetWatermarks empty implementation Signed-off-by: Marius Tache <marius.tache@nxp.com> * Fix typo in device.gni after fixing conflict Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * [K32W1] Remove anchors and backtick some words Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * [K32W] Fix confusing naming in K32W builder Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * [K32W] Remove commented option Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * [K32W] Fix binary extension format Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * Restyled by autopep8 * [K32W] Fix binary name when copying Signed-off-by: marius-alex-tache <marius.tache@nxp.com> * Restyled by clang-format * [K32W1] Fix ErrorStr header inclusion Signed-off-by: marius-alex-tache <marius.tache@nxp.com> --------- Signed-off-by: Doru Gucea <doru-cristian.gucea@nxp.com> Signed-off-by: Marius Tache <marius.tache@nxp.com> Signed-off-by: marius-alex-tache <marius.tache@nxp.com> Co-authored-by: Doru Gucea <doru-cristian.gucea@nxp.com> Co-authored-by: Restyled.io <commits@restyled.io>
1 parent 23ebaeb commit 19771ed

File tree

118 files changed

+12615
-93
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

118 files changed

+12615
-93
lines changed

.github/workflows/examples-k32w.yaml

+22-12
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,7 @@
1212
# See the License for the specific language governing permissions and
1313
# limitations under the License.
1414

15-
name: Build example - K32W with SE051
15+
name: Build example - K32W
1616

1717
on:
1818
push:
@@ -37,7 +37,7 @@ jobs:
3737
if: github.actor != 'restyled-io[bot]'
3838

3939
container:
40-
image: ghcr.io/project-chip/chip-build-k32w:5
40+
image: ghcr.io/project-chip/chip-build-k32w:6
4141
volumes:
4242
- "/tmp/bloat_reports:/tmp/bloat_reports"
4343
steps:
@@ -46,7 +46,7 @@ jobs:
4646
- name: Checkout submodules & Bootstrap
4747
uses: ./.github/actions/checkout-submodules-and-bootstrap
4848
with:
49-
platform: k32w0
49+
platform: k32w
5050

5151
- name: Set up environment for size reports
5252
uses: ./.github/actions/setup-size-reports
@@ -58,32 +58,42 @@ jobs:
5858
run: |
5959
scripts/run_in_build_env.sh "\
6060
./scripts/build/build_examples.py \
61-
--target k32w-light-crypto-platform-tokenizer \
62-
--target k32w-lock-crypto-platform-tokenizer \
63-
--target k32w-lock-crypto-platform-low-power-nologs \
64-
--target k32w-contact-crypto-platform-tokenizer \
65-
--target k32w-contact-crypto-platform-low-power-nologs \
66-
--target k32w-shell-crypto-platform \
61+
--target k32w-k32w0-light-crypto-platform-tokenizer \
62+
--target k32w-k32w0-lock-crypto-platform-tokenizer \
63+
--target k32w-k32w0-lock-crypto-platform-low-power-nologs \
64+
--target k32w-k32w0-contact-crypto-platform-tokenizer \
65+
--target k32w-k32w0-contact-crypto-platform-low-power-nologs \
66+
--target k32w-k32w0-shell-crypto-platform \
67+
--target k32w-k32w1-light-crypto-platform-openthread-ftd \
68+
--target k32w-k32w1-contact-crypto-platform-low-power-nologs \
6769
build \
6870
--copy-artifacts-to out/artifacts \
6971
"
7072
- name: Get light size stats
7173
run: |
7274
.environment/pigweed-venv/bin/python3 scripts/tools/memory/gh_sizes.py \
7375
k32w k32w0+release light \
74-
out/artifacts/k32w-light-crypto-platform-tokenizer/chip-k32w0x-light-example \
76+
out/artifacts/k32w-k32w0-light-crypto-platform-tokenizer/chip-k32w0x-light-example.elf \
77+
/tmp/bloat_reports/
78+
.environment/pigweed-venv/bin/python3 scripts/tools/memory/gh_sizes.py \
79+
k32w k32w1+release light \
80+
out/artifacts/k32w-k32w1-light-crypto-platform-openthread-ftd/chip-k32w1-light-example.elf \
7581
/tmp/bloat_reports/
7682
- name: Get lock size stats
7783
run: |
7884
.environment/pigweed-venv/bin/python3 scripts/tools/memory/gh_sizes.py \
7985
k32w k32w0+release lock \
80-
out/artifacts/k32w-lock-crypto-platform-tokenizer/chip-k32w0x-lock-example \
86+
out/artifacts/k32w-k32w0-lock-crypto-platform-tokenizer/chip-k32w0x-lock-example.elf \
8187
/tmp/bloat_reports/
8288
- name: Get contact size stats
8389
run: |
8490
.environment/pigweed-venv/bin/python3 scripts/tools/memory/gh_sizes.py \
8591
k32w k32w0+release contact \
86-
out/artifacts/k32w-contact-crypto-platform-tokenizer/chip-k32w0x-contact-example \
92+
out/artifacts/k32w-k32w0-contact-crypto-platform-tokenizer/chip-k32w0x-contact-example.elf \
93+
/tmp/bloat_reports/
94+
.environment/pigweed-venv/bin/python3 scripts/tools/memory/gh_sizes.py \
95+
k32w k32w1+release contact \
96+
out/artifacts/k32w-k32w1-contact-crypto-platform-low-power-nologs/chip-k32w1-contact-example.elf \
8797
/tmp/bloat_reports/
8898
- name: Uploading Size Reports
8999
uses: ./.github/actions/upload-size-reports

.gitmodules

+3-3
Original file line numberDiff line numberDiff line change
@@ -54,16 +54,16 @@
5454
path = third_party/freertos/repo
5555
url = https://github.com/FreeRTOS/FreeRTOS-Kernel.git
5656
branch = V10.3.1-kernel-only
57-
platforms = ameba,cc13xx_26xx,bouffalolab,efr32,esp32,k32w0,infineon,qpg,cc32xx,silabs_docker
57+
platforms = ameba,cc13xx_26xx,bouffalolab,efr32,esp32,k32w,infineon,qpg,cc32xx,silabs_docker
5858
[submodule "simw-top-mini"]
5959
path = third_party/simw-top-mini/repo
6060
url = https://github.com/NXP/plug-and-trust.git
6161
branch = int/CHIPSE_Release
62-
platforms = k32w0
62+
platforms = k32w
6363
[submodule "third_party/openthread/ot-nxp"]
6464
path = third_party/openthread/ot-nxp
6565
url = https://github.com/openthread/ot-nxp.git
66-
platforms = k32w0
66+
platforms = k32w
6767
[submodule "third_party/openthread/ot-qorvo"]
6868
path = third_party/openthread/ot-qorvo
6969
url = https://github.com/openthread/ot-qorvo.git

build_overrides/k32w1_sdk.gni

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
# Copyright (c) 2020 Project CHIP Authors
2+
#
3+
# Licensed under the Apache License, Version 2.0 (the "License");
4+
# you may not use this file except in compliance with the License.
5+
# You may obtain a copy of the License at
6+
#
7+
# http://www.apache.org/licenses/LICENSE-2.0
8+
#
9+
# Unless required by applicable law or agreed to in writing, software
10+
# distributed under the License is distributed on an "AS IS" BASIS,
11+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12+
# See the License for the specific language governing permissions and
13+
# limitations under the License.
14+
15+
declare_args() {
16+
# Root directory for K32W SDK build files.
17+
k32w1_sdk_build_root = "//third_party/nxp/k32w1_sdk"
18+
}
+19
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
# Copyright (c) 2020 Project CHIP Authors
2+
#
3+
# Licensed under the Apache License, Version 2.0 (the "License");
4+
# you may not use this file except in compliance with the License.
5+
# You may obtain a copy of the License at
6+
#
7+
# http://www.apache.org/licenses/LICENSE-2.0
8+
#
9+
# Unless required by applicable law or agreed to in writing, software
10+
# distributed under the License is distributed on an "AS IS" BASIS,
11+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12+
# See the License for the specific language governing permissions and
13+
# limitations under the License.
14+
15+
declare_args() {
16+
# Root directory for k32w SDK.
17+
k32w1_sdk_build_root =
18+
"//third_party/connectedhomeip/third_party/nxp/k32w1_sdk"
19+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
# Copyright (c) 2020-2023 Project CHIP Authors
2+
# Copyright (c) 2023 NXP
3+
#
4+
# Licensed under the Apache License, Version 2.0 (the "License");
5+
# you may not use this file except in compliance with the License.
6+
# You may obtain a copy of the License at
7+
#
8+
# http://www.apache.org/licenses/LICENSE-2.0
9+
#
10+
# Unless required by applicable law or agreed to in writing, software
11+
# distributed under the License is distributed on an "AS IS" BASIS,
12+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
# See the License for the specific language governing permissions and
14+
# limitations under the License.
15+
16+
import("//build_overrides/build.gni")
17+
18+
# The location of the build configuration file.
19+
buildconfig = "${build_root}/config/BUILDCONFIG.gn"
20+
21+
# CHIP uses angle bracket includes.
22+
check_system_includes = true
23+
24+
default_args = {
25+
target_cpu = "arm"
26+
target_os = "freertos"
27+
28+
import("//args.gni")
29+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,136 @@
1+
# Copyright (c) 2021-2023 Project CHIP Authors
2+
# Copyright (c) 2023 NXP
3+
#
4+
# Licensed under the Apache License, Version 2.0 (the "License");
5+
# you may not use this file except in compliance with the License.
6+
# You may obtain a copy of the License at
7+
#
8+
# http://www.apache.org/licenses/LICENSE-2.0
9+
#
10+
# Unless required by applicable law or agreed to in writing, software
11+
# distributed under the License is distributed on an "AS IS" BASIS,
12+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
# See the License for the specific language governing permissions and
14+
# limitations under the License.
15+
16+
import("//build_overrides/chip.gni")
17+
import("//build_overrides/k32w1_sdk.gni")
18+
import("//build_overrides/openthread.gni")
19+
20+
import("${k32w1_sdk_build_root}/k32w1_executable.gni")
21+
import("${k32w1_sdk_build_root}/k32w1_sdk.gni")
22+
23+
import("${chip_root}/src/crypto/crypto.gni")
24+
import("${chip_root}/src/lib/core/core.gni")
25+
import("${chip_root}/src/platform/device.gni")
26+
27+
declare_args() {
28+
chip_software_version = 0
29+
}
30+
31+
assert(current_os == "freertos")
32+
33+
k32w1_platform_dir = "${chip_root}/examples/platform/nxp/k32w/k32w1"
34+
k32w1_sdk_root = getenv("NXP_K32W1_SDK_ROOT")
35+
36+
k32w1_sdk("sdk") {
37+
sources = [
38+
"${k32w1_platform_dir}/app/project_include/OpenThreadConfig.h",
39+
"include/CHIPProjectConfig.h",
40+
"include/FreeRTOSConfig.h",
41+
"main/include/app_config.h",
42+
]
43+
44+
public_deps =
45+
[ "${chip_root}/third_party/openthread/platforms:libopenthread-platform" ]
46+
47+
include_dirs = [
48+
"main/include",
49+
"main",
50+
"include",
51+
"${k32w1_platform_dir}/app/project_include",
52+
"${k32w1_platform_dir}/app/support",
53+
"${k32w1_platform_dir}/util/include",
54+
]
55+
56+
defines = []
57+
if (is_debug) {
58+
defines += [ "BUILD_RELEASE=0" ]
59+
} else {
60+
defines += [ "BUILD_RELEASE=1" ]
61+
}
62+
63+
if (chip_software_version != 0) {
64+
defines += [
65+
"CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION=${chip_software_version}",
66+
]
67+
}
68+
}
69+
70+
k32w1_executable("contact_sensor_app") {
71+
output_name = "chip-k32w1-contact-example"
72+
73+
sources = [
74+
"${k32w1_platform_dir}/util/LEDWidget.cpp",
75+
"${k32w1_platform_dir}/util/include/LEDWidget.h",
76+
"main/AppTask.cpp",
77+
"main/ContactSensorManager.cpp",
78+
"main/ZclCallbacks.cpp",
79+
"main/include/AppEvent.h",
80+
"main/include/AppTask.h",
81+
"main/include/ContactSensorManager.h",
82+
"main/main.cpp",
83+
]
84+
85+
deps = [
86+
":sdk",
87+
"${chip_root}/examples/common/QRCode",
88+
"${chip_root}/examples/contact-sensor-app/contact-sensor-common",
89+
"${chip_root}/examples/providers:device_info_provider",
90+
"${chip_root}/src/lib",
91+
"${chip_root}/src/platform:syscalls_stub",
92+
"${chip_root}/third_party/mbedtls:mbedtls",
93+
"${k32w1_platform_dir}/app/support:freertos_mbedtls_utils",
94+
]
95+
96+
if (chip_openthread_ftd) {
97+
deps += [
98+
"${chip_root}/third_party/openthread/repo:libopenthread-cli-ftd",
99+
"${chip_root}/third_party/openthread/repo:libopenthread-ftd",
100+
]
101+
} else {
102+
deps += [
103+
"${chip_root}/third_party/openthread/repo:libopenthread-cli-mtd",
104+
"${chip_root}/third_party/openthread/repo:libopenthread-mtd",
105+
]
106+
}
107+
108+
cflags = [ "-Wconversion" ]
109+
110+
output_dir = root_out_dir
111+
112+
ldscript = "${k32w1_sdk_root}/middleware/wireless/framework/Common/devices/kw45_k32w1/gcc/connectivity.ld"
113+
114+
inputs = [ ldscript ]
115+
116+
ldflags = [
117+
"-Wl,--defsym=__heap_size__=0",
118+
"-Wl,--defsym=__stack_size__=0x480",
119+
"-Wl,--defsym=gNvmSectors=8",
120+
"-Wl,--defsym=lp_ram_lower_limit=0x04000000",
121+
"-Wl,--defsym=lp_ram_upper_limit=0x2001C000",
122+
"-Wl,-print-memory-usage",
123+
"-Wl,--no-warn-rwx-segments",
124+
"-T" + rebase_path(ldscript, root_build_dir),
125+
]
126+
127+
output_dir = root_out_dir
128+
}
129+
130+
group("k32w1") {
131+
deps = [ ":contact_sensor_app" ]
132+
}
133+
134+
group("default") {
135+
deps = [ ":k32w1" ]
136+
}

0 commit comments

Comments
 (0)