add shell save parameter txpower, channel, panid
This commit is contained in:
parent
f368875ea2
commit
a2f8424b74
5 changed files with 115 additions and 199 deletions
|
@ -27,205 +27,22 @@ uint8_t led_pin=4;
|
|||
uint8_t led_status;
|
||||
}
|
||||
|
||||
settings_status_t status;
|
||||
uint16_t panid;
|
||||
char hostname[30];
|
||||
uint16_t channel;
|
||||
|
||||
struct rf_consts {
|
||||
radio_value_t channel_min;
|
||||
radio_value_t channel_max;
|
||||
radio_value_t txpower_min;
|
||||
radio_value_t txpower_max;
|
||||
};
|
||||
|
||||
//static struct rf_consts consts;
|
||||
|
||||
static radio_value_t value;
|
||||
static uint8_t ext_addr[8];
|
||||
|
||||
|
||||
/*---------------------------------------------------------------------------*/
|
||||
static void
|
||||
print_rf_values(void)
|
||||
{
|
||||
printf("====================================\n");
|
||||
printf("RF Values\n");
|
||||
|
||||
printf("Power: ");
|
||||
if(get_param(RADIO_PARAM_POWER_MODE, &value) == RADIO_RESULT_OK) {
|
||||
if(value == RADIO_POWER_MODE_ON) {
|
||||
printf("On\n");
|
||||
} else if(value == RADIO_POWER_MODE_OFF) {
|
||||
printf("Off\n");
|
||||
}
|
||||
}
|
||||
|
||||
printf("Channel: ");
|
||||
if(get_param(RADIO_PARAM_CHANNEL, &value) == RADIO_RESULT_OK) {
|
||||
printf("%d\n", value);
|
||||
}
|
||||
|
||||
printf("PAN ID: ");
|
||||
if(get_param(RADIO_PARAM_PAN_ID, &value) == RADIO_RESULT_OK) {
|
||||
printf("0x%02x%02x\n", (value >> 8) & 0xFF, value & 0xFF);
|
||||
}
|
||||
|
||||
printf("16-bit Address: ");
|
||||
if(get_param(RADIO_PARAM_16BIT_ADDR, &value) == RADIO_RESULT_OK) {
|
||||
printf("0x%02x%02x\n", (value >> 8) & 0xFF, value & 0xFF);
|
||||
}
|
||||
|
||||
printf("64-bit Address: ");
|
||||
if(get_object(RADIO_PARAM_64BIT_ADDR, ext_addr, 8) == RADIO_RESULT_OK) {
|
||||
print_64bit_addr(ext_addr);
|
||||
}
|
||||
|
||||
printf("RX Mode: ");
|
||||
if(get_param(RADIO_PARAM_RX_MODE, &value) == RADIO_RESULT_OK) {
|
||||
printf("Address Filtering is ");
|
||||
if(value & RADIO_RX_MODE_ADDRESS_FILTER) {
|
||||
printf("On, ");
|
||||
} else {
|
||||
printf("Off, ");
|
||||
}
|
||||
printf("Auto ACK is ");
|
||||
if(value & RADIO_RX_MODE_AUTOACK) {
|
||||
printf("On, ");
|
||||
} else {
|
||||
printf("Off, ");
|
||||
}
|
||||
|
||||
printf("(value=%d)\n", value);
|
||||
}
|
||||
|
||||
printf("TX Mode: ");
|
||||
if(get_param(RADIO_PARAM_TX_MODE, &value) == RADIO_RESULT_OK) {
|
||||
printf("%d\n", value);
|
||||
}
|
||||
|
||||
printf("TX Power: ");
|
||||
if(get_param(RADIO_PARAM_TXPOWER, &value) == RADIO_RESULT_OK) {
|
||||
printf("%d dBm [0x%04x]\n", value, (uint16_t)value);
|
||||
}
|
||||
|
||||
printf("CCA Threshold: ");
|
||||
if(get_param(RADIO_PARAM_CCA_THRESHOLD, &value) == RADIO_RESULT_OK) {
|
||||
printf("%d dBm [0x%04x]\n", value, (uint16_t)value);
|
||||
}
|
||||
|
||||
printf("RSSI: ");
|
||||
if(get_param(RADIO_PARAM_RSSI, &value) == RADIO_RESULT_OK) {
|
||||
printf("%d dBm [0x%04x]\n", value, (uint16_t)value);
|
||||
}
|
||||
}
|
||||
|
||||
void setup (void)
|
||||
{
|
||||
settings_iter_t iter;
|
||||
int i;
|
||||
// switch off the led
|
||||
pinMode(led_pin, OUTPUT);
|
||||
digitalWrite(led_pin, HIGH);
|
||||
led_status=0;
|
||||
// settings manager
|
||||
/* Basic setting of parameters */
|
||||
|
||||
// status = settings_set_uint16(SETTINGS_KEY_PAN_ID, 0xABCD);
|
||||
// if(SETTINGS_STATUS_OK != status) {
|
||||
// printf("settings-example: `set` failed: %d\n", status);
|
||||
// }
|
||||
// status = settings_set_uint8(SETTINGS_KEY_CHANNEL, 11);
|
||||
// if(SETTINGS_STATUS_OK != status) {
|
||||
// printf("settings-example: `set` failed: %d\n", status);
|
||||
// }
|
||||
// status = settings_set_cstr(SETTINGS_KEY_HOSTNAME, "contiki.local");
|
||||
// if(SETTINGS_STATUS_OK != status) {
|
||||
// printf("settings-example: `set` failed: %d\n", status);
|
||||
// }
|
||||
/* Basic getting of parameters */
|
||||
// panid = settings_get_uint16(SETTINGS_KEY_PAN_ID, 0);
|
||||
// if(0xABCD != panid) {
|
||||
// printf("settings-example: `get` failed: value mismatch.\n");
|
||||
// }
|
||||
// channel = settings_get_uint16(SETTINGS_KEY_CHANNEL, 0);
|
||||
// if(26 != channel) {
|
||||
// printf("settings-example: `get` failed: value mismatch.\n");
|
||||
// }
|
||||
|
||||
// if(!settings_get_cstr(SETTINGS_KEY_HOSTNAME, 0, hostname, sizeof(hostname))) {
|
||||
// printf("settings-example: `get` failed: settings_get_cstr returned NULL\n");
|
||||
// } else if(strcmp(hostname, "contiki.local") != 0) {
|
||||
// printf("settings-example: `get` failed: value mismatch.\n");
|
||||
// }
|
||||
/*************************************************************************/
|
||||
/* Adding multiple values with the same key */
|
||||
|
||||
// for(i = 0; i < 10; i++) {
|
||||
// settings_add_uint8(TCC('e','x'), i + 20);
|
||||
// }
|
||||
|
||||
/*************************************************************************/
|
||||
/* Reading multiple values with the same key */
|
||||
|
||||
// for(i = 0; i < 10; i++) {
|
||||
// if(settings_get_uint8(TCC('e', 'x'), i) != i + 20) {
|
||||
// printf("settings-example: `get` failed: value mismatch.\n");
|
||||
// }
|
||||
// }
|
||||
|
||||
/*************************************************************************/
|
||||
/* Iterating thru all settings */
|
||||
/*
|
||||
for(iter = settings_iter_begin(); iter; iter = settings_iter_next(iter)) {
|
||||
settings_length_t len = settings_iter_get_value_length(iter);
|
||||
eeprom_addr_t addr = settings_iter_get_value_addr(iter);
|
||||
uint8_t byte;
|
||||
|
||||
union {
|
||||
settings_key_t key;
|
||||
char bytes[0];
|
||||
} u;
|
||||
|
||||
u.key = settings_iter_get_key(iter);
|
||||
|
||||
if(u.bytes[0] >= 32 && u.bytes[0] < 127
|
||||
&& u.bytes[1] >= 32 && u.bytes[1] < 127
|
||||
) {
|
||||
printf("settings-example: [%c%c] = <",u.bytes[0],u.bytes[1]);
|
||||
} else {
|
||||
printf("settings-example: <0x%04X> = <",u.key);
|
||||
}
|
||||
|
||||
for(; len; len--, addr++) {
|
||||
eeprom_read(addr, &byte, 1);
|
||||
printf("%02X", byte);
|
||||
if(len != 1) {
|
||||
printf(" ");
|
||||
}
|
||||
}
|
||||
|
||||
printf(">\n");
|
||||
}
|
||||
*/
|
||||
|
||||
printf("settings-example: Done.\n");
|
||||
// Seriell Shell
|
||||
serial_shell_init();
|
||||
// shell_blink_init();
|
||||
shell_ps_init();
|
||||
shell_reboot_init();
|
||||
// shell_text_init();
|
||||
// shell_time_init();
|
||||
shell_merkur_init();
|
||||
|
||||
shell_merkur_init();
|
||||
#if COFFEE
|
||||
shell_coffee_init();
|
||||
shell_file_init();
|
||||
shell_coffee_init();
|
||||
shell_file_init();
|
||||
#endif
|
||||
|
||||
// get_rf_consts();
|
||||
print_rf_values();
|
||||
// init coap resourcen
|
||||
rest_init_engine ();
|
||||
#pragma GCC diagnostic ignored "-Wwrite-strings"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue