1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2024-12-11 19:24:10 +01:00

PiOS RCVR: Make the public API use a 1 based indexing for channel numbers.

This may or may not get into next, but if so anyone following it MUST
reconfigure their inputs.
This commit is contained in:
James Cotton 2011-09-06 16:35:28 -05:00
parent 8f7712435f
commit 72625d9971
2 changed files with 13 additions and 6 deletions

View File

@ -398,8 +398,9 @@ static void resetRcvrActivity(struct rcvr_activity_fsm * fsm)
} }
static void updateRcvrActivitySample(uint32_t rcvr_id, uint16_t samples[], uint8_t max_channels) { static void updateRcvrActivitySample(uint32_t rcvr_id, uint16_t samples[], uint8_t max_channels) {
for (uint8_t channel = 0; channel < max_channels; channel++) { for (uint8_t channel = 1; channel <= max_channels; channel++) {
samples[channel] = PIOS_RCVR_Read(rcvr_id, channel); // Subtract 1 because channels are 1 indexed
samples[channel - 1] = PIOS_RCVR_Read(rcvr_id, channel);
} }
} }
@ -408,11 +409,11 @@ static bool updateRcvrActivityCompare(uint32_t rcvr_id, struct rcvr_activity_fsm
bool activity_updated = false; bool activity_updated = false;
/* Compare the current value to the previous sampled value */ /* Compare the current value to the previous sampled value */
for (uint8_t channel = 0; for (uint8_t channel = 1;
channel < RCVR_ACTIVITY_MONITOR_CHANNELS_PER_GROUP; channel <= RCVR_ACTIVITY_MONITOR_CHANNELS_PER_GROUP;
channel++) { channel++) {
uint16_t delta; uint16_t delta;
uint16_t prev = fsm->prev[channel]; uint16_t prev = fsm->prev[channel - 1]; // Subtract 1 because channels are 1 indexed
uint16_t curr = PIOS_RCVR_Read(rcvr_id, channel); uint16_t curr = PIOS_RCVR_Read(rcvr_id, channel);
if (curr > prev) { if (curr > prev) {
delta = curr - prev; delta = curr - prev;

View File

@ -87,6 +87,12 @@ out_fail:
*/ */
int32_t PIOS_RCVR_Read(uint32_t rcvr_id, uint8_t channel) int32_t PIOS_RCVR_Read(uint32_t rcvr_id, uint8_t channel)
{ {
// Publicly facing API uses channel 1 for first channel
if(channel == 0)
return PIOS_RCVR_INVALID;
else
channel--;
if (rcvr_id == 0) if (rcvr_id == 0)
return PIOS_RCVR_NODRIVER; return PIOS_RCVR_NODRIVER;