Implemented radio rx mode parameter for STM32W, changed the byte order

of the 64 bit address to big-endian.
This commit is contained in:
Niclas Finne 2014-04-07 16:12:48 +02:00
parent 8ea9cb7693
commit 207f1987ee
1 changed files with 24 additions and 13 deletions

View File

@ -285,13 +285,13 @@ get_value(radio_param_t param, radio_value_t *value)
case RADIO_PARAM_16BIT_ADDR: case RADIO_PARAM_16BIT_ADDR:
*value = ST_RadioGetNodeId(); *value = ST_RadioGetNodeId();
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_PARAM_ADDRESS_HANDLER: case RADIO_PARAM_RX_MODE:
*value = 0; *value = 0;
if(ST_RadioAddressFilteringEnabled()) { if(ST_RadioAddressFilteringEnabled()) {
*value |= RADIO_ADDRESS_HANDLER_FILTER; *value |= RADIO_RX_MODE_ADDRESS_FILTER;
} }
if(ST_RadioAutoAckEnabled()) { if(ST_RadioAutoAckEnabled()) {
*value |= RADIO_ADDRESS_HANDLER_AUTOACK; *value |= RADIO_RX_MODE_AUTOACK;
} }
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_PARAM_TXPOWER: case RADIO_PARAM_TXPOWER:
@ -305,10 +305,10 @@ get_value(radio_param_t param, radio_value_t *value)
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_CONST_CHANNEL_MIN: case RADIO_CONST_CHANNEL_MIN:
*value = 11; *value = ST_MIN_802_15_4_CHANNEL_NUMBER;
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_CONST_CHANNEL_MAX: case RADIO_CONST_CHANNEL_MAX:
*value = 26; *value = ST_MAX_802_15_4_CHANNEL_NUMBER;
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_CONST_TXPOWER_MIN: case RADIO_CONST_TXPOWER_MIN:
@ -338,7 +338,8 @@ set_value(radio_param_t param, radio_value_t value)
} }
return RADIO_RESULT_INVALID_VALUE; return RADIO_RESULT_INVALID_VALUE;
case RADIO_PARAM_CHANNEL: case RADIO_PARAM_CHANNEL:
if(value < 11 || value > 26) { if(value < ST_MIN_802_15_4_CHANNEL_NUMBER ||
value > ST_MAX_802_15_4_CHANNEL_NUMBER) {
return RADIO_RESULT_INVALID_VALUE; return RADIO_RESULT_INVALID_VALUE;
} }
if(ST_RadioSetChannel(value) != ST_SUCCESS) { if(ST_RadioSetChannel(value) != ST_SUCCESS) {
@ -351,15 +352,20 @@ set_value(radio_param_t param, radio_value_t value)
case RADIO_PARAM_16BIT_ADDR: case RADIO_PARAM_16BIT_ADDR:
ST_RadioSetNodeId(value & 0xffff); ST_RadioSetNodeId(value & 0xffff);
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_PARAM_ADDRESS_HANDLER: case RADIO_PARAM_RX_MODE:
if(value & ~(RADIO_ADDRESS_HANDLER_FILTER | if(value & ~(RADIO_RX_MODE_ADDRESS_FILTER |
RADIO_ADDRESS_HANDLER_AUTOACK)) { RADIO_RX_MODE_AUTOACK)) {
return RADIO_RESULT_INVALID_VALUE; return RADIO_RESULT_INVALID_VALUE;
} }
ST_RadioEnableAddressFiltering((value & RADIO_ADDRESS_HANDLER_FILTER) != 0); ST_RadioEnableAddressFiltering((value & RADIO_RX_MODE_ADDRESS_FILTER) != 0);
ST_RadioEnableAutoAck((value & RADIO_ADDRESS_HANDLER_AUTOACK) != 0); ST_RadioEnableAutoAck((value & RADIO_RX_MODE_AUTOACK) != 0);
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
case RADIO_PARAM_TXPOWER: case RADIO_PARAM_TXPOWER:
if(value < MIN_RADIO_POWER) {
value = MIN_RADIO_POWER;
} else if(value > MAX_RADIO_POWER) {
value = MAX_RADIO_POWER;
}
if(ST_RadioSetPower((int8_t)value) != ST_SUCCESS) { if(ST_RadioSetPower((int8_t)value) != ST_SUCCESS) {
return RADIO_RESULT_INVALID_VALUE; return RADIO_RESULT_INVALID_VALUE;
} }
@ -375,7 +381,9 @@ set_value(radio_param_t param, radio_value_t value)
static radio_result_t static radio_result_t
get_object(radio_param_t param, void *dest, size_t size) get_object(radio_param_t param, void *dest, size_t size)
{ {
uint8_t *eui64; const uint8_t *eui64;
uint8_t *target;
int i;
if(param == RADIO_PARAM_64BIT_ADDR) { if(param == RADIO_PARAM_64BIT_ADDR) {
if(size < 8 || !dest) { if(size < 8 || !dest) {
@ -385,7 +393,10 @@ get_object(radio_param_t param, void *dest, size_t size)
if(!eui64) { if(!eui64) {
return RADIO_RESULT_ERROR; return RADIO_RESULT_ERROR;
} }
memcpy(dest, eui64, 8); target = dest;
for(i = 0; i < 8; i++) {
target[i] = eui64[7 - i];
}
return RADIO_RESULT_OK; return RADIO_RESULT_OK;
} }
return RADIO_RESULT_NOT_SUPPORTED; return RADIO_RESULT_NOT_SUPPORTED;