IIO firmware for the AD4110
Dependencies: tempsensors sdp_k1_sdram
app/app_config.c@0:6ca37a8f8ba9, 2022-07-27 (annotated)
- Committer:
- Janani Sunil
- Date:
- Wed Jul 27 17:04:15 2022 +0530
- Revision:
- 0:6ca37a8f8ba9
Initial implementation for AD4110 IIO Firmware
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Janani Sunil | 0:6ca37a8f8ba9 | 1 | /***************************************************************************//** |
Janani Sunil | 0:6ca37a8f8ba9 | 2 | * @file app_config.c |
Janani Sunil | 0:6ca37a8f8ba9 | 3 | * @brief Application configurations module |
Janani Sunil | 0:6ca37a8f8ba9 | 4 | ******************************************************************************** |
Janani Sunil | 0:6ca37a8f8ba9 | 5 | * Copyright (c) 2022 Analog Devices, Inc. |
Janani Sunil | 0:6ca37a8f8ba9 | 6 | * All rights reserved. |
Janani Sunil | 0:6ca37a8f8ba9 | 7 | * |
Janani Sunil | 0:6ca37a8f8ba9 | 8 | * This software is proprietary to Analog Devices, Inc. and its licensors. |
Janani Sunil | 0:6ca37a8f8ba9 | 9 | * By using this software you agree to the terms of the associated |
Janani Sunil | 0:6ca37a8f8ba9 | 10 | * Analog Devices Software License Agreement. |
Janani Sunil | 0:6ca37a8f8ba9 | 11 | *******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 12 | |
Janani Sunil | 0:6ca37a8f8ba9 | 13 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 14 | /***************************** Include Files **********************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 15 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 16 | |
Janani Sunil | 0:6ca37a8f8ba9 | 17 | #include "app_config.h" |
Janani Sunil | 0:6ca37a8f8ba9 | 18 | #include "no_os_uart.h" |
Janani Sunil | 0:6ca37a8f8ba9 | 19 | #include "ad4110_data_capture.h" |
Janani Sunil | 0:6ca37a8f8ba9 | 20 | |
Janani Sunil | 0:6ca37a8f8ba9 | 21 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 22 | /************************ Macros/Constants ************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 23 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 24 | |
Janani Sunil | 0:6ca37a8f8ba9 | 25 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 26 | /*************************** Types Declarations *******************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 27 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 28 | |
Janani Sunil | 0:6ca37a8f8ba9 | 29 | /* UART init parameters */ |
Janani Sunil | 0:6ca37a8f8ba9 | 30 | struct no_os_uart_init_param uart_init_params = { |
Janani Sunil | 0:6ca37a8f8ba9 | 31 | .device_id = NULL, |
Janani Sunil | 0:6ca37a8f8ba9 | 32 | .baud_rate = IIO_UART_BAUD_RATE, |
Janani Sunil | 0:6ca37a8f8ba9 | 33 | .size = NO_OS_UART_CS_8, |
Janani Sunil | 0:6ca37a8f8ba9 | 34 | .parity = NO_OS_UART_PAR_NO, |
Janani Sunil | 0:6ca37a8f8ba9 | 35 | .stop = NO_OS_UART_STOP_1_BIT, |
Janani Sunil | 0:6ca37a8f8ba9 | 36 | .extra = &uart_extra_init_params |
Janani Sunil | 0:6ca37a8f8ba9 | 37 | }; |
Janani Sunil | 0:6ca37a8f8ba9 | 38 | |
Janani Sunil | 0:6ca37a8f8ba9 | 39 | /* GPIO - Chip select Pin init parameters */ |
Janani Sunil | 0:6ca37a8f8ba9 | 40 | static struct no_os_gpio_init_param csb_init_param = { |
Janani Sunil | 0:6ca37a8f8ba9 | 41 | .number = SPI_CSB, |
Janani Sunil | 0:6ca37a8f8ba9 | 42 | .platform_ops = &csb_platform_ops |
Janani Sunil | 0:6ca37a8f8ba9 | 43 | }; |
Janani Sunil | 0:6ca37a8f8ba9 | 44 | |
Janani Sunil | 0:6ca37a8f8ba9 | 45 | #if (DATA_CAPTURE_MODE == CONTINUOUS_DATA_CAPTURE) |
Janani Sunil | 0:6ca37a8f8ba9 | 46 | /* External interrupt init parameters */ |
Janani Sunil | 0:6ca37a8f8ba9 | 47 | static struct no_os_irq_init_param ext_int_init_params = { |
Janani Sunil | 0:6ca37a8f8ba9 | 48 | .irq_ctrl_id = 0, |
Janani Sunil | 0:6ca37a8f8ba9 | 49 | .extra = &ext_int_extra_init_params, |
Janani Sunil | 0:6ca37a8f8ba9 | 50 | .platform_ops = &irq_platform_ops, |
Janani Sunil | 0:6ca37a8f8ba9 | 51 | }; |
Janani Sunil | 0:6ca37a8f8ba9 | 52 | /* External interrupt callback descriptor */ |
Janani Sunil | 0:6ca37a8f8ba9 | 53 | static struct no_os_callback_desc ext_int_callback_desc = { |
Janani Sunil | 0:6ca37a8f8ba9 | 54 | data_capture_callback, |
Janani Sunil | 0:6ca37a8f8ba9 | 55 | NULL, |
Janani Sunil | 0:6ca37a8f8ba9 | 56 | NULL |
Janani Sunil | 0:6ca37a8f8ba9 | 57 | }; |
Janani Sunil | 0:6ca37a8f8ba9 | 58 | #endif |
Janani Sunil | 0:6ca37a8f8ba9 | 59 | |
Janani Sunil | 0:6ca37a8f8ba9 | 60 | /* UART descriptor */ |
Janani Sunil | 0:6ca37a8f8ba9 | 61 | struct no_os_uart_desc *uart_desc; |
Janani Sunil | 0:6ca37a8f8ba9 | 62 | |
Janani Sunil | 0:6ca37a8f8ba9 | 63 | /* GPIO descriptor for the chip select pin */ |
Janani Sunil | 0:6ca37a8f8ba9 | 64 | no_os_gpio_desc *csb_gpio; |
Janani Sunil | 0:6ca37a8f8ba9 | 65 | |
Janani Sunil | 0:6ca37a8f8ba9 | 66 | /* External interrupt descriptor */ |
Janani Sunil | 0:6ca37a8f8ba9 | 67 | struct no_os_irq_ctrl_desc *external_int_desc; |
Janani Sunil | 0:6ca37a8f8ba9 | 68 | |
Janani Sunil | 0:6ca37a8f8ba9 | 69 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 70 | /************************ Functions Prototypes ********************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 71 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 72 | |
Janani Sunil | 0:6ca37a8f8ba9 | 73 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 74 | /************************ Functions Definitions *******************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 75 | /******************************************************************************/ |
Janani Sunil | 0:6ca37a8f8ba9 | 76 | |
Janani Sunil | 0:6ca37a8f8ba9 | 77 | /** |
Janani Sunil | 0:6ca37a8f8ba9 | 78 | * @brief Initialize the UART peripheral |
Janani Sunil | 0:6ca37a8f8ba9 | 79 | * @return 0 in case of success, negative error code otherwise |
Janani Sunil | 0:6ca37a8f8ba9 | 80 | */ |
Janani Sunil | 0:6ca37a8f8ba9 | 81 | static int32_t init_uart(void) |
Janani Sunil | 0:6ca37a8f8ba9 | 82 | { |
Janani Sunil | 0:6ca37a8f8ba9 | 83 | return no_os_uart_init(&uart_desc, &uart_init_params); |
Janani Sunil | 0:6ca37a8f8ba9 | 84 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 85 | |
Janani Sunil | 0:6ca37a8f8ba9 | 86 | |
Janani Sunil | 0:6ca37a8f8ba9 | 87 | #if (DATA_CAPTURE_MODE == CONTINUOUS_DATA_CAPTURE) |
Janani Sunil | 0:6ca37a8f8ba9 | 88 | /** |
Janani Sunil | 0:6ca37a8f8ba9 | 89 | * @brief Initialize the IRQ contoller |
Janani Sunil | 0:6ca37a8f8ba9 | 90 | * @return 0 in case of success, negative error code otherwise |
Janani Sunil | 0:6ca37a8f8ba9 | 91 | * @details This function initialize the interrupts for system peripherals |
Janani Sunil | 0:6ca37a8f8ba9 | 92 | */ |
Janani Sunil | 0:6ca37a8f8ba9 | 93 | int32_t init_interrupt(void) |
Janani Sunil | 0:6ca37a8f8ba9 | 94 | { |
Janani Sunil | 0:6ca37a8f8ba9 | 95 | int32_t ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 96 | |
Janani Sunil | 0:6ca37a8f8ba9 | 97 | do { |
Janani Sunil | 0:6ca37a8f8ba9 | 98 | /* Init interrupt controller for external interrupt */ |
Janani Sunil | 0:6ca37a8f8ba9 | 99 | ret = no_os_irq_ctrl_init(&external_int_desc, &ext_int_init_params); |
Janani Sunil | 0:6ca37a8f8ba9 | 100 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 101 | break; |
Janani Sunil | 0:6ca37a8f8ba9 | 102 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 103 | |
Janani Sunil | 0:6ca37a8f8ba9 | 104 | /* Register a callback function for external interrupt */ |
Janani Sunil | 0:6ca37a8f8ba9 | 105 | ret = no_os_irq_register_callback(external_int_desc, |
Janani Sunil | 0:6ca37a8f8ba9 | 106 | IRQ_INT_ID, |
Janani Sunil | 0:6ca37a8f8ba9 | 107 | &ext_int_callback_desc); |
Janani Sunil | 0:6ca37a8f8ba9 | 108 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 109 | break; |
Janani Sunil | 0:6ca37a8f8ba9 | 110 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 111 | |
Janani Sunil | 0:6ca37a8f8ba9 | 112 | return 0; |
Janani Sunil | 0:6ca37a8f8ba9 | 113 | } while (0); |
Janani Sunil | 0:6ca37a8f8ba9 | 114 | |
Janani Sunil | 0:6ca37a8f8ba9 | 115 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 116 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 117 | #endif |
Janani Sunil | 0:6ca37a8f8ba9 | 118 | |
Janani Sunil | 0:6ca37a8f8ba9 | 119 | |
Janani Sunil | 0:6ca37a8f8ba9 | 120 | /** |
Janani Sunil | 0:6ca37a8f8ba9 | 121 | * @brief Initialize the system peripherals |
Janani Sunil | 0:6ca37a8f8ba9 | 122 | * @return 0 in case of success, Negative error code otherwise |
Janani Sunil | 0:6ca37a8f8ba9 | 123 | */ |
Janani Sunil | 0:6ca37a8f8ba9 | 124 | int32_t init_system(void) |
Janani Sunil | 0:6ca37a8f8ba9 | 125 | { |
Janani Sunil | 0:6ca37a8f8ba9 | 126 | int32_t ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 127 | |
Janani Sunil | 0:6ca37a8f8ba9 | 128 | ret = init_uart(); |
Janani Sunil | 0:6ca37a8f8ba9 | 129 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 130 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 131 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 132 | |
Janani Sunil | 0:6ca37a8f8ba9 | 133 | #if defined(USE_SDRAM_CAPTURE_BUFFER) |
Janani Sunil | 0:6ca37a8f8ba9 | 134 | ret = sdram_init(); |
Janani Sunil | 0:6ca37a8f8ba9 | 135 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 136 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 137 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 138 | #endif |
Janani Sunil | 0:6ca37a8f8ba9 | 139 | |
Janani Sunil | 0:6ca37a8f8ba9 | 140 | #if (DATA_CAPTURE_MODE == CONTINUOUS_DATA_CAPTURE) |
Janani Sunil | 0:6ca37a8f8ba9 | 141 | ret = init_interrupt(); |
Janani Sunil | 0:6ca37a8f8ba9 | 142 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 143 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 144 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 145 | |
Janani Sunil | 0:6ca37a8f8ba9 | 146 | ret = no_os_gpio_get(&csb_gpio, &csb_init_param); |
Janani Sunil | 0:6ca37a8f8ba9 | 147 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 148 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 149 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 150 | |
Janani Sunil | 0:6ca37a8f8ba9 | 151 | ret = no_os_gpio_direction_output(csb_gpio, NO_OS_GPIO_HIGH); |
Janani Sunil | 0:6ca37a8f8ba9 | 152 | if (ret) { |
Janani Sunil | 0:6ca37a8f8ba9 | 153 | return ret; |
Janani Sunil | 0:6ca37a8f8ba9 | 154 | } |
Janani Sunil | 0:6ca37a8f8ba9 | 155 | #endif |
Janani Sunil | 0:6ca37a8f8ba9 | 156 | |
Janani Sunil | 0:6ca37a8f8ba9 | 157 | return 0; |
Janani Sunil | 0:6ca37a8f8ba9 | 158 | } |