acc_hal_integration_stm32cube_xm.c
Go to the documentation of this file.
1 // Copyright (c) Acconeer AB, 2022-2023
2 // All rights reserved
3 // This file is subject to the terms and conditions defined in the file
4 // 'LICENSES/license_acconeer.txt', (BSD 3-Clause License) which is part
5 // of this source code package.
6 
7 #include <stdarg.h>
8 #include <stdbool.h>
9 #include <stdint.h>
10 #include <stdio.h>
11 #include <string.h>
12 
13 #include "main.h"
14 
15 #include "acc_definitions_common.h"
18 #include "acc_integration.h"
19 #include "acc_integration_log.h"
20 
21 /* spi handle */
22 extern SPI_HandleTypeDef A121_SPI_HANDLE;
23 
24 /**
25  * @brief The number of sensors available on the board
26  */
27 #define SENSOR_COUNT 1
28 
29 /**
30  * @brief Size of SPI transfer buffer
31  */
32 #ifndef STM32_MAX_TRANSFER_SIZE
33 #define STM32_MAX_TRANSFER_SIZE 65535
34 #endif
35 
36 static inline void disable_interrupts(void)
37 {
38  __disable_irq();
39 }
40 
41 static inline void enable_interrupts(void)
42 {
43  __enable_irq();
44  __ISB();
45 }
46 
47 #ifdef A121_USE_SPI_DMA
48 static volatile bool spi_transfer_complete;
49 
50 void HAL_SPI_TxRxCpltCallback(SPI_HandleTypeDef *h_spi)
51 {
52  (void)h_spi;
53  spi_transfer_complete = true;
54 }
55 
56 #endif
57 
58 //----------------------------------------
59 // Implementation of RSS HAL handlers
60 //----------------------------------------
61 
62 static void acc_hal_integration_sensor_transfer16(acc_sensor_id_t sensor_id, uint16_t *buffer, size_t buffer_length)
63 
64 {
65  (void)sensor_id; // Ignore parameter sensor_id
66 
67  const uint32_t SPI_TRANSMIT_RECEIVE_TIMEOUT = 5000;
68 
69 #ifdef A121_USE_SPI_DMA
70  spi_transfer_complete = false;
71  HAL_StatusTypeDef status = HAL_SPI_TransmitReceive_DMA(&A121_SPI_HANDLE, (uint8_t *)buffer, (uint8_t *)buffer, buffer_length);
72 
73  if (status != HAL_OK)
74  {
75  return;
76  }
77 
78  uint32_t start = HAL_GetTick();
79 
80  while (!spi_transfer_complete && (HAL_GetTick() - start) < SPI_TRANSMIT_RECEIVE_TIMEOUT)
81  {
82  // Turn off interrupts
84  // Check once more so that the interrupt have not occurred
85  if (!spi_transfer_complete)
86  {
87  __WFI();
88  }
89 
90  // Enable interrupt again, the ISR will execute directly after this
92  }
93 #else
94  HAL_SPI_TransmitReceive(&A121_SPI_HANDLE, (uint8_t *)buffer, (uint8_t *)buffer, buffer_length, SPI_TRANSMIT_RECEIVE_TIMEOUT);
95 
96 #endif
97 }
98 
100 {
101  (void)sensor_id; // Ignore parameter sensor_id
102 }
103 
105 {
106  (void)sensor_id; // Ignore parameter sensor_id
107 }
108 
110 {
111  (void)sensor_id; // Ignore parameter sensor_id
112 
113  HAL_GPIO_WritePin(ENABLE_GPIO_Port, ENABLE_Pin, GPIO_PIN_SET);
114 
115  // Wait 2 ms to make sure that the sensor crystal have time to stabilize
117 }
118 
120 {
121  (void)sensor_id; // Ignore parameter sensor_id
122 
123  HAL_GPIO_WritePin(ENABLE_GPIO_Port, ENABLE_Pin, GPIO_PIN_RESET);
124 
125  // Wait after disable to leave the sensor in a known state
126  // in case the application intends to enable the sensor directly
128 }
129 
131 {
132  (void)sensor_id; // Ignore parameter sensor_id
133 
134  const uint32_t wait_begin_ms = HAL_GetTick();
135  while ((HAL_GPIO_ReadPin(INTERRUPT_GPIO_Port, INTERRUPT_Pin) != GPIO_PIN_SET) && (HAL_GetTick() - wait_begin_ms < timeout_ms))
136  {
137  // Wait for the GPIO interrupt
139  // Check again so that IRQ did not occur
140  if (HAL_GPIO_ReadPin(INTERRUPT_GPIO_Port, INTERRUPT_Pin) != GPIO_PIN_SET)
141  {
142  __WFI();
143  }
144 
145  // Enable interrupts again to allow pending interrupt to be handled
147  }
148 
149  return HAL_GPIO_ReadPin(INTERRUPT_GPIO_Port, INTERRUPT_Pin) == GPIO_PIN_SET;
150 }
151 
153 {
154  static const acc_hal_a121_t val = {
156 
157  .mem_alloc = malloc,
158  .mem_free = free,
159 
160  .transfer = NULL,
161  .log = acc_integration_log,
162 
163  .optimization.transfer16 = acc_hal_integration_sensor_transfer16,
164  };
165 
166  return &val;
167 }
168 
170 {
171  return SENSOR_COUNT;
172 }
acc_hal_integration_sensor_supply_on
void acc_hal_integration_sensor_supply_on(acc_sensor_id_t sensor_id)
Power on sensor supply.
Definition: acc_hal_integration_stm32cube_xm.c:99
STM32_MAX_TRANSFER_SIZE
#define STM32_MAX_TRANSFER_SIZE
Size of SPI transfer buffer.
Definition: acc_hal_integration_stm32cube_xm.c:33
acc_hal_integration_wait_for_sensor_interrupt
bool acc_hal_integration_wait_for_sensor_interrupt(acc_sensor_id_t sensor_id, uint32_t timeout_ms)
Wait for a sensor interrupt.
Definition: acc_hal_integration_stm32cube_xm.c:130
acc_hal_integration_sensor_supply_off
void acc_hal_integration_sensor_supply_off(acc_sensor_id_t sensor_id)
Power off sensor supply.
Definition: acc_hal_integration_stm32cube_xm.c:104
buffer
void * buffer
Definition: i2c_example_cargo.c:40
acc_integration_log
void acc_integration_log(acc_log_level_t level, const char *module, const char *format,...)
Log function.
Definition: acc_exploration_server_stm32.c:207
acc_integration.h
ENABLE_GPIO_Port
#define ENABLE_GPIO_Port
Definition: main.h:85
disable_interrupts
static void disable_interrupts(void)
Definition: acc_hal_integration_stm32cube_xm.c:36
SENSOR_COUNT
#define SENSOR_COUNT
The number of sensors available on the board.
Definition: acc_hal_integration_stm32cube_xm.c:27
acc_hal_a121_t
Definition: acc_hal_definitions_a121.h:82
acc_integration_sleep_ms
void acc_integration_sleep_ms(uint32_t time_msec)
Sleep for a specified number of milliseconds.
Definition: acc_integration_stm32.c:468
A121_SPI_HANDLE
SPI_HandleTypeDef A121_SPI_HANDLE
acc_hal_integration_a121.h
acc_hal_integration_sensor_transfer16
static void acc_hal_integration_sensor_transfer16(acc_sensor_id_t sensor_id, uint16_t *buffer, size_t buffer_length)
Definition: acc_hal_integration_stm32cube_xm.c:62
acc_hal_integration_sensor_disable
void acc_hal_integration_sensor_disable(acc_sensor_id_t sensor_id)
Disable sensor.
Definition: acc_hal_integration_stm32cube_xm.c:119
acc_hal_definitions_a121.h
acc_hal_integration_sensor_count
uint16_t acc_hal_integration_sensor_count(void)
Get the max number of sensors the integration supports.
Definition: acc_hal_integration_stm32cube_xm.c:169
acc_hal_rss_integration_get_implementation
const acc_hal_a121_t * acc_hal_rss_integration_get_implementation(void)
Get hal implementation reference.
Definition: acc_hal_integration_stm32cube_xm.c:152
ENABLE_Pin
#define ENABLE_Pin
Definition: main.h:84
acc_hal_integration_sensor_enable
void acc_hal_integration_sensor_enable(acc_sensor_id_t sensor_id)
Enable sensor.
Definition: acc_hal_integration_stm32cube_xm.c:109
acc_sensor_id_t
uint32_t acc_sensor_id_t
Type representing a sensor ID.
Definition: acc_definitions_common.h:13
acc_integration_log.h
acc_hal_a121_t::max_spi_transfer_size
uint16_t max_spi_transfer_size
Definition: acc_hal_definitions_a121.h:84
main.h
: Header for main.c file. This file contains the common defines of the application.
INTERRUPT_GPIO_Port
#define INTERRUPT_GPIO_Port
Definition: main.h:63
acc_definitions_common.h
enable_interrupts
static void enable_interrupts(void)
Definition: acc_hal_integration_stm32cube_xm.c:41
INTERRUPT_Pin
#define INTERRUPT_Pin
Definition: main.h:62