Statistics
| Branch: | Tag: | Revision:

amiro-os / modules / PowerManagement_1-2 / module.c @ 9d8f1b9e

History | View | Annotate | Download (35.103 KB)

1 b010278f Thomas Schöpping
/*
2
AMiRo-OS is an operating system designed for the Autonomous Mini Robot (AMiRo) platform.
3
Copyright (C) 2016..2019  Thomas Schöpping et al.
4

5
This program is free software: you can redistribute it and/or modify
6
it under the terms of the GNU General Public License as published by
7
the Free Software Foundation, either version 3 of the License, or
8
(at your option) any later version.
9

10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
GNU General Public License for more details.
14

15
You should have received a copy of the GNU General Public License
16
along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
*/
18
19
/**
20
 * @file
21
 * @brief   Structures and constant for the PowerManagement module.
22
 *
23
 * @addtogroup powermanagement_module
24
 * @{
25
 */
26
27 c53ef0b1 Thomas Schöpping
#include <amiroos.h>
28
29
#include <string.h>
30 b010278f Thomas Schöpping
31
/*===========================================================================*/
32
/**
33
 * @name Module specific functions
34
 * @{
35
 */
36
/*===========================================================================*/
37
38
/** @} */
39
40
/*===========================================================================*/
41
/**
42
 * @name ChibiOS/HAL configuration
43
 * @{
44
 */
45
/*===========================================================================*/
46
47
ADCConversionGroup moduleHalAdcVsysConversionGroup = {
48
  /* buffer type        */ true,
49
  /* number of channels */ 1,
50
  /* callback function  */ NULL,
51
  /* error callback     */ NULL,
52
  /* CR1                */ ADC_CR1_AWDEN | ADC_CR1_AWDIE,
53
  /* CR2                */ ADC_CR2_SWSTART | ADC_CR2_CONT,
54
  /* SMPR1              */ 0,
55
  /* SMPR2              */ ADC_SMPR2_SMP_AN9(ADC_SAMPLE_480),
56
  /* HTR                */ ADC_HTR_HT,
57
  /* LTR                */ 0,
58
  /* SQR1               */ ADC_SQR1_NUM_CH(1),
59
  /* SQR2               */ 0,
60
  /* SQR3               */ ADC_SQR3_SQ1_N(ADC_CHANNEL_IN9),
61
};
62
63
CANConfig moduleHalCanConfig = {
64
  /* mcr  */ CAN_MCR_ABOM | CAN_MCR_AWUM | CAN_MCR_TXFP,
65
  /* btr  */ CAN_BTR_SJW(1) | CAN_BTR_TS2(3) | CAN_BTR_TS1(15) | CAN_BTR_BRP(1),
66
};
67
68
I2CConfig moduleHalI2cSrPm18Pm33GaugeRearConfig = {
69
  /* I²C mode   */ OPMODE_I2C,
70
  /* frequency  */ 400000, // TODO: replace with some macro (-> ChibiOS/HAL)
71
  /* duty cycle */ FAST_DUTY_CYCLE_2,
72
};
73
74
I2CConfig moduleHalI2cSrPm42Pm50PmVddEepromGaugeFrontConfig = {
75
  /* I²C mode   */ OPMODE_I2C,
76
  /* frequency  */ 400000, // TODO: replace with some macro (-> ChibiOS/HAL)
77
  /* duty cycle */ FAST_DUTY_CYCLE_2,
78
};
79
80
PWMConfig moduleHalPwmBuzzerConfig = {
81
  /* frequency              */ 1000000,
82
  /* period                 */ 0,
83
  /* callback               */ NULL,
84
  /* channel configurations */ {
85
    /* channel 0              */ {
86
      /* mode                   */ PWM_OUTPUT_DISABLED,
87
      /* callback               */ NULL
88
    },
89
    /* channel 1              */ {
90
      /* mode                   */ PWM_OUTPUT_ACTIVE_HIGH,
91
      /* callback               */ NULL
92
    },
93
    /* channel 2              */ {
94
      /* mode                   */ PWM_OUTPUT_DISABLED,
95
      /* callback               */ NULL
96
    },
97
    /* channel 3              */ {
98
      /* mode                   */ PWM_OUTPUT_DISABLED,
99
      /* callback               */ NULL
100
    },
101
  },
102
  /* TIM CR2 register       */ 0,
103
#if (STM32_PWM_USE_ADVANCED == TRUE)
104
  /* TIM BDTR register      */ 0,
105
#endif /* (STM32_PWM_USE_ADVANCED == TRUE) */
106
  /* TIM DIER register      */ 0,
107
};
108
109
SerialConfig moduleHalProgIfConfig = {
110
  /* bit rate */ 115200,
111
  /* CR1      */ 0,
112
  /* CR1      */ 0,
113
  /* CR1      */ 0,
114
};
115
116
/** @} */
117
118
/*===========================================================================*/
119
/**
120
 * @name GPIO definitions
121
 * @{
122
 */
