xref: /aosp_15_r20/external/pigweed/third_party/pico_sdk/src/rp2040/hardware_structs/BUILD.gn (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1# Copyright 2022 The Pigweed Authors
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may not
4# use this file except in compliance with the License. You may obtain a copy of
5# the License at
6#
7#     https://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, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations under
13# the License.
14
15import("//build_overrides/pi_pico.gni")
16import("//build_overrides/pigweed.gni")
17
18import("$dir_pw_build/target_types.gni")
19
20# TODO(amontanez): This can go away if the GN build can be upstreamed to the
21# Pi Pico repo.
22_CWD = "${PICO_SRC_DIR}/src/rp2040/hardware_structs"
23
24config("public_include_dirs") {
25  include_dirs = [ "${_CWD}/include" ]
26}
27
28pw_source_set("hardware_structs") {
29  public_configs = [
30    ":public_include_dirs",
31    "${PICO_ROOT}/gn:disable_warnings",
32  ]
33  public_deps = [
34    "${PICO_ROOT}/src/rp2040/hardware_regs",
35    "${PICO_ROOT}/src/rp2040/hardware_regs:platform_defs",
36    "${PICO_ROOT}/src/rp2_common/hardware_base",
37  ]
38  public = [
39    "${_CWD}/include/hardware/structs/adc.h",
40    "${_CWD}/include/hardware/structs/bus_ctrl.h",
41    "${_CWD}/include/hardware/structs/clocks.h",
42    "${_CWD}/include/hardware/structs/dma.h",
43    "${_CWD}/include/hardware/structs/i2c.h",
44    "${_CWD}/include/hardware/structs/interp.h",
45    "${_CWD}/include/hardware/structs/iobank0.h",
46    "${_CWD}/include/hardware/structs/ioqspi.h",
47    "${_CWD}/include/hardware/structs/mpu.h",
48    "${_CWD}/include/hardware/structs/pads_qspi.h",
49    "${_CWD}/include/hardware/structs/padsbank0.h",
50    "${_CWD}/include/hardware/structs/pio.h",
51    "${_CWD}/include/hardware/structs/pll.h",
52    "${_CWD}/include/hardware/structs/psm.h",
53    "${_CWD}/include/hardware/structs/pwm.h",
54    "${_CWD}/include/hardware/structs/resets.h",
55    "${_CWD}/include/hardware/structs/rosc.h",
56    "${_CWD}/include/hardware/structs/rtc.h",
57    "${_CWD}/include/hardware/structs/scb.h",
58    "${_CWD}/include/hardware/structs/sio.h",
59    "${_CWD}/include/hardware/structs/spi.h",
60    "${_CWD}/include/hardware/structs/ssi.h",
61    "${_CWD}/include/hardware/structs/syscfg.h",
62    "${_CWD}/include/hardware/structs/systick.h",
63    "${_CWD}/include/hardware/structs/timer.h",
64    "${_CWD}/include/hardware/structs/uart.h",
65    "${_CWD}/include/hardware/structs/usb.h",
66    "${_CWD}/include/hardware/structs/vreg_and_chip_reset.h",
67    "${_CWD}/include/hardware/structs/watchdog.h",
68    "${_CWD}/include/hardware/structs/xip_ctrl.h",
69    "${_CWD}/include/hardware/structs/xosc.h",
70  ]
71}
72