aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/include
diff options
context:
space:
mode:
authorbarthess <barthess@yandex.ru>2015-03-01 21:09:12 +0300
committerbarthess <barthess@yandex.ru>2015-03-01 21:09:12 +0300
commit4764c3ba15e737bdb781e445184c00e2a6f0bb00 (patch)
tree8a5fc85618a734679e183478d4afffbb2ef4063f /os/hal/include
parent8bb246b572b18cd5e5fcbf503bc15f8036df2f03 (diff)
downloadChibiOS-Contrib-4764c3ba15e737bdb781e445184c00e2a6f0bb00.tar.gz
ChibiOS-Contrib-4764c3ba15e737bdb781e445184c00e2a6f0bb00.tar.bz2
ChibiOS-Contrib-4764c3ba15e737bdb781e445184c00e2a6f0bb00.zip
EICU. Fixed handlign of 32-bit timers. General code cleanup. PWM mode still untested.
Diffstat (limited to 'os/hal/include')
-rw-r--r--os/hal/include/eicu.h76
1 files changed, 41 insertions, 35 deletions
diff --git a/os/hal/include/eicu.h b/os/hal/include/eicu.h
index 4fbc644..5eefa7c 100644
--- a/os/hal/include/eicu.h
+++ b/os/hal/include/eicu.h
@@ -43,12 +43,12 @@
* @brief Driver state machine possible states.
*/
typedef enum {
- EICU_UNINIT = 0, /* Not initialized. */
- EICU_STOP = 1, /* Stopped. */
- EICU_READY = 2, /* Ready. */
- EICU_WAITING = 3, /* Waiting for first edge. */
- EICU_ACTIVE = 4, /* Active cycle phase. */
- EICU_IDLE = 5 /* Idle cycle phase. */
+ EICU_UNINIT = 0, /* Not initialized. */
+ EICU_STOP = 1, /* Stopped. */
+ EICU_READY = 2, /* Ready. */
+ EICU_WAITING = 3, /* Waiting for first edge. */
+ EICU_ACTIVE = 4, /* Active cycle phase. */
+ EICU_IDLE = 5 /* Idle cycle phase. */
} eicustate_t;
/**
@@ -103,10 +103,10 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
#define eicuDisableI(eicup) eicu_lld_disable(eicup)
/**
- * @brief Returns the width of the latest pulse.
- * @details The pulse width is defined as number of ticks between the start
- * edge and the stop edge.
- * @note This function is meant to be invoked from the width capture
+ * @brief Returns the time of the latest measurement.
+ * @details The pulse width is defined as number of ticks between the 2
+ * capture events depending on EICU mode (pulse width or period).
+ * @note This function is meant to be invoked from the capture
* callback only.
*
* @param[in] eicup Pointer to the @p EICUDriver object
@@ -115,13 +115,13 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
*
* @special
*/
-#define eicuGetWidth(eicup, channel) eicu_lld_get_width((eicup), (channel))
+#define eicuGetTime(eicup, channel) eicu_lld_get_time((eicup), (channel))
/**
* @brief Returns the width of the latest cycle.
* @details The cycle width is defined as number of ticks between a start
* edge and the next start edge.
- * @note This function is meant to be invoked from the width capture
+ * @note This function is meant to be invoked from the capture
* callback only.
*
* @param[in] eicup Pointer to the @p EICUDriver object
@@ -144,11 +144,12 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
*
* @notapi
*/
-#define _eicu_isr_invoke_pwm_width_cb(eicup, channel) { \
- if ((eicup)->state != EICU_WAITING) { \
- (eicup)->state = EICU_IDLE; \
- (eicup)->config->iccfgp[channel]->width_cb((eicup), (channel)); \
- } \
+static inline void _eicu_isr_invoke_pwm_width_cb(EICUDriver *eicup,
+ eicuchannel_t channel) {
+ if (eicup->state != EICU_WAITING) {
+ eicup->state = EICU_IDLE;
+ eicup->config->iccfgp[channel]->capture_cb(eicup, channel);
+ }
}
/**
@@ -159,11 +160,12 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
*
* @notapi
*/
-#define _eicu_isr_invoke_pwm_period_cb(eicup, channel) { \
- eicustate_t previous_state = (eicup)->state; \
- (eicup)->state = EICU_ACTIVE; \
- if (previous_state != EICU_WAITING) \
- (eicup)->config->period_cb((eicup), (channel)); \
+static inline void _eicu_isr_invoke_pwm_period_cb(EICUDriver *eicup,
+ eicuchannel_t channel) {
+ eicustate_t previous_state = eicup->state;
+ eicup->state = EICU_ACTIVE;
+ if (previous_state != EICU_WAITING)
+ eicup->config->period_cb(eicup, channel);
}
/**
@@ -178,16 +180,18 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
*
* @notapi
*/
-#define _eicu_isr_invoke_pulse_width_cb(eicup, channel) { \
- if ((eicup)->state == EICU_ACTIVE) { \
- (eicup)->state = EICU_READY; \
- eicu_lld_invert_polarity((eicup), (channel)); \
- (eicup)->config->iccfgp[(channel)]->width_cb((eicup), (channel)); \
- } else { \
- (eicup)->state = EICU_ACTIVE; \
- (eicup)->last_count[(channel)] = eicu_lld_get_compare((eicup), (channel)); \
- eicu_lld_invert_polarity((eicup), (channel)); \
- } \
+static inline void _eicu_isr_invoke_pulse_width_cb(EICUDriver *eicup,
+ eicuchannel_t channel) {
+ if (eicup->state == EICU_ACTIVE) {
+ eicup->state = EICU_READY;
+ eicu_lld_invert_polarity(eicup, channel);
+ eicup->config->iccfgp[channel]->capture_cb(eicup, channel);
+ }
+ else {
+ eicup->state = EICU_ACTIVE;
+ eicup->last_count[channel] = eicu_lld_get_compare(eicup, channel);
+ eicu_lld_invert_polarity(eicup, channel);
+ }
}
/**
@@ -198,9 +202,11 @@ typedef void (*eicucallback_t)(EICUDriver *eicup, eicuchannel_t channel);
*
* @notapi
*/
-#define _eicu_isr_invoke_edge_detect_cb(eicup, channel) { \
- (eicup)->state = EICU_READY; \
- (eicup)->config->iccfgp[(channel)]->width_cb((eicup), (channel)); \
+static inline void _eicu_isr_invoke_edge_detect_cb(EICUDriver *eicup,
+ eicuchannel_t channel) {
+ eicup->state = EICU_READY;
+ eicup->config->iccfgp[channel]->capture_cb(eicup, channel);
+ eicup->last_count[channel] = eicu_lld_get_compare(eicup, channel);
}
/**