123
/*===========================================================================*/
124
125
/**
126
 * @brief   SWITCH_STATUS input signal GPIO.
127
 */
128
static apalGpio_t _gpioSwitchStatus = {
129 3106e8cc Thomas Schöpping
  /* line */ LINE_SWITCH_STATUS_N,
130 b010278f Thomas Schöpping
};
131
ROMCONST apalControlGpio_t moduleGpioSwitchStatus = {
132
  /* GPIO */ &_gpioSwitchStatus,
133
  /* meta */ {
134
    /* direction      */ APAL_GPIO_DIRECTION_INPUT,
135
    /* active state   */ APAL_GPIO_ACTIVE_LOW,
136
    /* interrupt edge */ APAL_GPIO_EDGE_NONE,
137
  },
138
};
139
140
/**
141
 * @brief   SYS_REG_EN output signal GPIO.
142
 */
143
static apalGpio_t _gpioSysRegEn = {
144 3106e8cc Thomas Schöpping
  /* line */ LINE_SYS_REG_EN,
145 b010278f Thomas Schöpping
};
146
ROMCONST apalControlGpio_t moduleGpioSysRegEn = {
147
  /* GPIO */ &_gpioSysRegEn,
148
  /* meta */ {
149
    /* direction      */ APAL_GPIO_DIRECTION_OUTPUT,
150
    /* active state   */ APAL_GPIO_ACTIVE_HIGH,
151
    /* interrupt edge */ APAL_GPIO_EDGE_NONE,
152
  },
153
};
154
155
/**
156
 * @brief   IR_INT1 input signal GPIO.
157
 */
158
static apalGpio_t _gpioIrInt1 = {
159 3106e8cc Thomas Schöpping
  /* line */ LINE_IR_INT1_N,
160 b010278f Thomas Schöpping
};
161
ROMCONST apalControlGpio_t moduleGpioIrInt1 = {
162
  /* GPIO */ &_gpioIrInt1,
163
  /* meta */ {
164
    /* direction      */ APAL_GPIO_DIRECTION_INPUT,
165
#if (BOARD_SENSORRING == BOARD_PROXIMITYSENSOR)
166
    /* active state   */ (VCNL4020_LLD_INT_EDGE == APAL_GPIO_EDGE_RISING) ? APAL_GPIO_ACTIVE_HIGH : APAL_GPIO_ACTIVE_LOW,
167
    /* interrupt edge */ VCNL4020_LLD_INT_EDGE,
168
#elif (BOARD_SENSORRING == BOARD_DISTANCESENSOR_VL53L0X)
169
    /* active state   */ (PCAL6524_LLD_INT_EDGE == APAL_GPIO_EDGE_RISING) ? APAL_GPIO_ACTIVE_HIGH : APAL_GPIO_ACTIVE_LOW,
170
    /* interrupt edge */ PCAL6524_LLD_INT_EDGE,
171
#elif (BOARD_SENSORRING == BOARD_DISTANCESENSOR_VL53L1X)
172
    /* active state   */ (PCAL6524_LLD_INT_EDGE == APAL_GPIO_EDGE_RISING) ? APAL_GPIO_ACTIVE_HIGH : APAL_GPIO_ACTIVE_LOW,
173
    /* interrupt edge */ PCAL6524_LLD_INT_EDGE,
174
#else /* (BOARD_SENSORRING == ?) */
175
    /* active state   */ APAL_GPIO_ACTIVE_LOW,
176
    /* interrupt edge */ APAL_GPIO_EDGE_NONE,
177
#endif /* (BOARD_SENSORRING == ?) */
178
  },
179
};
180
181
/**
182
 * @brief   POWER_EN output signal GPIO.
183
 */
