From 7984ec38cebf3b326e88be652375d35367f6a63a Mon Sep 17 00:00:00 2001 From: joakime Date: Wed, 16 Mar 2011 13:56:29 +0100 Subject: [PATCH 1/4] fixed so that accelerometer is initialized and the isr vector is included --- platform/z1/Makefile.z1 | 2 +- platform/z1/contiki-z1-main.c | 3 +++ platform/z1/dev/adxl345.c | 3 ++- 3 files changed, 6 insertions(+), 2 deletions(-) diff --git a/platform/z1/Makefile.z1 b/platform/z1/Makefile.z1 index a470e2516..c18c67a3e 100644 --- a/platform/z1/Makefile.z1 +++ b/platform/z1/Makefile.z1 @@ -7,7 +7,7 @@ ARCH=msp430.c leds.c watchdog.c xmem.c \ spix.c cc2420.c cc2420-aes.c cc2420-arch.c cc2420-arch-sfd.c\ node-id.c sensors.c button-sensor.c cfs-coffee.c \ radio-sensor.c uart0x.c uart0-putchar.c uip-ipchksum.c \ - checkpoint-arch.c slip.c slip_uart0.c z1-phidgets.c + checkpoint-arch.c slip.c slip_uart0.c z1-phidgets.c adxl345.c i2cmaster.c CONTIKI_TARGET_DIRS = . dev apps net ifndef CONTIKI_TARGET_MAIN diff --git a/platform/z1/contiki-z1-main.c b/platform/z1/contiki-z1-main.c index 2ddfa4985..3206f6b12 100644 --- a/platform/z1/contiki-z1-main.c +++ b/platform/z1/contiki-z1-main.c @@ -69,6 +69,7 @@ SENSORS(&button_sensor); + #if DCOSYNCH_CONF_ENABLED static struct timer mgt_timer; #endif @@ -258,6 +259,8 @@ main(int argc, char **argv) set_rime_addr(); cc2420_init(); + accm_init(); + { uint8_t longaddr[8]; uint16_t shortaddr; diff --git a/platform/z1/dev/adxl345.c b/platform/z1/dev/adxl345.c index 14f6ec7b7..efa502e89 100644 --- a/platform/z1/dev/adxl345.c +++ b/platform/z1/dev/adxl345.c @@ -43,7 +43,7 @@ #include #include "contiki.h" #include "adxl345.h" -#include "cc2420-arch.c" +#include "cc2420.h" #include "i2cmaster.h" /* Callback pointers when interrupt occurs */ @@ -400,6 +400,7 @@ interrupt(PORT1_VECTOR) port1_isr (void) { } ENERGEST_OFF(ENERGEST_TYPE_IRQ); } + /*---------------------------------------------------------------------------*/ From fe2c972ef345f94d9babe8d06b5b0aa39b1802fe Mon Sep 17 00:00:00 2001 From: Joakim Eriksson Date: Thu, 17 Mar 2011 11:02:42 +0100 Subject: [PATCH 2/4] fixed so that the specified interface mac address is used when adding neighbors --- tools/stm32w/wpcapslip6/wpcapslip6.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/tools/stm32w/wpcapslip6/wpcapslip6.c b/tools/stm32w/wpcapslip6/wpcapslip6.c index 72eb0c5c6..4cb27a610 100644 --- a/tools/stm32w/wpcapslip6/wpcapslip6.c +++ b/tools/stm32w/wpcapslip6/wpcapslip6.c @@ -116,6 +116,8 @@ static bool clean_route = false; static bool clean_neighb = false; static struct uip_eth_addr adapter_eth_addr; static char * if_name; +static char * if_mac; + OSVERSIONINFO osVersionInfo; /* Fictitious Ethernet address of the attached device (used in tun mode). */ @@ -357,7 +359,7 @@ read_more: } addLoWPANRoute(if_name, br_prefix, rem_ipaddr); - addNeighbor(if_name, rem_ipaddr, DEV_MAC_ADDR); + addNeighbor(if_name, rem_ipaddr, if_mac);//DEV_MAC_ADDR); } } @@ -1058,13 +1060,12 @@ main(int argc, char **argv) (int *)&adapter_eth_addr.addr[2],(int *)&adapter_eth_addr.addr[3], (int *)&adapter_eth_addr.addr[4],(int *)&adapter_eth_addr.addr[5]); if_name = wpcap_start(&adapter_eth_addr, verbose); - + if_mac = argv[1]; if(local_ipaddr!=NULL){ addAddress(if_name, local_ipaddr); } - switch(baudrate) { case -2: break; /* Use default. */ From 8078ef7705454527fac329dde96c20341dee6b7e Mon Sep 17 00:00:00 2001 From: nvt Date: Thu, 17 Mar 2011 20:21:56 +0100 Subject: [PATCH 3/4] ROOT_RANK is now a macro function. --- core/net/rpl/rpl-timers.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/net/rpl/rpl-timers.c b/core/net/rpl/rpl-timers.c index 7c039712b..aa5e6d086 100644 --- a/core/net/rpl/rpl-timers.c +++ b/core/net/rpl/rpl-timers.c @@ -112,7 +112,7 @@ new_dio_interval(rpl_dag_t *dag) dag->version, dag->dio_totint, dag->dio_totsend, dag->dio_totrecv,dag->dio_intcurrent, - dag->rank == ROOT_RANK ? "BLUE" : "ORANGE"); + dag->rank == ROOT_RANK(dag) ? "BLUE" : "ORANGE"); #endif /* RPL_CONF_STATS */ /* reset the redundancy counter */ From 55c4df8ee782a8aa018e468e4a4e786a8a1c7eed Mon Sep 17 00:00:00 2001 From: nvt Date: Thu, 17 Mar 2011 20:29:38 +0100 Subject: [PATCH 4/4] Slight generalization to make it easier to switch metric. --- core/net/neighbor-info.c | 56 ++++++++++++++++++++-------------------- core/net/neighbor-info.h | 3 ++- 2 files changed, 30 insertions(+), 29 deletions(-) diff --git a/core/net/neighbor-info.c b/core/net/neighbor-info.c index aa9424978..c36a2b8a5 100644 --- a/core/net/neighbor-info.c +++ b/core/net/neighbor-info.c @@ -48,38 +48,38 @@ #define ETX_ALPHA 90 #define ETX_NOACK_PENALTY ETX_LIMIT /*---------------------------------------------------------------------------*/ -NEIGHBOR_ATTRIBUTE(uint8_t, etx, NULL); +NEIGHBOR_ATTRIBUTE(link_metric_t, etx, NULL); static neighbor_info_subscriber_t subscriber_callback; /*---------------------------------------------------------------------------*/ static void -update_etx(const rimeaddr_t *dest, int packet_etx) +update_metric(const rimeaddr_t *dest, int packet_metric) { - uint8_t *etxp; - uint8_t recorded_etx, new_etx; + link_metric_t *metricp; + link_metric_t recorded_metric, new_metric; - etxp = (uint8_t *)neighbor_attr_get_data(&etx, dest); - packet_etx = NEIGHBOR_INFO_ETX2FIX(packet_etx); - if(etxp == NULL || *etxp == 0) { - recorded_etx = NEIGHBOR_INFO_ETX2FIX(ETX_LIMIT); - new_etx = packet_etx; + metricp = (link_metric_t *)neighbor_attr_get_data(&etx, dest); + packet_metric = NEIGHBOR_INFO_ETX2FIX(packet_metric); + if(metricp == NULL || *metricp == 0) { + recorded_metric = NEIGHBOR_INFO_ETX2FIX(ETX_LIMIT); + new_metric = packet_metric; } else { - recorded_etx = *etxp; + recorded_metric = *metricp; /* Update the EWMA of the ETX for the neighbor. */ - new_etx = ((uint16_t)recorded_etx * ETX_ALPHA + - (uint16_t)packet_etx * (ETX_SCALE - ETX_ALPHA)) / ETX_SCALE; + new_metric = ((uint16_t)recorded_metric * ETX_ALPHA + + (uint16_t)packet_metric * (ETX_SCALE - ETX_ALPHA)) / ETX_SCALE; } PRINTF("neighbor-info: ETX changed from %d to %d (packet ETX = %d) %d\n", - NEIGHBOR_INFO_FIX2ETX(recorded_etx), - NEIGHBOR_INFO_FIX2ETX(new_etx), - NEIGHBOR_INFO_FIX2ETX(packet_etx), + NEIGHBOR_INFO_FIX2ETX(recorded_metric), + NEIGHBOR_INFO_FIX2ETX(new_metric), + NEIGHBOR_INFO_FIX2ETX(packet_metric), dest->u8[7]); if(neighbor_attr_has_neighbor(dest)) { - neighbor_attr_set_data(&etx, dest, &new_etx); - if(new_etx != recorded_etx && subscriber_callback != NULL) { - subscriber_callback(dest, 1, new_etx); + neighbor_attr_set_data(&etx, dest, &new_metric); + if(new_metric != recorded_metric && subscriber_callback != NULL) { + subscriber_callback(dest, 1, new_metric); } } } @@ -103,7 +103,7 @@ void neighbor_info_packet_sent(int status, int numtx) { const rimeaddr_t *dest; - uint8_t packet_etx; + link_metric_t packet_metric; dest = packetbuf_addr(PACKETBUF_ADDR_RECEIVER); if(rimeaddr_cmp(dest, &rimeaddr_null)) { @@ -116,14 +116,14 @@ neighbor_info_packet_sent(int status, int numtx) switch(status) { case MAC_TX_OK: - packet_etx = numtx; + packet_metric = numtx; add_neighbor(dest); break; case MAC_TX_COLLISION: - packet_etx = numtx; + packet_metric = numtx; break; case MAC_TX_NOACK: - packet_etx = ETX_NOACK_PENALTY; + packet_metric = ETX_NOACK_PENALTY; break; default: /* Do not penalize the ETX when collisions or transmission @@ -131,7 +131,7 @@ neighbor_info_packet_sent(int status, int numtx) return; } - update_etx(dest, packet_etx); + update_metric(dest, packet_metric); } /*---------------------------------------------------------------------------*/ void @@ -162,12 +162,12 @@ neighbor_info_subscribe(neighbor_info_subscriber_t s) return 0; } /*---------------------------------------------------------------------------*/ -uint8_t -neighbor_info_get_etx(const rimeaddr_t *addr) +link_metric_t +neighbor_info_get_metric(const rimeaddr_t *addr) { - uint8_t *etxp; + link_metric_t *metricp; - etxp = (uint8_t *)neighbor_attr_get_data(&etx, addr); - return etxp == NULL ? ETX_LIMIT : *etxp; + metricp = (link_metric_t *)neighbor_attr_get_data(&etx, addr); + return metricp == NULL ? ETX_LIMIT : *metricp; } /*---------------------------------------------------------------------------*/ diff --git a/core/net/neighbor-info.h b/core/net/neighbor-info.h index 09dd84ed4..f292c2ef1 100644 --- a/core/net/neighbor-info.h +++ b/core/net/neighbor-info.h @@ -52,6 +52,7 @@ #define NEIGHBOR_INFO_FIX2ETX(fix) ((fix) / NEIGHBOR_INFO_ETX_DIVISOR) typedef void (*neighbor_info_subscriber_t)(const rimeaddr_t *, int known, int etx); +typedef uint8_t link_metric_t; /** * Notify the neighbor information module about the status of @@ -85,6 +86,6 @@ int neighbor_info_subscribe(neighbor_info_subscriber_t); * * \return Returns ETX if the neighbor exists, and 0 if not. */ -uint8_t neighbor_info_get_etx(const rimeaddr_t *addr); +link_metric_t neighbor_info_get_etx(const rimeaddr_t *addr); #endif /* NEIGHBOR_INFO_H */