Rev 2065 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 2065 | Rev 2069 | ||
---|---|---|---|
1 | #include "externalControl.h" |
1 | #include "externalControl.h" |
2 | #include "configuration.h" |
2 | #include "configuration.h" |
3 | #include "controlMixer.h" |
3 | #include "controlMixer.h" |
4 | 4 | ||
5 | ExternalControl_t externalControl; |
5 | ExternalControl_t externalControl; |
6 | uint8_t externalControlActive = 0; |
6 | uint8_t externalControlActive = 0; |
7 | // int16_t EC_PRTY[4]; |
7 | // int16_t EC_PRTY[4]; |
8 | // TODO: Who is going to call this |
8 | // TODO: Who is going to call this |
9 | 9 | ||
10 | void EC_setNeutral(void) { |
10 | void EC_setNeutral(void) { |
11 | // if necessary. From main.c. |
11 | // if necessary. From main.c. |
12 | externalControl.config = 0; |
12 | externalControl.config = 0; |
13 | externalControl.pitch = 0; |
13 | externalControl.pitch = 0; |
14 | externalControl.roll = 0; |
14 | externalControl.roll = 0; |
15 | externalControl.yaw = 0; |
15 | externalControl.yaw = 0; |
16 | externalControl.throttle = 0; |
16 | externalControl.throttle = 0; |
17 | 17 | ||
18 | // From main.c. What does it do?? |
18 | // From main.c. What does it do?? |
19 | externalControl.digital[0] = 0x55; |
19 | externalControl.digital[0] = 0x55; |
20 | } |
20 | } |
21 | 21 | ||
22 | void EC_periodicTaskAndPRTY(int16_t* PRTY) { |
22 | void EC_periodicTaskAndPRTY(int16_t* PRTY) { |
23 | if (externalControlActive) { |
23 | if (externalControlActive) { |
24 | externalControlActive--; |
24 | externalControlActive--; |
25 | PRTY[CONTROL_PITCH] += externalControl.pitch * (int16_t) staticParams.stickP; |
25 | PRTY[CONTROL_PITCH] += externalControl.pitch * (int16_t) staticParams.stickP; |
26 | PRTY[CONTROL_ROLL] += externalControl.roll * (int16_t) staticParams.stickP; |
26 | PRTY[CONTROL_ROLL] += externalControl.roll * (int16_t) staticParams.stickP; |
27 | PRTY[CONTROL_THROTTLE] += externalControl.throttle; |
27 | PRTY[CONTROL_THROTTLE] += externalControl.throttle; |
28 | PRTY[CONTROL_YAW] += externalControl.yaw; // No stickP or similar?????? |
28 | PRTY[CONTROL_YAW] += externalControl.yaw; // No stickP or similar?????? |
29 | } |
29 | } |
30 | } |
30 | } |
31 | 31 | ||
32 | uint8_t EC_getArgument(void) { |
32 | uint8_t EC_getArgument(void) { |
33 | return externalControl.config; |
33 | return externalControl.config; |
34 | } |
34 | } |
35 | 35 | ||
36 | uint8_t EC_getCommand(void) { |
36 | uint8_t EC_getCommand(void) { |
37 | return externalControl.free; |
37 | return externalControl.free; |
38 | } |
38 | } |
39 | 39 | ||
40 | // not implemented. |
40 | // not implemented. |
41 | int16_t EC_getVariable(uint8_t varNum) { |
41 | int16_t EC_getVariable(uint8_t varNum) { |
42 | return 0; |
42 | return 0; |
43 | } |
43 | } |
44 | 44 | ||
45 | uint8_t EC_getSignalQuality(void) { |
45 | uint8_t EC_getSignalQuality(void) { |
46 | if (externalControlActive > 80) |
46 | if (externalControlActive > 40) |
47 | // Configured and heard from recently |
47 | // Configured and heard from recently |
48 | return SIGNAL_GOOD; |
48 | return SIGNAL_GOOD; |
49 | 49 | ||
50 | if (externalControlActive) |
50 | if (externalControlActive) |
51 | // Configured and heard from |
51 | // Configured and heard from |
52 | return SIGNAL_OK; |
52 | return SIGNAL_OK; |
53 | 53 | ||
54 | if (!(externalControl.config & 0x01 && dynamicParams.externalControl > 128)) |
54 | if (!(externalControl.config & 0x01 && dynamicParams.externalControl > 128)) |
55 | // External control is not even configured. |
55 | // External control is not even configured. |
56 | return NO_SIGNAL; |
56 | return NO_SIGNAL; |
57 | 57 | ||
58 | // Configured but expired. |
58 | // Configured but expired. |
59 | return SIGNAL_LOST; |
59 | return SIGNAL_LOST; |
60 | } |
60 | } |
61 | 61 |