184
static apalGpio_t _gpioPowerEn = {
185 3106e8cc Thomas Schöpping
  /* line */ LINE_POWER_EN,
186 b010278f Thomas Schöpping
};
187
ROMCONST apalControlGpio_t moduleGpioPowerEn = {
188
  /* GPIO */ &_gpioPowerEn,
189
  /* meta */ {
190
    /* direction      */ APAL_GPIO_DIRECTION_OUTPUT,
191
    /* active state   */ APAL_GPIO_ACTIVE_HIGH,
192
    /* interrupt edge */ APAL_GPIO_EDGE_NONE,
193
  },
194
};
195
196
/**
197
 * @brief   SYS_UART_DN bidirectional signal GPIO.
198
 */
199
static apalGpio_t _gpioSysUartDn = {
200 3106e8cc Thomas Schöpping
  /* line */ LINE_SYS_UART_DN,
201 b010278f Thomas Schöpping
};
202
ROMCONST apalControlGpio_t moduleGpioSysUartDn = {
203
  /* GPIO */ &_gpioSysUartDn,
204
  /* meta */ {
205
    /* direction      */ APAL_GPIO_DIRECTION_BIDIRECTIONAL,
206
    /* active state   */ APAL_GPIO_ACTIVE_LOW,
207
    /* interrupt edge */ APAL_GPIO_EDGE_BOTH,
208
  },
209
};
210
211
/**
212
 * @brief   CHARGE_STAT2A input signal GPIO.
213
 */
214
static apalGpio_t _gpioChargeStat2A = {
215 3106e8cc Thomas Schöpping
  /* line */ LINE_CHARGE_STAT2A,
216 b010278f Thomas Schöpping
};
217
ROMCONST apalControlGpio_t moduleGpioChargeStat2A = {
218
  /* GPIO */ &_gpioChargeStat2A,
219
  /* meta */ {
220
    /* direction      */ APAL_GPIO_DIRECTION_INPUT,
221
    /* active state   */ BQ241xx_LLD_CHARGE_STATUS_GPIO_ACTIVE_STATE,
222
    /* interrupt edge */ APAL_GPIO_EDGE_NONE,
223
  },
224
};
225
226
/**
227
 * @brief   GAUGE_BATLOW2 input signal GPIO.
228
 */
229
static apalGpio_t _gpioGaugeBatLow2 = {
230 3106e8cc Thomas Schöpping
  /* line */ LINE_GAUGE_BATLOW2,
231 b010278f Thomas Schöpping
};
232
ROMCONST apalControlGpio_t moduleGpioGaugeBatLow2 = {
233
  /* GPIO */ &_gpioGaugeBatLow2,
234
  /* meta */ {
235
    /* direction      */ APAL_GPIO_DIRECTION_INPUT,
236
    /* active state   */ BQ27500_LLD_BATLOW_ACTIVE_STATE,
237
    /* interrupt edge */ APAL_GPIO_EDGE_BOTH,
238
  },
239
};
240
241
/**
242
 * @brief   GAUGE_BATGD2 input signal GPIO.
243
 */
244
static apalGpio_t _gpioGaugeBatGd2 = {
245