[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[paparazzi-commits] [5489] refactored spektrum parser
From: |
Eric |
Subject: |
[paparazzi-commits] [5489] refactored spektrum parser |
Date: |
Thu, 19 Aug 2010 15:38:56 +0000 |
Revision: 5489
http://svn.sv.gnu.org/viewvc/?view=rev&root=paparazzi&revision=5489
Author: lamestllama
Date: 2010-08-19 15:38:56 +0000 (Thu, 19 Aug 2010)
Log Message:
-----------
refactored spektrum parser
Modified Paths:
--------------
paparazzi3/trunk/sw/airborne/booz/radio_control/booz_radio_control_spektrum.h
Modified:
paparazzi3/trunk/sw/airborne/booz/radio_control/booz_radio_control_spektrum.h
===================================================================
---
paparazzi3/trunk/sw/airborne/booz/radio_control/booz_radio_control_spektrum.h
2010-08-19 15:38:11 UTC (rev 5488)
+++
paparazzi3/trunk/sw/airborne/booz/radio_control/booz_radio_control_spektrum.h
2010-08-19 15:38:56 UTC (rev 5489)
@@ -25,79 +25,14 @@
#ifndef BOOZ_RADIO_CONTROL_SPEKTRUM_H
#define BOOZ_RADIO_CONTROL_SPEKTRUM_H
-#include "std.h"
-#include "uart.h"
-
/* implemented in
booz/arch/xxx/radio_control/booz_radio_control_spektrum_arch.c */
extern void radio_control_spektrum_try_bind(void);
#include RADIO_CONTROL_SPEKTRUM_MODEL_H
-#define RC_SPK_SYNC_1 0x03
+/* implemented in
booz/arch/xxx/radio_control/booz_radio_control_spektrum_arch.c */
+extern void RadioControlEventImp(void);
-#define RC_SPK_STA_UNINIT 0
-#define RC_SPK_STA_GOT_SYNC_1 1
-#define RC_SPK_STA_GOT_SYNC_2 2
+#define RadioControlEvent(_received_frame_handler) RadioControlEventImp()
-extern bool_t rc_spk_parser_status;
-extern uint8_t rc_spk_parser_idx;
-extern uint8_t rc_spk_parser_buf[RADIO_CONTROL_NB_CHANNEL*2];
-
-#define MAX_SPK 344
-extern const int16_t rc_spk_throw[RADIO_CONTROL_NB_CHANNEL];
-
-#define __RcLink(dev, _x) dev##_x
-#define _RcLink(dev, _x) __RcLink(dev, _x)
-#define RcLink(_x) _RcLink(RADIO_CONTROL_LINK, _x)
-
-#define RcLinkChAvailable() RcLink(ChAvailable())
-#define RcLinkGetCh() RcLink(Getch())
-
-#define RadioControlEvent(_received_frame_handler) { \
- while (RcLinkChAvailable()) { \
- int8_t c = RcLinkGetCh(); \
- switch (rc_spk_parser_status) { \
- case RC_SPK_STA_UNINIT: \
- if (c==RC_SPK_SYNC_1) \
- rc_spk_parser_status = RC_SPK_STA_GOT_SYNC_1; \
- break; \
- case RC_SPK_STA_GOT_SYNC_1: \
- if (c==RC_SPK_SYNC_2) { \
- rc_spk_parser_status = RC_SPK_STA_GOT_SYNC_2; \
- rc_spk_parser_idx = 0; \
- } \
- else \
- rc_spk_parser_status = RC_SPK_STA_UNINIT; \
- break; \
- case RC_SPK_STA_GOT_SYNC_2: \
- rc_spk_parser_buf[rc_spk_parser_idx] = c; \
- rc_spk_parser_idx++; \
- if (rc_spk_parser_idx >= 2*RADIO_CONTROL_NB_CHANNEL) { \
- rc_spk_parser_status = RC_SPK_STA_UNINIT; \
- radio_control.frame_cpt++; \
- radio_control.time_since_last_frame = 0; \
- radio_control.status = RADIO_CONTROL_OK; \
- uint8_t i; \
- for (i=0;i<RADIO_CONTROL_NB_CHANNEL;i++) { \
- const int16_t tmp = (rc_spk_parser_buf[2*i]<<8) + \
- rc_spk_parser_buf[2*i+1]; \
- /*const int16_t chan = (tmp&0xFC00) >> 10;*/ \
- const int16_t val = (tmp&0x03FF) - 512; \
- radio_control.values[i] = val; \
- radio_control.values[i] *= rc_spk_throw[i]; \
- if (i==RADIO_CONTROL_THROTTLE) { \
- radio_control.values[i] += MAX_PPRZ; \
- radio_control.values[i] /= 2; \
- } \
- } \
- _received_frame_handler(); \
- } \
- break; \
- default: \
- rc_spk_parser_status = RC_SPK_STA_UNINIT; \
- } \
- } \
- }
-
-
#endif /* BOOZ_RADIO_CONTROL_SPEKTRUM_H */
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [paparazzi-commits] [5489] refactored spektrum parser,
Eric <=