123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621 |
- /**
- * Copyright (c) 2015 - 2020, Nordic Semiconductor ASA
- *
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without modification,
- * are permitted provided that the following conditions are met:
- *
- * 1. Redistributions of source code must retain the above copyright notice, this
- * list of conditions and the following disclaimer.
- *
- * 2. Redistributions in binary form, except as embedded into a Nordic
- * Semiconductor ASA integrated circuit in a product or a software update for
- * such product, must reproduce the above copyright notice, this list of
- * conditions and the following disclaimer in the documentation and/or other
- * materials provided with the distribution.
- *
- * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
- * contributors may be used to endorse or promote products derived from this
- * software without specific prior written permission.
- *
- * 4. This software, with or without modification, must only be used with a
- * Nordic Semiconductor ASA integrated circuit.
- *
- * 5. Any software provided in binary form under this license must not be reverse
- * engineered, decompiled, modified and/or disassembled.
- *
- * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
- * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
- * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
- * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
- #ifndef NRF_I2S_H__
- #define NRF_I2S_H__
- #include <nrfx.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @defgroup nrf_i2s_hal I2S HAL
- * @{
- * @ingroup nrf_i2s
- * @brief Hardware access layer for managing the Inter-IC Sound (I2S) peripheral.
- */
- /**
- * @brief This value can be provided as a parameter for the @ref nrf_i2s_pins_set
- * function call to specify that the given I2S signal (SDOUT, SDIN, or MCK)
- * shall not be connected to a physical pin.
- */
- #define NRF_I2S_PIN_NOT_CONNECTED 0xFFFFFFFF
- /** @brief I2S tasks. */
- typedef enum
- {
- NRF_I2S_TASK_START = offsetof(NRF_I2S_Type, TASKS_START), ///< Starts continuous I2S transfer. Also starts the MCK generator if this is enabled.
- NRF_I2S_TASK_STOP = offsetof(NRF_I2S_Type, TASKS_STOP) ///< Stops I2S transfer. Also stops the MCK generator.
- } nrf_i2s_task_t;
- /** @brief I2S events. */
- typedef enum
- {
- NRF_I2S_EVENT_RXPTRUPD = offsetof(NRF_I2S_Type, EVENTS_RXPTRUPD), ///< The RXD.PTR register has been copied to internal double buffers.
- NRF_I2S_EVENT_TXPTRUPD = offsetof(NRF_I2S_Type, EVENTS_TXPTRUPD), ///< The TXD.PTR register has been copied to internal double buffers.
- NRF_I2S_EVENT_STOPPED = offsetof(NRF_I2S_Type, EVENTS_STOPPED) ///< I2S transfer stopped.
- } nrf_i2s_event_t;
- /** @brief I2S interrupts. */
- typedef enum
- {
- NRF_I2S_INT_RXPTRUPD_MASK = I2S_INTENSET_RXPTRUPD_Msk, ///< Interrupt on RXPTRUPD event.
- NRF_I2S_INT_TXPTRUPD_MASK = I2S_INTENSET_TXPTRUPD_Msk, ///< Interrupt on TXPTRUPD event.
- NRF_I2S_INT_STOPPED_MASK = I2S_INTENSET_STOPPED_Msk ///< Interrupt on STOPPED event.
- } nrf_i2s_int_mask_t;
- /** @brief I2S modes of operation. */
- typedef enum
- {
- NRF_I2S_MODE_MASTER = I2S_CONFIG_MODE_MODE_Master, ///< Master mode.
- NRF_I2S_MODE_SLAVE = I2S_CONFIG_MODE_MODE_Slave ///< Slave mode.
- } nrf_i2s_mode_t;
- /** @brief I2S master clock generator settings. */
- typedef enum
- {
- NRF_I2S_MCK_DISABLED = 0, ///< MCK disabled.
- #if defined(I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV2) || defined(__NRFX_DOXYGEN__)
- // [conversion to 'int' needed to prevent compilers from complaining
- // that the provided value (0x80000000UL) is out of range of "int"]
- NRF_I2S_MCK_32MDIV2 = (int)I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV2, ///< 32 MHz / 2 = 16.0 MHz.
- #endif
- #if defined(I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV3) || defined(__NRFX_DOXYGEN__)
- NRF_I2S_MCK_32MDIV3 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV3, ///< 32 MHz / 3 = 10.6666667 MHz.
- #endif
- #if defined(I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV4) || defined(__NRFX_DOXYGEN__)
- NRF_I2S_MCK_32MDIV4 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV4, ///< 32 MHz / 4 = 8.0 MHz.
- #endif
- #if defined(I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV5) || defined(__NRFX_DOXYGEN__)
- NRF_I2S_MCK_32MDIV5 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV5, ///< 32 MHz / 5 = 6.4 MHz.
- #endif
- #if defined(I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV6) || defined(__NRFX_DOXYGEN__)
- NRF_I2S_MCK_32MDIV6 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV6, ///< 32 MHz / 6 = 5.3333333 MHz.
- #endif
- NRF_I2S_MCK_32MDIV8 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV8, ///< 32 MHz / 8 = 4.0 MHz.
- NRF_I2S_MCK_32MDIV10 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV10, ///< 32 MHz / 10 = 3.2 MHz.
- NRF_I2S_MCK_32MDIV11 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV11, ///< 32 MHz / 11 = 2.9090909 MHz.
- NRF_I2S_MCK_32MDIV15 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV15, ///< 32 MHz / 15 = 2.1333333 MHz.
- NRF_I2S_MCK_32MDIV16 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV16, ///< 32 MHz / 16 = 2.0 MHz.
- NRF_I2S_MCK_32MDIV21 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV21, ///< 32 MHz / 21 = 1.5238095 MHz.
- NRF_I2S_MCK_32MDIV23 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV23, ///< 32 MHz / 23 = 1.3913043 MHz.
- NRF_I2S_MCK_32MDIV30 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV30, ///< 32 MHz / 30 = 1.0666667 MHz.
- NRF_I2S_MCK_32MDIV31 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV31, ///< 32 MHz / 31 = 1.0322581 MHz.
- NRF_I2S_MCK_32MDIV32 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV32, ///< 32 MHz / 32 = 1.0 MHz.
- NRF_I2S_MCK_32MDIV42 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV42, ///< 32 MHz / 42 = 0.7619048 MHz.
- NRF_I2S_MCK_32MDIV63 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV63, ///< 32 MHz / 63 = 0.5079365 MHz.
- NRF_I2S_MCK_32MDIV125 = I2S_CONFIG_MCKFREQ_MCKFREQ_32MDIV125 ///< 32 MHz / 125 = 0.256 MHz.
- } nrf_i2s_mck_t;
- /** @brief I2S MCK/LRCK ratios. */
- typedef enum
- {
- NRF_I2S_RATIO_32X = I2S_CONFIG_RATIO_RATIO_32X, ///< LRCK = MCK / 32.
- NRF_I2S_RATIO_48X = I2S_CONFIG_RATIO_RATIO_48X, ///< LRCK = MCK / 48.
- NRF_I2S_RATIO_64X = I2S_CONFIG_RATIO_RATIO_64X, ///< LRCK = MCK / 64.
- NRF_I2S_RATIO_96X = I2S_CONFIG_RATIO_RATIO_96X, ///< LRCK = MCK / 96.
- NRF_I2S_RATIO_128X = I2S_CONFIG_RATIO_RATIO_128X, ///< LRCK = MCK / 128.
- NRF_I2S_RATIO_192X = I2S_CONFIG_RATIO_RATIO_192X, ///< LRCK = MCK / 192.
- NRF_I2S_RATIO_256X = I2S_CONFIG_RATIO_RATIO_256X, ///< LRCK = MCK / 256.
- NRF_I2S_RATIO_384X = I2S_CONFIG_RATIO_RATIO_384X, ///< LRCK = MCK / 384.
- NRF_I2S_RATIO_512X = I2S_CONFIG_RATIO_RATIO_512X ///< LRCK = MCK / 512.
- } nrf_i2s_ratio_t;
- /** @brief I2S sample widths. */
- typedef enum
- {
- NRF_I2S_SWIDTH_8BIT = I2S_CONFIG_SWIDTH_SWIDTH_8Bit, ///< 8 bit.
- NRF_I2S_SWIDTH_16BIT = I2S_CONFIG_SWIDTH_SWIDTH_16Bit, ///< 16 bit.
- NRF_I2S_SWIDTH_24BIT = I2S_CONFIG_SWIDTH_SWIDTH_24Bit ///< 24 bit.
- } nrf_i2s_swidth_t;
- /** @brief I2S alignments of sample within a frame. */
- typedef enum
- {
- NRF_I2S_ALIGN_LEFT = I2S_CONFIG_ALIGN_ALIGN_Left, ///< Left-aligned.
- NRF_I2S_ALIGN_RIGHT = I2S_CONFIG_ALIGN_ALIGN_Right ///< Right-aligned.
- } nrf_i2s_align_t;
- /** @brief I2S frame formats. */
- typedef enum
- {
- NRF_I2S_FORMAT_I2S = I2S_CONFIG_FORMAT_FORMAT_I2S, ///< Original I2S format.
- NRF_I2S_FORMAT_ALIGNED = I2S_CONFIG_FORMAT_FORMAT_Aligned ///< Alternate (left-aligned or right-aligned) format.
- } nrf_i2s_format_t;
- /** @brief I2S enabled channels. */
- typedef enum
- {
- NRF_I2S_CHANNELS_STEREO = I2S_CONFIG_CHANNELS_CHANNELS_Stereo, ///< Stereo.
- NRF_I2S_CHANNELS_LEFT = I2S_CONFIG_CHANNELS_CHANNELS_Left, ///< Left only.
- NRF_I2S_CHANNELS_RIGHT = I2S_CONFIG_CHANNELS_CHANNELS_Right ///< Right only.
- } nrf_i2s_channels_t;
- /**
- * @brief Function for activating the specified I2S task.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] task Task to be activated.
- */
- __STATIC_INLINE void nrf_i2s_task_trigger(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task);
- /**
- * @brief Function for getting the address of the specified I2S task register.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] task Specified task.
- *
- * @return Address of the specified task register.
- */
- __STATIC_INLINE uint32_t nrf_i2s_task_address_get(NRF_I2S_Type const * p_reg,
- nrf_i2s_task_t task);
- /**
- * @brief Function for clearing the specified I2S event.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] event Event to clear.
- */
- __STATIC_INLINE void nrf_i2s_event_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event);
- /**
- * @brief Function for retrieving the state of the I2S event.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] event Event to be checked.
- *
- * @retval true The event has been generated.
- * @retval false The event has not been generated.
- */
- __STATIC_INLINE bool nrf_i2s_event_check(NRF_I2S_Type const * p_reg,
- nrf_i2s_event_t event);
- /**
- * @brief Function for getting the address of the specified I2S event register.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] event Specified event.
- *
- * @return Address of the specified event register.
- */
- __STATIC_INLINE uint32_t nrf_i2s_event_address_get(NRF_I2S_Type const * p_reg,
- nrf_i2s_event_t event);
- /**
- * @brief Function for enabling specified interrupts.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] mask Mask of interrupts to be enabled.
- */
- __STATIC_INLINE void nrf_i2s_int_enable(NRF_I2S_Type * p_reg, uint32_t mask);
- /**
- * @brief Function for disabling specified interrupts.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] mask Mask of interrupts to be disabled.
- */
- __STATIC_INLINE void nrf_i2s_int_disable(NRF_I2S_Type * p_reg, uint32_t mask);
- /**
- * @brief Function for retrieving the state of a given interrupt.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] i2s_int Interrupt to be checked.
- *
- * @retval true The interrupt is enabled.
- * @retval false The interrupt is not enabled.
- */
- __STATIC_INLINE bool nrf_i2s_int_enable_check(NRF_I2S_Type const * p_reg,
- nrf_i2s_int_mask_t i2s_int);
- /**
- * @brief Function for enabling the I2S peripheral.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- */
- __STATIC_INLINE void nrf_i2s_enable(NRF_I2S_Type * p_reg);
- /**
- * @brief Function for disabling the I2S peripheral.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- */
- __STATIC_INLINE void nrf_i2s_disable(NRF_I2S_Type * p_reg);
- #if defined(DPPI_PRESENT) || defined(__NRFX_DOXYGEN__)
- /**
- * @brief Function for setting the subscribe configuration for a given
- * I2S task.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] task Task for which to set the configuration.
- * @param[in] channel Channel through which to subscribe events.
- */
- __STATIC_INLINE void nrf_i2s_subscribe_set(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task,
- uint8_t channel);
- /**
- * @brief Function for clearing the subscribe configuration for a given
- * I2S task.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] task Task for which to clear the configuration.
- */
- __STATIC_INLINE void nrf_i2s_subscribe_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task);
- /**
- * @brief Function for setting the publish configuration for a given
- * I2S event.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] event Event for which to set the configuration.
- * @param[in] channel Channel through which to publish the event.
- */
- __STATIC_INLINE void nrf_i2s_publish_set(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event,
- uint8_t channel);
- /**
- * @brief Function for clearing the publish configuration for a given
- * I2S event.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] event Event for which to clear the configuration.
- */
- __STATIC_INLINE void nrf_i2s_publish_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event);
- #endif // defined(DPPI_PRESENT) || defined(__NRFX_DOXYGEN__)
- /**
- * @brief Function for configuring I2S pins.
- *
- * Usage of the SDOUT, SDIN, and MCK signals is optional.
- * If a given signal is not needed, pass the @ref NRF_I2S_PIN_NOT_CONNECTED
- * value instead of its pin number.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] sck_pin SCK pin number.
- * @param[in] lrck_pin LRCK pin number.
- * @param[in] mck_pin MCK pin number.
- * @param[in] sdout_pin SDOUT pin number.
- * @param[in] sdin_pin SDIN pin number.
- */
- __STATIC_INLINE void nrf_i2s_pins_set(NRF_I2S_Type * p_reg,
- uint32_t sck_pin,
- uint32_t lrck_pin,
- uint32_t mck_pin,
- uint32_t sdout_pin,
- uint32_t sdin_pin);
- /**
- * @brief Function for setting the I2S peripheral configuration.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] mode Mode of operation (master or slave).
- * @param[in] format I2S frame format.
- * @param[in] alignment Alignment of sample within a frame.
- * @param[in] sample_width Sample width.
- * @param[in] channels Enabled channels.
- * @param[in] mck_setup Master clock generator setup.
- * @param[in] ratio MCK/LRCK ratio.
- *
- * @retval true The configuration has been set successfully.
- * @retval false The specified configuration is not allowed.
- */
- __STATIC_INLINE bool nrf_i2s_configure(NRF_I2S_Type * p_reg,
- nrf_i2s_mode_t mode,
- nrf_i2s_format_t format,
- nrf_i2s_align_t alignment,
- nrf_i2s_swidth_t sample_width,
- nrf_i2s_channels_t channels,
- nrf_i2s_mck_t mck_setup,
- nrf_i2s_ratio_t ratio);
- /**
- * @brief Function for setting up the I2S transfer.
- *
- * This function sets up the RX and TX buffers and enables reception or
- * transmission (or both) accordingly. If the transfer in a given direction is not
- * required, pass NULL instead of the pointer to the corresponding buffer.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] size Size of the buffers (in 32-bit words).
- * @param[in] p_rx_buffer Pointer to the receive buffer.
- * Pass NULL to disable reception.
- * @param[in] p_tx_buffer Pointer to the transmit buffer.
- * Pass NULL to disable transmission.
- */
- __STATIC_INLINE void nrf_i2s_transfer_set(NRF_I2S_Type * p_reg,
- uint16_t size,
- uint32_t * p_rx_buffer,
- uint32_t const * p_tx_buffer);
- /**
- * @brief Function for setting the pointer to the receive buffer.
- *
- * @note The size of the buffer can be set only by calling
- * @ref nrf_i2s_transfer_set.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] p_buffer Pointer to the receive buffer.
- */
- __STATIC_INLINE void nrf_i2s_rx_buffer_set(NRF_I2S_Type * p_reg,
- uint32_t * p_buffer);
- /**
- * @brief Function for getting the pointer to the receive buffer.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- *
- * @return Pointer to the receive buffer.
- */
- __STATIC_INLINE uint32_t * nrf_i2s_rx_buffer_get(NRF_I2S_Type const * p_reg);
- /**
- * @brief Function for setting the pointer to the transmit buffer.
- *
- * @note The size of the buffer can be set only by calling
- * @ref nrf_i2s_transfer_set.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- * @param[in] p_buffer Pointer to the transmit buffer.
- */
- __STATIC_INLINE void nrf_i2s_tx_buffer_set(NRF_I2S_Type * p_reg,
- uint32_t const * p_buffer);
- /**
- * @brief Function for getting the pointer to the transmit buffer.
- *
- * @param[in] p_reg Pointer to the structure of registers of the peripheral.
- *
- * @return Pointer to the transmit buffer.
- */
- __STATIC_INLINE uint32_t * nrf_i2s_tx_buffer_get(NRF_I2S_Type const * p_reg);
- #ifndef SUPPRESS_INLINE_IMPLEMENTATION
- __STATIC_INLINE void nrf_i2s_task_trigger(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task)
- {
- *((volatile uint32_t *)((uint8_t *)p_reg + (uint32_t)task)) = 0x1UL;
- }
- __STATIC_INLINE uint32_t nrf_i2s_task_address_get(NRF_I2S_Type const * p_reg,
- nrf_i2s_task_t task)
- {
- return ((uint32_t)p_reg + (uint32_t)task);
- }
- __STATIC_INLINE void nrf_i2s_event_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event)
- {
- *((volatile uint32_t *)((uint8_t *)p_reg + (uint32_t)event)) = 0x0UL;
- #if __CORTEX_M == 0x04
- volatile uint32_t dummy = *((volatile uint32_t *)((uint8_t *)p_reg + (uint32_t)event));
- (void)dummy;
- #endif
- }
- __STATIC_INLINE bool nrf_i2s_event_check(NRF_I2S_Type const * p_reg,
- nrf_i2s_event_t event)
- {
- return (bool)*(volatile uint32_t *)((uint8_t *)p_reg + (uint32_t)event);
- }
- __STATIC_INLINE uint32_t nrf_i2s_event_address_get(NRF_I2S_Type const * p_reg,
- nrf_i2s_event_t event)
- {
- return ((uint32_t)p_reg + (uint32_t)event);
- }
- __STATIC_INLINE void nrf_i2s_int_enable(NRF_I2S_Type * p_reg, uint32_t mask)
- {
- p_reg->INTENSET = mask;
- }
- __STATIC_INLINE void nrf_i2s_int_disable(NRF_I2S_Type * p_reg, uint32_t mask)
- {
- p_reg->INTENCLR = mask;
- }
- __STATIC_INLINE bool nrf_i2s_int_enable_check(NRF_I2S_Type const * p_reg,
- nrf_i2s_int_mask_t i2s_int)
- {
- return (bool)(p_reg->INTENSET & i2s_int);
- }
- __STATIC_INLINE void nrf_i2s_enable(NRF_I2S_Type * p_reg)
- {
- p_reg->ENABLE = (I2S_ENABLE_ENABLE_Enabled << I2S_ENABLE_ENABLE_Pos);
- }
- __STATIC_INLINE void nrf_i2s_disable(NRF_I2S_Type * p_reg)
- {
- p_reg->ENABLE = (I2S_ENABLE_ENABLE_Disabled << I2S_ENABLE_ENABLE_Pos);
- }
- #if defined(DPPI_PRESENT)
- __STATIC_INLINE void nrf_i2s_subscribe_set(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task,
- uint8_t channel)
- {
- *((volatile uint32_t *) ((uint8_t *) p_reg + (uint32_t) task + 0x80uL)) =
- ((uint32_t)channel | I2S_SUBSCRIBE_START_EN_Msk);
- }
- __STATIC_INLINE void nrf_i2s_subscribe_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_task_t task)
- {
- *((volatile uint32_t *) ((uint8_t *) p_reg + (uint32_t) task + 0x80uL)) = 0;
- }
- __STATIC_INLINE void nrf_i2s_publish_set(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event,
- uint8_t channel)
- {
- *((volatile uint32_t *) ((uint8_t *) p_reg + (uint32_t) event + 0x80uL)) =
- ((uint32_t)channel | I2S_PUBLISH_STOPPED_EN_Msk);
- }
- __STATIC_INLINE void nrf_i2s_publish_clear(NRF_I2S_Type * p_reg,
- nrf_i2s_event_t event)
- {
- *((volatile uint32_t *) ((uint8_t *) p_reg + (uint32_t) event + 0x80uL)) = 0;
- }
- #endif // defined(DPPI_PRESENT)
- __STATIC_INLINE void nrf_i2s_pins_set(NRF_I2S_Type * p_reg,
- uint32_t sck_pin,
- uint32_t lrck_pin,
- uint32_t mck_pin,
- uint32_t sdout_pin,
- uint32_t sdin_pin)
- {
- p_reg->PSEL.SCK = sck_pin;
- p_reg->PSEL.LRCK = lrck_pin;
- p_reg->PSEL.MCK = mck_pin;
- p_reg->PSEL.SDOUT = sdout_pin;
- p_reg->PSEL.SDIN = sdin_pin;
- }
- __STATIC_INLINE bool nrf_i2s_configure(NRF_I2S_Type * p_reg,
- nrf_i2s_mode_t mode,
- nrf_i2s_format_t format,
- nrf_i2s_align_t alignment,
- nrf_i2s_swidth_t sample_width,
- nrf_i2s_channels_t channels,
- nrf_i2s_mck_t mck_setup,
- nrf_i2s_ratio_t ratio)
- {
- if (mode == NRF_I2S_MODE_MASTER)
- {
- // The MCK/LRCK ratio must be a multiple of 2 * sample width.
- if (((sample_width == NRF_I2S_SWIDTH_16BIT) &&
- (ratio == NRF_I2S_RATIO_48X))
- ||
- ((sample_width == NRF_I2S_SWIDTH_24BIT) &&
- ((ratio == NRF_I2S_RATIO_32X) ||
- (ratio == NRF_I2S_RATIO_64X) ||
- (ratio == NRF_I2S_RATIO_128X) ||
- (ratio == NRF_I2S_RATIO_256X) ||
- (ratio == NRF_I2S_RATIO_512X))))
- {
- return false;
- }
- }
- p_reg->CONFIG.MODE = mode;
- p_reg->CONFIG.FORMAT = format;
- p_reg->CONFIG.ALIGN = alignment;
- p_reg->CONFIG.SWIDTH = sample_width;
- p_reg->CONFIG.CHANNELS = channels;
- p_reg->CONFIG.RATIO = ratio;
- if (mck_setup == NRF_I2S_MCK_DISABLED)
- {
- p_reg->CONFIG.MCKEN =
- (I2S_CONFIG_MCKEN_MCKEN_Disabled << I2S_CONFIG_MCKEN_MCKEN_Pos);
- }
- else
- {
- p_reg->CONFIG.MCKFREQ = mck_setup;
- p_reg->CONFIG.MCKEN =
- (I2S_CONFIG_MCKEN_MCKEN_Enabled << I2S_CONFIG_MCKEN_MCKEN_Pos);
- }
- return true;
- }
- __STATIC_INLINE void nrf_i2s_transfer_set(NRF_I2S_Type * p_reg,
- uint16_t size,
- uint32_t * p_buffer_rx,
- uint32_t const * p_buffer_tx)
- {
- p_reg->RXTXD.MAXCNT = size;
- nrf_i2s_rx_buffer_set(p_reg, p_buffer_rx);
- p_reg->CONFIG.RXEN = (p_buffer_rx != NULL) ? 1 : 0;
- nrf_i2s_tx_buffer_set(p_reg, p_buffer_tx);
- p_reg->CONFIG.TXEN = (p_buffer_tx != NULL) ? 1 : 0;
- }
- __STATIC_INLINE void nrf_i2s_rx_buffer_set(NRF_I2S_Type * p_reg,
- uint32_t * p_buffer)
- {
- p_reg->RXD.PTR = (uint32_t)p_buffer;
- }
- __STATIC_INLINE uint32_t * nrf_i2s_rx_buffer_get(NRF_I2S_Type const * p_reg)
- {
- return (uint32_t *)(p_reg->RXD.PTR);
- }
- __STATIC_INLINE void nrf_i2s_tx_buffer_set(NRF_I2S_Type * p_reg,
- uint32_t const * p_buffer)
- {
- p_reg->TXD.PTR = (uint32_t)p_buffer;
- }
- __STATIC_INLINE uint32_t * nrf_i2s_tx_buffer_get(NRF_I2S_Type const * p_reg)
- {
- return (uint32_t *)(p_reg->TXD.PTR);
- }
- #endif // SUPPRESS_INLINE_IMPLEMENTATION
- /** @} */
- #ifdef __cplusplus
- }
- #endif
- #endif // NRF_I2S_H__
|