123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309 |
- /**
- * @file
- * @brief SPI Devicetree macro public API header file.
- */
- /*
- * Copyright (c) 2020 Nordic Semiconductor
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_DEVICETREE_SPI_H_
- #define ZEPHYR_INCLUDE_DEVICETREE_SPI_H_
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @defgroup devicetree-spi Devicetree SPI API
- * @ingroup devicetree
- * @{
- */
- /**
- * @brief Does a SPI controller node have chip select GPIOs configured?
- *
- * SPI bus controllers use the "cs-gpios" property for configuring
- * chip select GPIOs. Its value is a phandle-array which specifies the
- * chip select lines.
- *
- * Example devicetree fragment:
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- * };
- *
- * spi2: spi@... {
- * compatible = "vnd,spi";
- * };
- *
- * Example usage:
- *
- * DT_SPI_HAS_CS_GPIOS(DT_NODELABEL(spi1)) // 1
- * DT_SPI_HAS_CS_GPIOS(DT_NODELABEL(spi2)) // 0
- *
- * @param spi a SPI bus controller node identifier
- * @return 1 if "spi" has a cs-gpios property, 0 otherwise
- */
- #define DT_SPI_HAS_CS_GPIOS(spi) DT_NODE_HAS_PROP(spi, cs_gpios)
- /**
- * @brief Number of chip select GPIOs in a SPI controller's cs-gpios property
- *
- * Example devicetree fragment:
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- * };
- *
- * spi2: spi@... {
- * compatible = "vnd,spi";
- * };
- *
- * Example usage:
- *
- * DT_SPI_NUM_CS_GPIOS(DT_NODELABEL(spi1)) // 2
- * DT_SPI_NUM_CS_GPIOS(DT_NODELABEL(spi2)) // 0
- *
- * @param spi a SPI bus controller node identifier
- * @return Logical length of spi's cs-gpios property, or 0 if "spi" doesn't
- * have a cs-gpios property
- */
- #define DT_SPI_NUM_CS_GPIOS(spi) \
- COND_CODE_1(DT_SPI_HAS_CS_GPIOS(spi), \
- (DT_PROP_LEN(spi, cs_gpios)), (0))
- /**
- * @brief Does a SPI device have a chip select line configured?
- * Example devicetree fragment:
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- *
- * a: spi-dev-a@0 {
- * reg = <0>;
- * };
- *
- * b: spi-dev-b@1 {
- * reg = <1>;
- * };
- * };
- *
- * spi2: spi@... {
- * compatible = "vnd,spi";
- * c: spi-dev-c@0 {
- * reg = <0>;
- * };
- * };
- *
- * Example usage:
- *
- * DT_SPI_DEV_HAS_CS_GPIOS(DT_NODELABEL(a)) // 1
- * DT_SPI_DEV_HAS_CS_GPIOS(DT_NODELABEL(b)) // 1
- * DT_SPI_DEV_HAS_CS_GPIOS(DT_NODELABEL(c)) // 0
- *
- * @param spi_dev a SPI device node identifier
- * @return 1 if spi_dev's bus node DT_BUS(spi_dev) has a chip select
- * pin at index DT_REG_ADDR(spi_dev), 0 otherwise
- */
- #define DT_SPI_DEV_HAS_CS_GPIOS(spi_dev) DT_SPI_HAS_CS_GPIOS(DT_BUS(spi_dev))
- /**
- * @brief Get a SPI device's chip select GPIO controller's node identifier
- *
- * Example devicetree fragment:
- *
- * gpio1: gpio@... { ... };
- *
- * gpio2: gpio@... { ... };
- *
- * spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- *
- * a: spi-dev-a@0 {
- * reg = <0>;
- * };
- *
- * b: spi-dev-b@1 {
- * reg = <1>;
- * };
- * };
- *
- * Example usage:
- *
- * DT_SPI_DEV_CS_GPIOS_CTLR(DT_NODELABEL(a)) // DT_NODELABEL(gpio1)
- * DT_SPI_DEV_CS_GPIOS_CTLR(DT_NODELABEL(b)) // DT_NODELABEL(gpio2)
- *
- * @param spi_dev a SPI device node identifier
- * @return node identifier for spi_dev's chip select GPIO controller
- */
- #define DT_SPI_DEV_CS_GPIOS_CTLR(spi_dev) \
- DT_GPIO_CTLR_BY_IDX(DT_BUS(spi_dev), cs_gpios, DT_REG_ADDR(spi_dev))
- /**
- * @brief Get a SPI device's chip select GPIO controller's label property
- *
- * Example devicetree fragment:
- *
- * gpio1: gpio@... {
- * label = "GPIO_1";
- * };
- *
- * gpio2: gpio@... {
- * label = "GPIO_2";
- * };
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- *
- * a: spi-dev-a@0 {
- * reg = <0>;
- * };
- *
- * b: spi-dev-b@1 {
- * reg = <1>;
- * };
- * };
- *
- * Example usage:
- *
- * DT_SPI_DEV_CS_GPIOS_LABEL(DT_NODELABEL(a)) // "GPIO_1"
- * DT_SPI_DEV_CS_GPIOS_LABEL(DT_NODELABEL(b)) // "GPIO_2"
- *
- * @param spi_dev a SPI device node identifier
- * @return label property of spi_dev's chip select GPIO controller
- */
- #define DT_SPI_DEV_CS_GPIOS_LABEL(spi_dev) \
- DT_GPIO_LABEL_BY_IDX(DT_BUS(spi_dev), cs_gpios, DT_REG_ADDR(spi_dev))
- /**
- * @brief Get a SPI device's chip select GPIO pin number
- *
- * It's an error if the GPIO specifier for spi_dev's entry in its
- * bus node's cs-gpios property has no pin cell.
- *
- * Example devicetree fragment:
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>,
- * <&gpio2 20 GPIO_ACTIVE_LOW>;
- *
- * a: spi-dev-a@0 {
- * reg = <0>;
- * };
- *
- * b: spi-dev-b@1 {
- * reg = <1>;
- * };
- * };
- *
- * Example usage:
- *
- * DT_SPI_DEV_CS_GPIOS_PIN(DT_NODELABEL(a)) // 10
- * DT_SPI_DEV_CS_GPIOS_PIN(DT_NODELABEL(b)) // 20
- *
- * @param spi_dev a SPI device node identifier
- * @return pin number of spi_dev's chip select GPIO
- */
- #define DT_SPI_DEV_CS_GPIOS_PIN(spi_dev) \
- DT_GPIO_PIN_BY_IDX(DT_BUS(spi_dev), cs_gpios, DT_REG_ADDR(spi_dev))
- /**
- * @brief Get a SPI device's chip select GPIO flags
- *
- * Example devicetree fragment:
- *
- * spi1: spi@... {
- * compatible = "vnd,spi";
- * cs-gpios = <&gpio1 10 GPIO_ACTIVE_LOW>;
- *
- * a: spi-dev-a@0 {
- * reg = <0>;
- * };
- * };
- *
- * Example usage:
- *
- * DT_SPI_DEV_CS_GPIOS_FLAGS(DT_NODELABEL(a)) // GPIO_ACTIVE_LOW
- *
- * If the GPIO specifier for spi_dev's entry in its bus node's
- * cs-gpios property has no flags cell, this expands to zero.
- *
- * @param spi_dev a SPI device node identifier
- * @return flags value of spi_dev's chip select GPIO specifier, or
- * zero if there is none
- */
- #define DT_SPI_DEV_CS_GPIOS_FLAGS(spi_dev) \
- DT_GPIO_FLAGS_BY_IDX(DT_BUS(spi_dev), cs_gpios, DT_REG_ADDR(spi_dev))
- /**
- * @brief Equivalent to DT_SPI_DEV_HAS_CS_GPIOS(DT_DRV_INST(inst)).
- * @param inst DT_DRV_COMPAT instance number
- * @return 1 if the instance's bus has a CS pin at index
- * DT_INST_REG_ADDR(inst), 0 otherwise
- * @see DT_SPI_DEV_HAS_CS_GPIOS()
- */
- #define DT_INST_SPI_DEV_HAS_CS_GPIOS(inst) \
- DT_SPI_DEV_HAS_CS_GPIOS(DT_DRV_INST(inst))
- /**
- * @brief Get GPIO controller node identifier for a SPI device instance
- * This is equivalent to DT_SPI_DEV_CS_GPIOS_CTLR(DT_DRV_INST(inst)).
- * @param inst DT_DRV_COMPAT instance number
- * @return node identifier for instance's chip select GPIO controller
- * @see DT_SPI_DEV_CS_GPIOS_CTLR()
- */
- #define DT_INST_SPI_DEV_CS_GPIOS_CTLR(inst) \
- DT_SPI_DEV_CS_GPIOS_CTLR(DT_DRV_INST(inst))
- /**
- * @brief Get GPIO controller name for a SPI device instance
- * This is equivalent to DT_SPI_DEV_CS_GPIOS_LABEL(DT_DRV_INST(inst)).
- * @param inst DT_DRV_COMPAT instance number
- * @return label property of the instance's chip select GPIO controller
- * @see DT_SPI_DEV_CS_GPIOS_LABEL()
- */
- #define DT_INST_SPI_DEV_CS_GPIOS_LABEL(inst) \
- DT_SPI_DEV_CS_GPIOS_LABEL(DT_DRV_INST(inst))
- /**
- * @brief Equivalent to DT_SPI_DEV_CS_GPIOS_PIN(DT_DRV_INST(inst)).
- * @param inst DT_DRV_COMPAT instance number
- * @return pin number of the instance's chip select GPIO
- * @see DT_SPI_DEV_CS_GPIOS_PIN()
- */
- #define DT_INST_SPI_DEV_CS_GPIOS_PIN(inst) \
- DT_SPI_DEV_CS_GPIOS_PIN(DT_DRV_INST(inst))
- /**
- * @brief DT_SPI_DEV_CS_GPIOS_FLAGS(DT_DRV_INST(inst)).
- * @param inst DT_DRV_COMPAT instance number
- * @return flags value of the instance's chip select GPIO specifier,
- * or zero if there is none
- * @see DT_SPI_DEV_CS_GPIOS_FLAGS()
- */
- #define DT_INST_SPI_DEV_CS_GPIOS_FLAGS(inst) \
- DT_SPI_DEV_CS_GPIOS_FLAGS(DT_DRV_INST(inst))
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* ZEPHYR_INCLUDE_DEVICETREE_SPI_H_ */
|