xref: /nrf52832-nimble/nordic/nrfx/drivers/include/nrfx_pdm.h (revision 150812a83cab50279bd772ef6db1bfaf255f2c5b)
1*150812a8SEvalZero /*
2*150812a8SEvalZero  * Copyright (c) 2015 - 2018, Nordic Semiconductor ASA
3*150812a8SEvalZero  * All rights reserved.
4*150812a8SEvalZero  *
5*150812a8SEvalZero  * Redistribution and use in source and binary forms, with or without
6*150812a8SEvalZero  * modification, are permitted provided that the following conditions are met:
7*150812a8SEvalZero  *
8*150812a8SEvalZero  * 1. Redistributions of source code must retain the above copyright notice, this
9*150812a8SEvalZero  *    list of conditions and the following disclaimer.
10*150812a8SEvalZero  *
11*150812a8SEvalZero  * 2. Redistributions in binary form must reproduce the above copyright
12*150812a8SEvalZero  *    notice, this list of conditions and the following disclaimer in the
13*150812a8SEvalZero  *    documentation and/or other materials provided with the distribution.
14*150812a8SEvalZero  *
15*150812a8SEvalZero  * 3. Neither the name of the copyright holder nor the names of its
16*150812a8SEvalZero  *    contributors may be used to endorse or promote products derived from this
17*150812a8SEvalZero  *    software without specific prior written permission.
18*150812a8SEvalZero  *
19*150812a8SEvalZero  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20*150812a8SEvalZero  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21*150812a8SEvalZero  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22*150812a8SEvalZero  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23*150812a8SEvalZero  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*150812a8SEvalZero  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*150812a8SEvalZero  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*150812a8SEvalZero  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*150812a8SEvalZero  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*150812a8SEvalZero  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*150812a8SEvalZero  * POSSIBILITY OF SUCH DAMAGE.
30*150812a8SEvalZero  */
31*150812a8SEvalZero 
32*150812a8SEvalZero #ifndef NRFX_PDM_H__
33*150812a8SEvalZero #define NRFX_PDM_H__
34*150812a8SEvalZero 
35*150812a8SEvalZero #include <nrfx.h>
36*150812a8SEvalZero #include <hal/nrf_pdm.h>
37*150812a8SEvalZero 
38*150812a8SEvalZero #ifdef __cplusplus
39*150812a8SEvalZero extern "C" {
40*150812a8SEvalZero #endif
41*150812a8SEvalZero 
42*150812a8SEvalZero /**
43*150812a8SEvalZero  * @defgroup nrfx_pdm PDM driver
44*150812a8SEvalZero  * @{
45*150812a8SEvalZero  * @ingroup nrf_pdm
46*150812a8SEvalZero  * @brief   Pulse Density Modulation (PDM) peripheral driver.
47*150812a8SEvalZero  */
48*150812a8SEvalZero 
49*150812a8SEvalZero 
50*150812a8SEvalZero #define NRFX_PDM_MAX_BUFFER_SIZE 32767
51*150812a8SEvalZero 
52*150812a8SEvalZero 
53*150812a8SEvalZero /**
54*150812a8SEvalZero  * @brief PDM error type.
55*150812a8SEvalZero  */
56*150812a8SEvalZero typedef enum
57*150812a8SEvalZero {
58*150812a8SEvalZero     NRFX_PDM_NO_ERROR = 0,
59*150812a8SEvalZero     NRFX_PDM_ERROR_OVERFLOW = 1
60*150812a8SEvalZero } nrfx_pdm_error_t;
61*150812a8SEvalZero 
62*150812a8SEvalZero /**
63*150812a8SEvalZero  * @brief PDM event structure.
64*150812a8SEvalZero  */
65*150812a8SEvalZero typedef struct
66*150812a8SEvalZero {
67*150812a8SEvalZero     bool             buffer_requested;  ///< Buffer request flag.
68*150812a8SEvalZero     int16_t *        buffer_released;   ///< Pointer to the released buffer. Can be NULL.
69*150812a8SEvalZero     nrfx_pdm_error_t error;             ///< Error type.
70*150812a8SEvalZero } nrfx_pdm_evt_t;
71*150812a8SEvalZero 
72*150812a8SEvalZero /**
73*150812a8SEvalZero  * @brief PDM interface driver configuration structure.
74*150812a8SEvalZero  */
75*150812a8SEvalZero typedef struct
76*150812a8SEvalZero {
77*150812a8SEvalZero     nrf_pdm_mode_t mode;               ///< Interface operation mode.
78*150812a8SEvalZero     nrf_pdm_edge_t edge;               ///< Sampling mode.
79*150812a8SEvalZero     uint8_t        pin_clk;            ///< CLK pin.
80*150812a8SEvalZero     uint8_t        pin_din;            ///< DIN pin.
81*150812a8SEvalZero     nrf_pdm_freq_t clock_freq;         ///< Clock frequency.
82*150812a8SEvalZero     nrf_pdm_gain_t gain_l;             ///< Left channel gain.
83*150812a8SEvalZero     nrf_pdm_gain_t gain_r;             ///< Right channel gain.
84*150812a8SEvalZero     uint8_t        interrupt_priority; ///< Interrupt priority.
85*150812a8SEvalZero } nrfx_pdm_config_t;
86*150812a8SEvalZero 
87*150812a8SEvalZero /**
88*150812a8SEvalZero  * @brief Macro for setting @ref nrfx_pdm_config_t to default settings
89*150812a8SEvalZero  *        in single ended mode.
90*150812a8SEvalZero  *
91*150812a8SEvalZero  * @param _pin_clk  CLK output pin.
92*150812a8SEvalZero  * @param _pin_din  DIN input pin.
93*150812a8SEvalZero  */
94*150812a8SEvalZero #define NRFX_PDM_DEFAULT_CONFIG(_pin_clk, _pin_din)                   \
95*150812a8SEvalZero {                                                                     \
96*150812a8SEvalZero     .mode               = (nrf_pdm_mode_t)NRFX_PDM_CONFIG_MODE,       \
97*150812a8SEvalZero     .edge               = (nrf_pdm_edge_t)NRFX_PDM_CONFIG_EDGE,       \
98*150812a8SEvalZero     .pin_clk            = _pin_clk,                                   \
99*150812a8SEvalZero     .pin_din            = _pin_din,                                   \
100*150812a8SEvalZero     .clock_freq         = (nrf_pdm_freq_t)NRFX_PDM_CONFIG_CLOCK_FREQ, \
101*150812a8SEvalZero     .gain_l             = NRF_PDM_GAIN_DEFAULT,                       \
102*150812a8SEvalZero     .gain_r             = NRF_PDM_GAIN_DEFAULT,                       \
103*150812a8SEvalZero     .interrupt_priority = NRFX_PDM_CONFIG_IRQ_PRIORITY                \
104*150812a8SEvalZero }
105*150812a8SEvalZero 
106*150812a8SEvalZero /**
107*150812a8SEvalZero  * @brief Handler for PDM interface ready events.
108*150812a8SEvalZero  *
109*150812a8SEvalZero  * This event handler is called on a buffer request, an error or when a buffer
110*150812a8SEvalZero  * is full and ready to be processed.
111*150812a8SEvalZero  *
112*150812a8SEvalZero  * @param[in] p_evt Pointer to the PDM event structure.
113*150812a8SEvalZero  */
114*150812a8SEvalZero typedef void (*nrfx_pdm_event_handler_t)(nrfx_pdm_evt_t const * const p_evt);
115*150812a8SEvalZero 
116*150812a8SEvalZero 
117*150812a8SEvalZero /**
118*150812a8SEvalZero  * @brief Function for initializing the PDM interface.
119*150812a8SEvalZero  *
120*150812a8SEvalZero  * @param[in] p_config      Pointer to the structure with initial configuration.
121*150812a8SEvalZero  * @param[in] event_handler Event handler provided by the user. Cannot be NULL.
122*150812a8SEvalZero  *
123*150812a8SEvalZero  * @retval    NRFX_SUCCESS If initialization was successful.
124*150812a8SEvalZero  * @retval    NRFX_ERROR_INVALID_STATE If the driver is already initialized.
125*150812a8SEvalZero  * @retval    NRFX_ERROR_INVALID_PARAM If invalid configuration was specified.
126*150812a8SEvalZero  */
127*150812a8SEvalZero nrfx_err_t nrfx_pdm_init(nrfx_pdm_config_t const * p_config,
128*150812a8SEvalZero                          nrfx_pdm_event_handler_t  event_handler);
129*150812a8SEvalZero 
130*150812a8SEvalZero /**
131*150812a8SEvalZero  * @brief Function for uninitializing the PDM interface.
132*150812a8SEvalZero  *
133*150812a8SEvalZero  * This function stops PDM sampling, if it is in progress.
134*150812a8SEvalZero  */
135*150812a8SEvalZero void nrfx_pdm_uninit(void);
136*150812a8SEvalZero 
137*150812a8SEvalZero /**
138*150812a8SEvalZero  * @brief Function for getting the address of a PDM interface task.
139*150812a8SEvalZero  *
140*150812a8SEvalZero  * @param[in]  task Task.
141*150812a8SEvalZero  *
142*150812a8SEvalZero  * @return     Task address.
143*150812a8SEvalZero  */
nrfx_pdm_task_address_get(nrf_pdm_task_t task)144*150812a8SEvalZero __STATIC_INLINE uint32_t nrfx_pdm_task_address_get(nrf_pdm_task_t task)
145*150812a8SEvalZero {
146*150812a8SEvalZero     return nrf_pdm_task_address_get(task);
147*150812a8SEvalZero }
148*150812a8SEvalZero 
149*150812a8SEvalZero /**
150*150812a8SEvalZero  * @brief Function for getting the state of the PDM interface.
151*150812a8SEvalZero  *
152*150812a8SEvalZero  * @retval true  If the PDM interface is enabled.
153*150812a8SEvalZero  * @retval false If the PDM interface is disabled.
154*150812a8SEvalZero  */
nrfx_pdm_enable_check(void)155*150812a8SEvalZero __STATIC_INLINE bool nrfx_pdm_enable_check(void)
156*150812a8SEvalZero {
157*150812a8SEvalZero     return nrf_pdm_enable_check();
158*150812a8SEvalZero }
159*150812a8SEvalZero 
160*150812a8SEvalZero /**
161*150812a8SEvalZero  * @brief Function for starting PDM sampling.
162*150812a8SEvalZero  *
163*150812a8SEvalZero  * @retval NRFX_SUCCESS    If sampling was started successfully or was already in progress.
164*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY If a previous start/stop operation is in progress.
165*150812a8SEvalZero  */
166*150812a8SEvalZero nrfx_err_t nrfx_pdm_start(void);
167*150812a8SEvalZero 
168*150812a8SEvalZero /**
169*150812a8SEvalZero  * @brief   Function for stopping PDM sampling.
170*150812a8SEvalZero  *
171*150812a8SEvalZero  * When this function is called, the PDM interface is stopped after finishing
172*150812a8SEvalZero  * the current frame.
173*150812a8SEvalZero  * The event handler function might be called once more after calling this function.
174*150812a8SEvalZero  *
175*150812a8SEvalZero  * @retval NRFX_SUCCESS    If sampling was stopped successfully or was already stopped before.
176*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY If a previous start/stop operation is in progress.
177*150812a8SEvalZero  */
178*150812a8SEvalZero nrfx_err_t nrfx_pdm_stop(void);
179*150812a8SEvalZero 
180*150812a8SEvalZero /**
181*150812a8SEvalZero  * @brief   Function for supplying the sample buffer.
182*150812a8SEvalZero  *
183*150812a8SEvalZero  * Call this function after every buffer request event.
184*150812a8SEvalZero  *
185*150812a8SEvalZero  * @param[in]  buffer        Pointer to the receive buffer. Cannot be NULL.
186*150812a8SEvalZero  * @param[in]  buffer_length Length of the receive buffer in 16-bit words.
187*150812a8SEvalZero  *
188*150812a8SEvalZero  * @retval NRFX_SUCCESS             If the buffer was applied successfully.
189*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY          If the buffer was already supplied or the peripheral is currently being stopped.
190*150812a8SEvalZero  * @retval NRFX_ERROR_INVALID_STATE If the driver was not initialized.
191*150812a8SEvalZero  * @retval NRFX_ERROR_INVALID_PARAM If invalid parameters were provided.
192*150812a8SEvalZero  */
193*150812a8SEvalZero nrfx_err_t nrfx_pdm_buffer_set(int16_t * buffer, uint16_t buffer_length);
194*150812a8SEvalZero 
195*150812a8SEvalZero 
196*150812a8SEvalZero void nrfx_pdm_irq_handler(void);
197*150812a8SEvalZero 
198*150812a8SEvalZero 
199*150812a8SEvalZero /** @} */
200*150812a8SEvalZero 
201*150812a8SEvalZero #ifdef __cplusplus
202*150812a8SEvalZero }
203*150812a8SEvalZero #endif
204*150812a8SEvalZero 
205*150812a8SEvalZero #endif // NRFX_PDM_H__
206