conn_mw.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /**
  2. * Copyright (c) 2014 - 2019, Nordic Semiconductor ASA
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. *
  9. * 1. Redistributions of source code must retain the above copyright notice, this
  10. * list of conditions and the following disclaimer.
  11. *
  12. * 2. Redistributions in binary form, except as embedded into a Nordic
  13. * Semiconductor ASA integrated circuit in a product or a software update for
  14. * such product, must reproduce the above copyright notice, this list of
  15. * conditions and the following disclaimer in the documentation and/or other
  16. * materials provided with the distribution.
  17. *
  18. * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
  19. * contributors may be used to endorse or promote products derived from this
  20. * software without specific prior written permission.
  21. *
  22. * 4. This software, with or without modification, must only be used with a
  23. * Nordic Semiconductor ASA integrated circuit.
  24. *
  25. * 5. Any software provided in binary form under this license must not be reverse
  26. * engineered, decompiled, modified and/or disassembled.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
  29. * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  30. * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
  31. * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
  32. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  33. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
  34. * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  35. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  36. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  37. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  38. *
  39. */
  40. #include <stddef.h>
  41. #include "ble_serialization.h"
  42. #include "nrf_soc.h"
  43. /**@brief Connectivity middleware handler type. */
  44. typedef uint32_t (*conn_mw_handler_t)(uint8_t const * const p_rx_buf,
  45. uint32_t rx_buf_len,
  46. uint8_t * const p_tx_buf,
  47. uint32_t * const p_tx_buf_len);
  48. /**@brief Connectivity middleware item. */
  49. typedef struct
  50. {
  51. uint8_t opcode; /**< Opcode by which specific codec is identified */
  52. conn_mw_handler_t fp_handler; /**< Function pointer to handler associated with given opcode */
  53. } conn_mw_item_t;
  54. /* Include handlers for given softdevice */
  55. #include "conn_mw_items.c"
  56. /**@brief Number of registered connectivity middleware handlers. */
  57. static const uint32_t conn_mw_item_len = sizeof (conn_mw_item) / sizeof (conn_mw_item[0]);
  58. /**@brief Local function for finding connectivity middleware handler in the table.. */
  59. static conn_mw_handler_t conn_mw_handler_get(uint8_t opcode)
  60. {
  61. conn_mw_handler_t fp_handler = NULL;
  62. uint32_t i;
  63. for (i = 0; i < conn_mw_item_len; i++)
  64. {
  65. if (opcode == conn_mw_item[i].opcode)
  66. {
  67. fp_handler = conn_mw_item[i].fp_handler;
  68. break;
  69. }
  70. }
  71. return fp_handler;
  72. }
  73. uint32_t conn_mw_handler(uint8_t const * const p_rx_buf,
  74. uint32_t rx_buf_len,
  75. uint8_t * const p_tx_buf,
  76. uint32_t * const p_tx_buf_len)
  77. {
  78. SER_ASSERT_NOT_NULL(p_rx_buf);
  79. SER_ASSERT_NOT_NULL(p_tx_buf);
  80. SER_ASSERT_NOT_NULL(p_tx_buf_len);
  81. conn_mw_handler_t fp_handler;
  82. uint32_t err_code = NRF_SUCCESS;
  83. uint8_t opcode = p_rx_buf[SER_CMD_OP_CODE_POS];
  84. fp_handler = conn_mw_handler_get(opcode);
  85. if (fp_handler)
  86. {
  87. err_code = fp_handler(p_rx_buf, rx_buf_len, p_tx_buf, p_tx_buf_len);
  88. }
  89. else
  90. {
  91. err_code = NRF_ERROR_NOT_SUPPORTED;
  92. }
  93. return err_code;
  94. }