/* * Copyright (c) 2019-2023 Beijing Hanwei Innovation Technology Ltd. Co. and * its subsidiaries and affiliates (collectly called MKSEMI). * * 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 an MKSEMI * 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 MKSEMI 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 * MKSEMI 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 MKSEMI "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 MKSEMI 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 RANGING_FIRA_H_ #define RANGING_FIRA_H_ #include "lib_fira.h" #include "wsf_timer.h" #include "ranging_fira_task.h" #ifndef PDOA_3D_EN #define PDOA_3D_EN (0) #endif /* Main control block of the ranging task */ struct RANGING_CB_T { wsfQueue_t msg_queue; wsfHandlerId_t handle_id; wsfTimer_t daemon_timer; }; #if MCTT_TEST_EN /** Ranging round print payload indication */ struct RANGING_ROUND_PRINT_IND_T { wsfMsgHdr_t hdr; }; #endif #ifdef __cplusplus extern "C" { #endif /** * @brief Initialize ranging task. * * @param [in] handle_id Task handle ID */ int ranging_init(uint8_t handle_id); /** * @brief De-initialize ranging task. */ int ranging_deinit(void); /** * @brief Configure ranging environment variable, generate ranging keys and configure UWB subsystem. * */ void ranging_configure(void); /** * @brief Start ranging procedure. */ void ranging_start(void); /** * @brief Stop ranging procedure. */ void ranging_stop(void); /** * @brief Restart ranging procedure. * @note This function can be called once detected link loss from peer device */ void ranging_restart(void); /** * @brief Get ranging UWB TX power. * @return ranging UWB TX power in dBm */ int8_t ranging_tx_power_get(void); /** * @brief Clear ranging measurements. */ void ranging_measurements_clear(void); /** * @brief Start ranging monitor timer. * This API will be called by ranging start * * @param [in] time_ms Time to check link loss, unit: ms */ void ranging_monitor_start(uint32_t time_ms); /** * @brief Stop ranging monitor timer. * This API will be called by ranging stop */ void ranging_monitor_stop(void); /** * @brief Filter distance result. * * @param [in] mac_addr Pointer of device MAC address * @param [inout] distance Pointer of ranging distance result */ void distance_result_filter(uint8_t *mac_addr, uint16_t *distance); /** * @brief Filter angle result. * * @param [in] mac_addr Pointer of device MAC address * @param [inout] angle Pointer of angle result * @param [in] type azimuth or elevation */ void angle_result_filter(uint8_t *mac_addr, int16_t *angle, uint8_t type); /** * @brief Filter ranging result. * * @param [in] mac_addr Pointer of device MAC address * @param [inout] distance Pointer of ranging distance result * @param [inout] azimuth Pointer of azimuth result * @param [inout] elevation Pointer of elevation result */ void ranging_result_filter(uint8_t *mac_addr, uint16_t *distance, int16_t *azimuth, int16_t *elevation); /** * @brief Ranging procedure complete handler, to calculate distance. * * @param [in] ind Pointer of ranging rx done indication packet */ int measure_report_handler(const struct UWB_PKT_RX_DONE_IND_T *ind); /** * @brief Ranging result process handler. * * @param [in] ind Pointer of ranging rx done indication packet */ int ranging_result_report_handler(const struct UWB_PKT_RX_DONE_IND_T *ind); #ifdef __cplusplus } #endif #endif /* RANGING_FIRA_H_ */