xref: /aosp_15_r20/external/pigweed/pw_spi_mcuxpresso/BUILD.gn (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker# Copyright 2023 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker#
3*61c4878aSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker# use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker# the License at
6*61c4878aSAndroid Build Coastguard Worker#
7*61c4878aSAndroid Build Coastguard Worker#     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker#
9*61c4878aSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker# License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker# the License.
14*61c4878aSAndroid Build Coastguard Worker
15*61c4878aSAndroid Build Coastguard Workerimport("//build_overrides/pigweed.gni")
16*61c4878aSAndroid Build Coastguard Worker
17*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_build/target_types.gni")
18*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_docgen/docs.gni")
19*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_third_party/mcuxpresso/mcuxpresso.gni")
20*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_unit_test/test.gni")
21*61c4878aSAndroid Build Coastguard Worker
22*61c4878aSAndroid Build Coastguard Workerconfig("default_config") {
23*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "public" ]
24*61c4878aSAndroid Build Coastguard Worker}
25*61c4878aSAndroid Build Coastguard Worker
26*61c4878aSAndroid Build Coastguard Workergroup("pw_spi_mcuxpresso") {
27*61c4878aSAndroid Build Coastguard Worker  deps = [
28*61c4878aSAndroid Build Coastguard Worker    ":flexio_spi",
29*61c4878aSAndroid Build Coastguard Worker    ":spi",
30*61c4878aSAndroid Build Coastguard Worker  ]
31*61c4878aSAndroid Build Coastguard Worker}
32*61c4878aSAndroid Build Coastguard Worker
33*61c4878aSAndroid Build Coastguard Workerif (pw_third_party_mcuxpresso_SDK != "") {
34*61c4878aSAndroid Build Coastguard Worker  pw_source_set("spi") {
35*61c4878aSAndroid Build Coastguard Worker    public_configs = [ ":default_config" ]
36*61c4878aSAndroid Build Coastguard Worker    public = [ "public/pw_spi_mcuxpresso/spi.h" ]
37*61c4878aSAndroid Build Coastguard Worker    public_deps = [
38*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:chip_selector",
39*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:initiator",
40*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_status",
41*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:binary_semaphore",
42*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:lock_annotations",
43*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:mutex",
44*61c4878aSAndroid Build Coastguard Worker      "$pw_third_party_mcuxpresso_SDK",
45*61c4878aSAndroid Build Coastguard Worker    ]
46*61c4878aSAndroid Build Coastguard Worker    deps = [
47*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_assert",
48*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_chrono:system_clock",
49*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_log",
50*61c4878aSAndroid Build Coastguard Worker    ]
51*61c4878aSAndroid Build Coastguard Worker    sources = [ "spi.cc" ]
52*61c4878aSAndroid Build Coastguard Worker  }
53*61c4878aSAndroid Build Coastguard Worker
54*61c4878aSAndroid Build Coastguard Worker  pw_source_set("flexio_spi") {
55*61c4878aSAndroid Build Coastguard Worker    public_configs = [ ":default_config" ]
56*61c4878aSAndroid Build Coastguard Worker    public = [ "public/pw_spi_mcuxpresso/flexio_spi.h" ]
57*61c4878aSAndroid Build Coastguard Worker    public_deps = [
58*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_digital_io",
59*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:chip_selector",
60*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:initiator",
61*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_status",
62*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:binary_semaphore",
63*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:lock_annotations",
64*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:mutex",
65*61c4878aSAndroid Build Coastguard Worker      "$pw_third_party_mcuxpresso_SDK",
66*61c4878aSAndroid Build Coastguard Worker    ]
67*61c4878aSAndroid Build Coastguard Worker    deps = [
68*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_chrono:system_clock",
69*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_log",
70*61c4878aSAndroid Build Coastguard Worker    ]
71*61c4878aSAndroid Build Coastguard Worker    sources = [ "flexio_spi.cc" ]
72*61c4878aSAndroid Build Coastguard Worker  }
73*61c4878aSAndroid Build Coastguard Worker
74*61c4878aSAndroid Build Coastguard Worker  pw_source_set("responder") {
75*61c4878aSAndroid Build Coastguard Worker    public_configs = [ ":default_config" ]
76*61c4878aSAndroid Build Coastguard Worker    public = [ "public/pw_spi_mcuxpresso/responder.h" ]
77*61c4878aSAndroid Build Coastguard Worker    public_deps = [
78*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_digital_io",
79*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:initiator",
80*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:responder",
81*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_status",
82*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:binary_semaphore",
83*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:lock_annotations",
84*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_sync:mutex",
85*61c4878aSAndroid Build Coastguard Worker      "$pw_third_party_mcuxpresso_SDK",
86*61c4878aSAndroid Build Coastguard Worker    ]
87*61c4878aSAndroid Build Coastguard Worker    deps = [
88*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_chrono:system_clock",
89*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_log",
90*61c4878aSAndroid Build Coastguard Worker    ]
91*61c4878aSAndroid Build Coastguard Worker    sources = [ "responder.cc" ]
92*61c4878aSAndroid Build Coastguard Worker  }
93*61c4878aSAndroid Build Coastguard Worker
94*61c4878aSAndroid Build Coastguard Worker  pw_test("spi_test") {
95*61c4878aSAndroid Build Coastguard Worker    enable_if =
96*61c4878aSAndroid Build Coastguard Worker        pw_third_party_mcuxpresso_SDK ==
97*61c4878aSAndroid Build Coastguard Worker        "//targets/mimxrt595_evk_freertos:sdk" &&
98*61c4878aSAndroid Build Coastguard Worker        (pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_debug" ||
99*61c4878aSAndroid Build Coastguard Worker         pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_size_optimized" ||
100*61c4878aSAndroid Build Coastguard Worker         pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_speed_optimized")
101*61c4878aSAndroid Build Coastguard Worker    sources = [ "spi_test.cc" ]
102*61c4878aSAndroid Build Coastguard Worker    deps = [
103*61c4878aSAndroid Build Coastguard Worker      ":spi",
104*61c4878aSAndroid Build Coastguard Worker      "$dir_pw_spi:device",
105*61c4878aSAndroid Build Coastguard Worker      "//targets/mimxrt595_evk_freertos:sdk",
106*61c4878aSAndroid Build Coastguard Worker    ]
107*61c4878aSAndroid Build Coastguard Worker  }
108*61c4878aSAndroid Build Coastguard Worker
109*61c4878aSAndroid Build Coastguard Worker  pw_test("flexio_spi_test") {
110*61c4878aSAndroid Build Coastguard Worker    enable_if =
111*61c4878aSAndroid Build Coastguard Worker        pw_third_party_mcuxpresso_SDK ==
112*61c4878aSAndroid Build Coastguard Worker        "//targets/mimxrt595_evk_freertos:sdk" &&
113*61c4878aSAndroid Build Coastguard Worker        (pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_debug" ||
114*61c4878aSAndroid Build Coastguard Worker         pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_size_optimized" ||
115*61c4878aSAndroid Build Coastguard Worker         pw_toolchain_SCOPE.name == "mimxrt595_evk_freertos_speed_optimized")
116*61c4878aSAndroid Build Coastguard Worker    sources = [ "flexio_spi_test.cc" ]
117*61c4878aSAndroid Build Coastguard Worker    deps = [
118*61c4878aSAndroid Build Coastguard Worker      ":flexio_spi",
119*61c4878aSAndroid Build Coastguard Worker      "//targets/mimxrt595_evk_freertos:sdk",
120*61c4878aSAndroid Build Coastguard Worker    ]
121*61c4878aSAndroid Build Coastguard Worker  }
122*61c4878aSAndroid Build Coastguard Worker
123*61c4878aSAndroid Build Coastguard Worker  pw_test_group("tests") {
124*61c4878aSAndroid Build Coastguard Worker    tests = [
125*61c4878aSAndroid Build Coastguard Worker      ":spi_test",
126*61c4878aSAndroid Build Coastguard Worker      ":flexio_spi_test",
127*61c4878aSAndroid Build Coastguard Worker    ]
128*61c4878aSAndroid Build Coastguard Worker  }
129*61c4878aSAndroid Build Coastguard Worker} else {
130*61c4878aSAndroid Build Coastguard Worker  pw_test_group("tests") {
131*61c4878aSAndroid Build Coastguard Worker    tests = []
132*61c4878aSAndroid Build Coastguard Worker  }
133*61c4878aSAndroid Build Coastguard Worker}
134*61c4878aSAndroid Build Coastguard Worker
135*61c4878aSAndroid Build Coastguard Workerpw_doc_group("docs") {
136*61c4878aSAndroid Build Coastguard Worker  sources = [ "docs.rst" ]
137*61c4878aSAndroid Build Coastguard Worker}
138