1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/pkg/openwsn/patches/0005-fixes-to-RIOT-adaption.patch

2829 lines
88 KiB
Diff
Raw Normal View History

From 49fa857a8548b297381f823bf0979732fe18b7dd Mon Sep 17 00:00:00 2001
From: Thomas Eichinger <thomas.eichinger1@gmail.com>
Date: Tue, 2 Dec 2014 14:48:17 +0100
Subject: [PATCH 5/5] fixes to RIOT adaption
---
Makefile | 3 +-
bsp/boards/radiotimer.h | 2 +-
bsp/boards/riot-adaption/board_info.h | 51 +--
bsp/boards/riot-adaption/board_ow.c | 8 +-
bsp/boards/riot-adaption/leds_ow.c | 63 +--
bsp/boards/riot-adaption/radio.c | 615 ++++++++++++++------------
bsp/boards/riot-adaption/radiotimer.c | 58 +--
bsp/boards/riot-adaption/riot.h | 36 ++
bsp/boards/riot-adaption/spi_ow.c | 321 --------------
bsp/boards/riot-adaption/uart_ow.c | 8 +-
bsp/boards/uart.h | 2 +-
drivers/common/Makefile | 6 +
drivers/common/openserial.c | 412 ++++++++---------
drivers/common/opentimers.c | 32 +-
kernel/openos/scheduler.c | 22 +-
openapps/Makefile | 6 +-
openapps/cstorm/cstorm.c | 2 +-
openapps/uecho/uecho.c | 98 ++--
openstack/02a-MAClow/IEEE802154E.c | 5 +
openstack/02a-MAClow/IEEE802154E.h | 14 +-
openstack/02b-MAChigh/schedule.c | 30 +-
openstack/Makefile | 2 +
openstack/cross-layers/idmanager.c | 37 +-
openstack/cross-layers/idmanager.h | 2 +-
openstack/openstack.c | 8 +-
openstack/openstack.h | 2 +-
projects/common/03oos_openwsn/03oos_openwsn.c | 72 +--
projects/common/03oos_openwsn/03oos_openwsn.h | 8 +-
projects/common/03oos_openwsn/Makefile | 2 +
29 files changed, 875 insertions(+), 1052 deletions(-)
create mode 100644 bsp/boards/riot-adaption/riot.h
delete mode 100644 bsp/boards/riot-adaption/spi_ow.c
diff --git a/Makefile b/Makefile
index f1917fa..41ca883 100644
--- a/Makefile
+++ b/Makefile
@@ -5,7 +5,8 @@ DIRS += $(OPENWSN_ROOT)/projects/common/03oos_openwsn \
$(OPENWSN_ROOT)/openstack \
$(OPENWSN_ROOT)/openapps \
$(OPENWSN_ROOT)/kernel/openos \
- $(OPENWSN_ROOT)/drivers/common
+ $(OPENWSN_ROOT)/drivers/common \
+ $(OPENWSN_ROOT)/bsp/boards/riot-adaption
INCLUDES += -I$(OPENWSN_ROOT)/kernel \
-I$(OPENWSN_ROOT)/inc \
diff --git a/bsp/boards/radiotimer.h b/bsp/boards/radiotimer.h
index 6b6b27c..fc2e639 100644
--- a/bsp/boards/radiotimer.h
+++ b/bsp/boards/radiotimer.h
@@ -44,7 +44,7 @@ void radiotimer_cancel(void);
PORT_RADIOTIMER_WIDTH radiotimer_getCapturedTime(void);
// interrupt handlers
-kick_scheduler_t radiotimer_isr(void);
+void radiotimer_isr(void);
/**
\}
diff --git a/bsp/boards/riot-adaption/board_info.h b/bsp/boards/riot-adaption/board_info.h
index 85f2eb1..fd46c20 100644
--- a/bsp/boards/riot-adaption/board_info.h
+++ b/bsp/boards/riot-adaption/board_info.h
@@ -1,12 +1,10 @@
/**
-\brief agilefox board information bsp module (based on openmoteSTM32 code).
+\brief RIOT adaption information bsp module.
This module simply defines some strings describing the board, which CoAP uses
to return the board's description.
-\author Thomas Watteyne <watteyne@eecs.berkeley.edu>, February 2012.
-\author Tengfei Chang <tengfei.chang@gmail.com>, July 2012.
-\author Alaeddine Weslati <alaeddine.weslati@inria.fr>, August 2013.
+\author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
*/
#ifndef __BOARD_INFO_H
@@ -29,44 +27,21 @@ to return the board's description.
#define PORT_RADIOTIMER_WIDTH uint32_t
#define PORT_SIGNED_INT_WIDTH int32_t
-#define PORT_TICS_PER_MS 32
-#define SCHEDULER_WAKEUP() //EXTI->SWIER |= EXTI_Line1;
-#define SCHEDULER_ENABLE_INTERRUPT() //enable in board use EXTI_Line1
-
-//===== pinout
-
-// [P4.7] radio SLP_TR_CNTL
-#define PORT_PIN_RADIO_SLP_TR_CNTL_HIGH() //GPIOA->ODR |= (1<<0);
-#define PORT_PIN_RADIO_SLP_TR_CNTL_LOW() //GPIOA->ODR &= ~(1<<0);
-// radio reset line
-// radio /RST
-#define PORT_PIN_RADIO_RESET_HIGH() //GPIOC->ODR |= 0X0040;// nothing
-#define PORT_PIN_RADIO_RESET_LOW() //GPIOC->ODR &= ~0X0040;// nothing
+#define PORT_TICS_PER_MS 1000
+#define SCHEDULER_WAKEUP()
+#define SCHEDULER_ENABLE_INTERRUPT()
//===== IEEE802154E timing
-
-//// time-slot related
-//#define PORT_TsSlotDuration 491 // counter counts one extra count, see datasheet
-//// execution speed related
-//#define PORT_maxTxDataPrepare 66 // 2014us (measured 746us)
-//#define PORT_maxRxAckPrepare 10 // 305us (measured 83us)
-//#define PORT_maxRxDataPrepare 33 // 1007us (measured 84us)
-//#define PORT_maxTxAckPrepare 10 // 305us (measured 219us)
-//// radio speed related
-//#define PORT_delayTx 9 // 214us (measured 219us)
-//#define PORT_delayRx 0 // 0us (can not measure)
-//// radio watchdog
-
// time-slot related
-#define PORT_TsSlotDuration 245 // counter counts one extra count, see datasheet
-// execution speed related (rcc configure need 235us)
-#define PORT_maxTxDataPrepare 33 // 2014us (measured 812us+235) stm32
-#define PORT_maxRxAckPrepare 10 // 900us (measured 171us+235) stm32
-#define PORT_maxRxDataPrepare 16 // 976us (measured 170us+235) stm32
-#define PORT_maxTxAckPrepare 10 // 900us (measured 323us+235) stm32
+#define PORT_TsSlotDuration 15000
+
+#define PORT_maxTxDataPrepare 2014
+#define PORT_maxRxAckPrepare 900
+#define PORT_maxRxDataPrepare 976
+#define PORT_maxTxAckPrepare 900
// radio speed related
-#define PORT_delayTx 10 // 549us (measured 315us+235) .....
-#define PORT_delayRx 0 // 0us (can not measure)
+#define PORT_delayTx 549
+#define PORT_delayRx 0
//===== adaptive_sync accuracy
diff --git a/bsp/boards/riot-adaption/board_ow.c b/bsp/boards/riot-adaption/board_ow.c
index 95f29b1..6c79b33 100644
--- a/bsp/boards/riot-adaption/board_ow.c
+++ b/bsp/boards/riot-adaption/board_ow.c
@@ -2,21 +2,15 @@
#include "radiotimer.h"
#include "radio.h"
#include "debugpins.h"
-#include "spi_ow.h"
-#define ENABLE_DEBUG (1)
+#define ENABLE_DEBUG (0)
#include "debug.h"
void board_init_ow(void)
{
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- spi_init_ow();
radio_init();
- DEBUG("%s\n",__PRETTY_FUNCTION__);
radiotimer_init();
- DEBUG("%s\n",__PRETTY_FUNCTION__);
debugpins_init();
- DEBUG("%s\n",__PRETTY_FUNCTION__);
}
void board_sleep(void)
diff --git a/bsp/boards/riot-adaption/leds_ow.c b/bsp/boards/riot-adaption/leds_ow.c
index cd892e1..0fd260e 100644
--- a/bsp/boards/riot-adaption/leds_ow.c
+++ b/bsp/boards/riot-adaption/leds_ow.c
@@ -24,16 +24,17 @@ void leds_error_toggle(void)
}
uint8_t leds_error_isOn(void)
{
- uint8_t bitstatus = 0x00;
- if ((LED_RED_PORT->ODR & LED_RED_PIN) != (uint32_t)0)
- {
- bitstatus = 0x00;
- }
- else
- {
- bitstatus = 0x01;
- }
- return bitstatus;
+ // uint8_t bitstatus = 0x00;
+ // if ((LED_RED_PORT->ODR & LED_RED_PIN) != (uint32_t)0)
+ // {
+ // bitstatus = 0x00;
+ // }
+ // else
+ // {
+ // bitstatus = 0x01;
+ // }
+ // return bitstatus;
+ return true;
}
void leds_error_blink(void) {}
@@ -52,16 +53,17 @@ void leds_sync_toggle(void)
}
uint8_t leds_sync_isOn(void)
{
- uint8_t bitstatus = 0x00;
- if ((LED_GREEN_PORT->ODR & LED_GREEN_PIN) != (uint32_t)0)
- {
- bitstatus = 0x00;
- }
- else
- {
- bitstatus = 0x01;
- }
- return bitstatus;
+ // uint8_t bitstatus = 0x00;
+ // if ((LED_GREEN_PORT->ODR & LED_GREEN_PIN) != (uint32_t)0)
+ // {
+ // bitstatus = 0x00;
+ // }
+ // else
+ // {
+ // bitstatus = 0x01;
+ // }
+ // return bitstatus;
+ return true;
}
/* orange */
@@ -79,16 +81,17 @@ void leds_radio_toggle(void)
}
uint8_t leds_radio_isOn(void)
{
- uint8_t bitstatus = 0x00;
- if ((LED_ORANGE_PORT->ODR & LED_ORANGE_PIN) != (uint32_t)0)
- {
- bitstatus = 0x00;
- }
- else
- {
- bitstatus = 0x01;
- }
- return bitstatus;
+ // uint8_t bitstatus = 0x00;
+ // if ((LED_ORANGE_PORT->ODR & LED_ORANGE_PIN) != (uint32_t)0)
+ // {
+ // bitstatus = 0x00;
+ // }
+ // else
+ // {
+ // bitstatus = 0x01;
+ // }
+ // return bitstatus;
+ return true;
}
/* yellow */
diff --git a/bsp/boards/riot-adaption/radio.c b/bsp/boards/riot-adaption/radio.c
index 203550c..76fd0ba 100644
--- a/bsp/boards/riot-adaption/radio.c
+++ b/bsp/boards/riot-adaption/radio.c
@@ -1,12 +1,11 @@
#include "board_ow.h"
#include "radio.h"
-#include "at86rf231_ow.h"
-#include "spi_ow.h"
+#include "board.h"
+#include "at86rf231.h"
+#include "at86rf231_spi.h"
#include "radiotimer.h"
#include "debugpins.h"
#include "leds.h"
-#include "board.h"
-#include "spi.h"
#include "periph_conf.h"
#define ENABLE_DEBUG (0)
@@ -27,46 +26,49 @@ radio_vars_t radio_vars;
//=========================== prototypes ======================================
-void radio_spiWriteReg(uint8_t reg_addr, uint8_t reg_setting);
-uint8_t radio_spiReadReg(uint8_t reg_addr);
-void radio_spiWriteTxFifo(uint8_t* bufToWrite, uint8_t lenToWrite);
-void radio_spiReadRxFifo(uint8_t* pBufRead,
- uint8_t* pLenRead,
- uint8_t maxBufLen,
- uint8_t* pLqi);
-uint8_t radio_spiReadRadioInfo(void);
+// void radio_spiWriteReg(uint8_t reg_addr, uint8_t reg_setting);
+// uint8_t radio_spiReadReg(uint8_t reg_addr);
+// void radio_spiWriteTxFifo(uint8_t* bufToWrite, uint8_t lenToWrite);
+// void radio_spiReadRxFifo(uint8_t* pBufRead,
+// uint8_t* pLenRead,
+// uint8_t maxBufLen,
+// uint8_t* pLqi);
+// uint8_t radio_spiReadRadioInfo(void);
//=========================== public ==========================================
//===== admin
void radio_init(void) {
-
- // clear variables
- memset(&radio_vars,0,sizeof(radio_vars_t));
-
- // change state
- radio_vars.state = RADIOSTATE_STOPPED;
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- // configure the radio
- radio_spiWriteReg(RG_TRX_STATE, CMD_FORCE_TRX_OFF); // turn radio off
-
- radio_spiWriteReg(RG_IRQ_MASK,
- (AT_IRQ_RX_START| AT_IRQ_TRX_END)); // tell radio to fire interrupt on TRX_END and RX_START
- radio_spiReadReg(RG_IRQ_STATUS); // deassert the interrupt pin in case is high
- radio_spiWriteReg(RG_ANT_DIV, RADIO_CHIP_ANTENNA); // use chip antenna
-#define RG_TRX_CTRL_1 0x04
- radio_spiWriteReg(RG_TRX_CTRL_1, 0x20); // have the radio calculate CRC
- //busy wait until radio status is TRX_OFF
- uint16_t c = 0;
- while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != TRX_OFF)
- if (c++ == 10000) {
- DEBUG("radio_spiReadReg timeout\n");
- break;
- }
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- // change state
- radio_vars.state = RADIOSTATE_RFOFF;
+ DEBUG("%s\n", __PRETTY_FUNCTION__);
+ at86rf231_initialize(&at86rf231_netdev);
+ at86rf231_set_monitor(1);
+
+// // clear variables
+// memset(&radio_vars,0,sizeof(radio_vars_t));
+
+// // change state
+// radio_vars.state = RADIOSTATE_STOPPED;
+// DEBUG("%s\n",__PRETTY_FUNCTION__);
+// // configure the radio
+// radio_spiWriteReg(RG_TRX_STATE, CMD_FORCE_TRX_OFF); // turn radio off
+
+// radio_spiWriteReg(RG_IRQ_MASK,
+// (AT_IRQ_RX_START| AT_IRQ_TRX_END)); // tell radio to fire interrupt on TRX_END and RX_START
+// radio_spiReadReg(RG_IRQ_STATUS); // deassert the interrupt pin in case is high
+// radio_spiWriteReg(RG_ANT_DIV, RADIO_CHIP_ANTENNA); // use chip antenna
+// #define RG_TRX_CTRL_1 0x04
+// radio_spiWriteReg(RG_TRX_CTRL_1, 0x20); // have the radio calculate CRC
+// //busy wait until radio status is TRX_OFF
+// uint16_t c = 0;
+// while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != TRX_OFF)
+// if (c++ == 10000) {
+// DEBUG("radio_spiReadReg timeout\n");
+// break;
+// }
+// DEBUG("%s\n",__PRETTY_FUNCTION__);
+// // change state
+// radio_vars.state = RADIOSTATE_RFOFF;
}
void radio_setOverflowCb(radiotimer_compare_cbt cb) {
@@ -88,7 +90,8 @@ void radio_setEndFrameCb(radiotimer_capture_cbt cb) {
//===== reset
void radio_reset(void) {
- PORT_PIN_RADIO_RESET_LOW();
+ at86rf231_off();
+ at86rf231_on();
}
//===== timer
@@ -116,53 +119,54 @@ void radio_setFrequency(uint8_t frequency) {
radio_vars.state = RADIOSTATE_SETTING_FREQUENCY;
// configure the radio to the right frequecy
- radio_spiWriteReg(RG_PHY_CC_CCA,0x20+frequency);
+ at86rf231_set_channel(frequency);
// change state
radio_vars.state = RADIOSTATE_FREQUENCY_SET;
}
void radio_rfOn(void) {
- PORT_PIN_RADIO_RESET_LOW();
+ at86rf231_on();
}
void radio_rfOff(void) {
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- // change state
- radio_vars.state = RADIOSTATE_TURNING_OFF;
- radio_spiReadReg(RG_TRX_STATUS);
- DEBUG("step 1\n");
- // turn radio off
- radio_spiWriteReg(RG_TRX_STATE, CMD_FORCE_TRX_OFF);
- DEBUG("step 2\n");
- radio_spiWriteReg(RG_TRX_STATE, CMD_TRX_OFF);
-
- // busy wait until done
- uint16_t c = 0;
- while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != TRX_OFF)
- ;// if (c++ == 100000) {
-// DEBUG("%s: radio_spiReadReg timeout\n", __PRETTY_FUNCTION__);
-// break;
-// }
-
- DEBUG("step 3\n");
- // wiggle debug pin
- debugpins_radio_clr();
+ // DEBUG("%s\n",__PRETTY_FUNCTION__);
+// // change state
+// radio_vars.state = RADIOSTATE_TURNING_OFF;
+// radio_spiReadReg(RG_TRX_STATUS);
+// DEBUG("step 1\n");
+// // turn radio off
+// radio_spiWriteReg(RG_TRX_STATE, CMD_FORCE_TRX_OFF);
+// DEBUG("step 2\n");
+// radio_spiWriteReg(RG_TRX_STATE, CMD_TRX_OFF);
+
+// // busy wait until done
+// uint16_t c = 0;
+// while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != TRX_OFF)
+// ;// if (c++ == 100000) {
+// // DEBUG("%s: radio_spiReadReg timeout\n", __PRETTY_FUNCTION__);
+// // break;
+// // }
+
+// DEBUG("step 3\n");
+// // wiggle debug pin
+// debugpins_radio_clr();
leds_radio_off();
- DEBUG("step 4\n");
- // change state
- radio_vars.state = RADIOSTATE_RFOFF;
- DEBUG("step 5\n");
+// DEBUG("step 4\n");
+// // change state
+// radio_vars.state = RADIOSTATE_RFOFF;
+// DEBUG("step 5\n");
}
//===== TX
void radio_loadPacket(uint8_t* packet, uint8_t len) {
+ DEBUG("rf load\n");
// change state
radio_vars.state = RADIOSTATE_LOADING_PACKET;
// load packet in TXFIFO
- radio_spiWriteTxFifo(packet,len);
+ at86rf231_write_fifo(packet, len);
// change state
radio_vars.state = RADIOSTATE_PACKET_LOADED;
@@ -171,19 +175,43 @@ void radio_loadPacket(uint8_t* packet, uint8_t len) {
void radio_txEnable(void) {
// change state
radio_vars.state = RADIOSTATE_ENABLING_TX;
-
- // wiggle debug pin
- debugpins_radio_set();
+ DEBUG("rf tx en\n");
+// // wiggle debug pin
+// debugpins_radio_set();
leds_radio_on();
- // turn on radio's PLL
- radio_spiWriteReg(RG_TRX_STATE, CMD_PLL_ON);
- uint16_t c = 0;
- while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != PLL_ON) // busy wait until done
- ;// if (c++ == 100000) {
-// DEBUG("%s: radio_spiReadReg timeout\n", __PRETTY_FUNCTION__);
-// break;
-// }
+ /* Go to state PLL_ON */
+ at86rf231_reg_write(AT86RF231_REG__TRX_STATE, AT86RF231_TRX_STATE__PLL_ON);
+
+ /* wait until it is on PLL_ON state */
+ do {
+ int max_wait = 100;
+ if (!--max_wait) {
+ DEBUG("at86rf231 : ERROR : could not enter PLL_ON mode\n");
+ break;
+ }
+ } while ((at86rf231_get_status() & AT86RF231_TRX_STATUS_MASK__TRX_STATUS)
+ != AT86RF231_TRX_STATUS__PLL_ON);
+
+ /* change into TX_ARET_ON state */
+ at86rf231_reg_write(AT86RF231_REG__TRX_STATE, AT86RF231_TRX_STATE__TX_ARET_ON);
+
+ do {
+ int max_wait = 100;
+ if (!--max_wait) {
+ DEBUG("at86rf231 : ERROR : could not enter TX_ARET_ON mode\n");
+ break;
+ }
+ } while (at86rf231_get_status() != AT86RF231_TRX_STATUS__TX_ARET_ON);
+
+// // turn on radio's PLL
+// radio_spiWriteReg(RG_TRX_STATE, CMD_PLL_ON);
+// uint16_t c = 0;
+// while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != PLL_ON) // busy wait until done
+// ;// if (c++ == 100000) {
+// // DEBUG("%s: radio_spiReadReg timeout\n", __PRETTY_FUNCTION__);
+// // break;
+// // }
// change state
radio_vars.state = RADIOSTATE_TX_ENABLED;
@@ -195,8 +223,11 @@ void radio_txNow(void) {
radio_vars.state = RADIOSTATE_TRANSMITTING;
leds_radio_toggle();
// send packet by pulsing the SLP_TR_CNTL pin
- PORT_PIN_RADIO_SLP_TR_CNTL_HIGH();
- PORT_PIN_RADIO_SLP_TR_CNTL_LOW();
+ // PORT_PIN_RADIO_SLP_TR_CNTL_HIGH();
+ // PORT_PIN_RADIO_SLP_TR_CNTL_LOW();
+
+ at86rf231_transmit_tx_buf(&at86rf231_netdev);
+
leds_radio_toggle();
// The AT86RF231 does not generate an interrupt when the radio transmits the
// SFD, which messes up the MAC state machine. The danger is that, if we leave
@@ -220,19 +251,21 @@ void radio_rxEnable(void) {
radio_vars.state = RADIOSTATE_ENABLING_RX;
// put radio in reception mode
- radio_spiWriteReg(RG_TRX_STATE, CMD_RX_ON);
+ // radio_spiWriteReg(RG_TRX_STATE, CMD_RX_ON);
- // wiggle debug pin
- debugpins_radio_set();
+ at86rf231_switch_to_rx();
+
+// // wiggle debug pin
+// debugpins_radio_set();
leds_radio_on();
- // busy wait until radio really listening
- uint16_t c = 0;
- while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != RX_ON)
- ;// if (c++ == 100000) {
-// DEBUG("%s: radio_spiReadReg timeout\n",__PRETTY_FUNCTION__);
-// break;
-// }
+// // busy wait until radio really listening
+// uint16_t c = 0;
+// while((radio_spiReadReg(RG_TRX_STATUS) & 0x1F) != RX_ON)
+// ;// if (c++ == 100000) {
+// // DEBUG("%s: radio_spiReadReg timeout\n",__PRETTY_FUNCTION__);
+// // break;
+// // }
// change state
radio_vars.state = RADIOSTATE_LISTENING;
@@ -248,212 +281,216 @@ void radio_getReceivedFrame(uint8_t* pBufRead,
uint8_t maxBufLen,
int8_t* pRssi,
uint8_t* pLqi,
- uint8_t* pCrc) {
+ bool* pCrc) {
uint8_t temp_reg_value;
//===== crc
- temp_reg_value = radio_spiReadReg(RG_PHY_RSSI);
+ temp_reg_value = at86rf231_reg_read(AT86RF231_REG__PHY_RSSI);
*pCrc = (temp_reg_value & 0x80)>>7; // msb is whether packet passed CRC
-
- //===== rssi
- // as per section 8.4.3 of the AT86RF231, the RSSI is calculate as:
- // -91 + ED [dBm]
- temp_reg_value = radio_spiReadReg(RG_PHY_ED_LEVEL);
- *pRssi = -91 + temp_reg_value;
-
- //===== packet
- radio_spiReadRxFifo(pBufRead,
- pLenRead,
- maxBufLen,
- pLqi);
+ *pRssi = (temp_reg_value & 0x0f);
+
+ // //===== rssi
+ // // as per section 8.4.3 of the AT86RF231, the RSSI is calculate as:
+ // // -91 + ED [dBm]
+ // temp_reg_value = radio_spiReadReg(RG_PHY_ED_LEVEL);
+ // *pRssi = -91 + temp_reg_value;
+
+ // //===== packet
+ // radio_spiReadRxFifo(pBufRead,
+ // pLenRead,
+ // maxBufLen,
+ // pLqi);
+ at86rf231_read_fifo(pLenRead, 1);
+ at86rf231_read_fifo(pBufRead, *pLenRead);
+ *pLqi = pBufRead[(*pLenRead)-1];
}
//=========================== private =========================================
-static inline void CSn_SET(void)
-{
- SPI_0_CS_PORT->BSRR = (1 << SPI_0_CS_PIN);
-}
-static inline void CSn_CLR(void)
-{
- SPI_0_CS_PORT->BRR = (1 << SPI_0_CS_PIN);
-}
-
-uint8_t radio_spiReadRadioInfo(void){
- uint8_t spi_tx_buffer[3];
- uint8_t spi_rx_buffer[3];
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- // prepare buffer to send over SPI
- spi_tx_buffer[0] = (0x80 | 0x1E); // [b7] Read/Write: 1 (read)
- // [b6] RAM/Register : 1 (register)
- // [b5-0] address: 0x1E (Manufacturer ID, Lower 16 Bit)
- spi_tx_buffer[1] = 0x00; // send a SNOP strobe just to get the reg value
- spi_tx_buffer[2] = 0x00; // send a SNOP strobe just to get the reg value
-
- // retrieve radio manufacturer ID over SPI
- // spi_txrx(spi_tx_buffer,
- // sizeof(spi_tx_buffer),
- // SPI_BUFFER,
- // spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_FIRST,
- // SPI_LAST);
- CSn_CLR();
- spi_transfer_bytes(SPI_0, spi_tx_buffer, spi_rx_buffer, 3);
- CSn_SET();
- return spi_rx_buffer[2];
-}
-
-void radio_spiWriteReg(uint8_t reg_addr, uint8_t reg_setting) {
- uint8_t spi_tx_buffer[2];
- uint8_t spi_rx_buffer[2];
- spi_tx_buffer[0] = (0xC0 | reg_addr); // turn addess in a 'reg write' address
- spi_tx_buffer[1] = reg_setting;
-
- // spi_txrx(spi_tx_buffer,
- // sizeof(spi_tx_buffer),
- // SPI_BUFFER,
- // (uint8_t*)spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_FIRST,
- // SPI_LAST);
- CSn_CLR();
- spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
- spi_transfer_byte(SPI_0, spi_tx_buffer[1], NULL);
- CSn_SET();
-}
-
-uint8_t radio_spiReadReg(uint8_t reg_addr) {
- uint8_t spi_tx_buffer[2];
- uint8_t spi_rx_buffer[2];
- spi_tx_buffer[0] = (0x80 | reg_addr); // turn addess in a 'reg read' address
- spi_tx_buffer[1] = 0x00; // send a no_operation command just to get the reg value
-
- // spi_txrx(spi_tx_buffer,
- // sizeof(spi_tx_buffer),
- // SPI_BUFFER,
- // (uint8_t*)spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_FIRST,
- // SPI_LAST);
- CSn_CLR();
- spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
- spi_transfer_byte(SPI_0, 0, spi_rx_buffer);
- CSn_SET();
-
- return spi_rx_buffer[0];
-}
-
-/** for testing purposes, remove if not needed anymore**/
-
-void radio_spiWriteTxFifo(uint8_t* bufToWrite, uint8_t lenToWrite) {
- uint8_t spi_tx_buffer[2];
- uint8_t spi_rx_buffer[1+1+127]; // 1B SPI address, 1B length, max. 127B data
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- spi_tx_buffer[0] = 0x60; // SPI destination address for TXFIFO
- spi_tx_buffer[1] = lenToWrite; // length byte
-
- CSn_CLR();
- spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
- spi_transfer_byte(SPI_0, spi_tx_buffer[1], NULL);
- spi_transfer_bytes(SPI_0, bufToWrite, NULL, lenToWrite);
- CSn_SET();
-
- // spi_txrx(spi_tx_buffer,
- // sizeof(spi_tx_buffer),
- // SPI_BUFFER,
- // spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_FIRST,
- // SPI_NOTLAST);
-
- // spi_txrx(bufToWrite,
- // lenToWrite,
- // SPI_BUFFER,
- // spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_NOTFIRST,
- // SPI_LAST);
-}
-
-
-
-void radio_spiReadRxFifo(uint8_t* pBufRead,
- uint8_t* pLenRead,
- uint8_t maxBufLen,
- uint8_t* pLqi) {
- // when reading the packet over SPI from the RX buffer, you get the following:
- // - *[1B] dummy byte because of SPI
- // - *[1B] length byte
- // - [0-125B] packet (excluding CRC)
- // - *[2B] CRC
- // - *[1B] LQI
- uint8_t spi_tx_buffer[125];
- uint8_t spi_rx_buffer[3];
- DEBUG("%s\n",__PRETTY_FUNCTION__);
- spi_tx_buffer[0] = 0x20;
-
- CSn_CLR();
- spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
- spi_transfer_byte(SPI_0, 0, spi_rx_buffer);
- // 2 first bytes
- // spi_txrx(spi_tx_buffer,
- // 2,
- // SPI_BUFFER,
- // spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_FIRST,
- // SPI_NOTLAST);
-
- *pLenRead = spi_rx_buffer[0];
-
- if (*pLenRead>2 && *pLenRead<=127) {
- // valid length
- spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
- spi_transfer_bytes(SPI_0, NULL, pBufRead, *pLenRead);
-
- // //read packet
- // spi_txrx(spi_tx_buffer,
- // *pLenRead,
- // SPI_BUFFER,
- // pBufRead,
- // 125,
- // SPI_NOTFIRST,
- // SPI_NOTLAST);
- spi_transfer_byte(SPI_0, 0, 0);
- spi_transfer_byte(SPI_0, 0, 0);
- spi_transfer_byte(SPI_0, 0, pLqi);
- // CRC (2B) and LQI (1B)
- // spi_txrx(spi_tx_buffer,
- // 2+1,
- // SPI_BUFFER,
- // spi_rx_buffer,
- // 3,
- // SPI_NOTFIRST,
- // SPI_LAST);
-
- // *pLqi = spi_rx_buffer[2];
-
- } else {
- // invalid length
- spi_transfer_byte(SPI_0, 0, 0);
- // read a just byte to close spi
- // spi_txrx(spi_tx_buffer,
- // 1,
- // SPI_BUFFER,
- // spi_rx_buffer,
- // sizeof(spi_rx_buffer),
- // SPI_NOTFIRST,
- // SPI_LAST);
- }
- CSn_SET();
-}
+// static inline void CSn_SET(void)
+// {
+// SPI_0_CS_PORT->BSRR = (1 << SPI_0_CS_PIN);
+// }
+// static inline void CSn_CLR(void)
+// {
+// SPI_0_CS_PORT->BRR = (1 << SPI_0_CS_PIN);
+// }
+
+// uint8_t radio_spiReadRadioInfo(void){
+// uint8_t spi_tx_buffer[3];
+// uint8_t spi_rx_buffer[3];
+// DEBUG("%s\n",__PRETTY_FUNCTION__);
+// // prepare buffer to send over SPI
+// spi_tx_buffer[0] = (0x80 | 0x1E); // [b7] Read/Write: 1 (read)
+// // [b6] RAM/Register : 1 (register)
+// // [b5-0] address: 0x1E (Manufacturer ID, Lower 16 Bit)
+// spi_tx_buffer[1] = 0x00; // send a SNOP strobe just to get the reg value
+// spi_tx_buffer[2] = 0x00; // send a SNOP strobe just to get the reg value
+
+// // retrieve radio manufacturer ID over SPI
+// // spi_txrx(spi_tx_buffer,
+// // sizeof(spi_tx_buffer),
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_FIRST,
+// // SPI_LAST);
+// CSn_CLR();
+// spi_transfer_bytes(SPI_0, spi_tx_buffer, spi_rx_buffer, 3);
+// CSn_SET();
+// return spi_rx_buffer[2];
+// }
+
+// void radio_spiWriteReg(uint8_t reg_addr, uint8_t reg_setting) {
+// uint8_t spi_tx_buffer[2];
+// uint8_t spi_rx_buffer[2];
+// spi_tx_buffer[0] = (0xC0 | reg_addr); // turn addess in a 'reg write' address
+// spi_tx_buffer[1] = reg_setting;
+
+// // spi_txrx(spi_tx_buffer,
+// // sizeof(spi_tx_buffer),
+// // SPI_BUFFER,
+// // (uint8_t*)spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_FIRST,
+// // SPI_LAST);
+// CSn_CLR();
+// spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
+// spi_transfer_byte(SPI_0, spi_tx_buffer[1], NULL);
+// CSn_SET();
+// }
+
+// uint8_t radio_spiReadReg(uint8_t reg_addr) {
+// uint8_t spi_tx_buffer[2];
+// uint8_t spi_rx_buffer[2];
+// spi_tx_buffer[0] = (0x80 | reg_addr); // turn addess in a 'reg read' address
+// spi_tx_buffer[1] = 0x00; // send a no_operation command just to get the reg value
+
+// // spi_txrx(spi_tx_buffer,
+// // sizeof(spi_tx_buffer),
+// // SPI_BUFFER,
+// // (uint8_t*)spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_FIRST,
+// // SPI_LAST);
+// CSn_CLR();
+// spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
+// spi_transfer_byte(SPI_0, 0, spi_rx_buffer);
+// CSn_SET();
+
+// return spi_rx_buffer[0];
+// }
+
+// /** for testing purposes, remove if not needed anymore**/
+
+// void radio_spiWriteTxFifo(uint8_t* bufToWrite, uint8_t lenToWrite) {
+// uint8_t spi_tx_buffer[2];
+// uint8_t spi_rx_buffer[1+1+127]; // 1B SPI address, 1B length, max. 127B data
+// DEBUG("%s\n",__PRETTY_FUNCTION__);
+// spi_tx_buffer[0] = 0x60; // SPI destination address for TXFIFO
+// spi_tx_buffer[1] = lenToWrite; // length byte
+
+// CSn_CLR();
+// spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
+// spi_transfer_byte(SPI_0, spi_tx_buffer[1], NULL);
+// spi_transfer_bytes(SPI_0, bufToWrite, NULL, lenToWrite);
+// CSn_SET();
+
+// // spi_txrx(spi_tx_buffer,
+// // sizeof(spi_tx_buffer),
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_FIRST,
+// // SPI_NOTLAST);
+
+// // spi_txrx(bufToWrite,
+// // lenToWrite,
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_NOTFIRST,
+// // SPI_LAST);
+// }
+
+
+
+// void radio_spiReadRxFifo(uint8_t* pBufRead,
+// uint8_t* pLenRead,
+// uint8_t maxBufLen,
+// uint8_t* pLqi) {
+// // when reading the packet over SPI from the RX buffer, you get the following:
+// // - *[1B] dummy byte because of SPI
+// // - *[1B] length byte
+// // - [0-125B] packet (excluding CRC)
+// // - *[2B] CRC
+// // - *[1B] LQI
+// uint8_t spi_tx_buffer[125];
+// uint8_t spi_rx_buffer[3];
+// DEBUG("%s\n",__PRETTY_FUNCTION__);
+// spi_tx_buffer[0] = 0x20;
+
+// CSn_CLR();
+// spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
+// spi_transfer_byte(SPI_0, 0, spi_rx_buffer);
+// // 2 first bytes
+// // spi_txrx(spi_tx_buffer,
+// // 2,
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_FIRST,
+// // SPI_NOTLAST);
+
+// *pLenRead = spi_rx_buffer[0];
+
+// if (*pLenRead>2 && *pLenRead<=127) {
+// // valid length
+// spi_transfer_byte(SPI_0, spi_tx_buffer[0], NULL);
+// spi_transfer_bytes(SPI_0, NULL, pBufRead, *pLenRead);
+
+// // //read packet
+// // spi_txrx(spi_tx_buffer,
+// // *pLenRead,
+// // SPI_BUFFER,
+// // pBufRead,
+// // 125,
+// // SPI_NOTFIRST,
+// // SPI_NOTLAST);
+// spi_transfer_byte(SPI_0, 0, 0);
+// spi_transfer_byte(SPI_0, 0, 0);
+// spi_transfer_byte(SPI_0, 0, pLqi);
+// // CRC (2B) and LQI (1B)
+// // spi_txrx(spi_tx_buffer,
+// // 2+1,
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // 3,
+// // SPI_NOTFIRST,
+// // SPI_LAST);
+
+// // *pLqi = spi_rx_buffer[2];
+
+// } else {
+// // invalid length
+// spi_transfer_byte(SPI_0, 0, 0);
+// // read a just byte to close spi
+// // spi_txrx(spi_tx_buffer,
+// // 1,
+// // SPI_BUFFER,
+// // spi_rx_buffer,
+// // sizeof(spi_rx_buffer),
+// // SPI_NOTFIRST,
+// // SPI_LAST);
+// }
+// CSn_SET();
+// }
//=========================== callbacks =======================================
//=========================== interrupt handlers ==============================
-kick_scheduler_t radio_isr(void) {
+void at86rf231_rx_irq(void) {
PORT_TIMER_WIDTH capturedTime;
uint8_t irq_status;
@@ -461,10 +498,10 @@ kick_scheduler_t radio_isr(void) {
capturedTime = radiotimer_getCapturedTime();
// reading IRQ_STATUS causes radio's IRQ pin to go low
- irq_status = radio_spiReadReg(RG_IRQ_STATUS);
+ irq_status = at86rf231_reg_read(AT86RF231_REG__IRQ_STATUS);
// start of frame event
- if (irq_status & AT_IRQ_RX_START) {
+ if (irq_status & AT86RF231_IRQ_STATUS_MASK__RX_START) {
DEBUG("Start of frame.\n");
// change state
radio_vars.state = RADIOSTATE_RECEIVING;
@@ -472,13 +509,13 @@ kick_scheduler_t radio_isr(void) {
// call the callback
radio_vars.startFrame_cb(capturedTime);
// kick the OS
- return KICK_SCHEDULER;
+ return;
} else {
while(1);
}
}
// end of frame event
- if (irq_status & AT_IRQ_TRX_END) {
+ if (irq_status & AT86RF231_IRQ_STATUS_MASK__TRX_END) {
DEBUG("End of Frame.\n");
// change state
radio_vars.state = RADIOSTATE_TXRX_DONE;
@@ -486,11 +523,9 @@ kick_scheduler_t radio_isr(void) {
// call the callback
radio_vars.endFrame_cb(capturedTime);
// kick the OS
- return KICK_SCHEDULER;
+ return;
} else {
while(1);
}
}
-
- return DO_NOT_KICK_SCHEDULER;
}
\ No newline at end of file
diff --git a/bsp/boards/riot-adaption/radiotimer.c b/bsp/boards/riot-adaption/radiotimer.c
index e9c0b54..47fa2d2 100644
--- a/bsp/boards/riot-adaption/radiotimer.c
+++ b/bsp/boards/riot-adaption/radiotimer.c
@@ -8,11 +8,14 @@ On openmoteSTM32, we use RTC for the radiotimer module.
#include "stdint.h"
#include "periph/timer.h"
+#include "hwtimer.h"
#include "leds.h"
#include "radiotimer.h"
#include "board_info.h"
+#include "riot.h"
+
#define ENABLE_DEBUG (0)
#include "debug.h"
@@ -36,14 +39,14 @@ volatile radiotimer_vars_t radiotimer_vars;
uint16_t current_period;
//=========================== prototypes ======================================
-
+extern int timer_set_relative(tim_t, int channel, unsigned int rel_value);
//=========================== public ==========================================
//===== admin
void radiotimer_init(void) {
// clear local variables
- memset(&radiotimer_vars,0,sizeof(radiotimer_vars_t));
+ memset((void*)&radiotimer_vars,0,sizeof(radiotimer_vars_t));
current_period = 0;
}
@@ -63,10 +66,10 @@ void radiotimer_setEndFrameCb(radiotimer_capture_cbt cb) {
while(1);
}
-void radiotimer_start(uint16_t period) {
+void radiotimer_start(PORT_RADIOTIMER_WIDTH period) {
DEBUG("%s\n", __PRETTY_FUNCTION__);
- timer_init(TIMER_1, 1, &radiotimer_isr);
- timer_set(TIMER_1, 1, (0xffff)&((unsigned int)period));
+ // timer_init(OWSN_TIMER, 1, &radiotimer_isr);
+ timer_set(OWSN_TIMER, 1, ((unsigned int)HWTIMER_TICKS(period)*10));
current_period = period;
radiotimer_vars.currentSlotPeriod = period;
radiotimer_vars.overflowORcompare = RADIOTIMER_OVERFLOW;
@@ -74,12 +77,13 @@ void radiotimer_start(uint16_t period) {
//===== direct access
-uint16_t radiotimer_getValue(void) {
- return (uint16_t)((0xffff)&timer_read(TIMER_1));
+PORT_RADIOTIMER_WIDTH radiotimer_getValue(void) {
+ return (PORT_RADIOTIMER_WIDTH)(HWTIMER_TICKS_TO_US(timer_read(OWSN_TIMER)));
}
-void radiotimer_setPeriod(uint16_t period) {
- timer_set(TIMER_1, 1, (0xffff)&((unsigned int)period));
+void radiotimer_setPeriod(PORT_RADIOTIMER_WIDTH period) {
+ DEBUG("%s\n", __PRETTY_FUNCTION__);
+ timer_set(OWSN_TIMER, 1, ((unsigned int)HWTIMER_TICKS(period)*10));
current_period = period;
radiotimer_vars.currentSlotPeriod = period;
@@ -87,26 +91,27 @@ void radiotimer_setPeriod(uint16_t period) {
radiotimer_vars.overflowORcompare = RADIOTIMER_OVERFLOW;
}
-uint16_t radiotimer_getPeriod(void) {
+PORT_RADIOTIMER_WIDTH radiotimer_getPeriod(void) {
return current_period;
}
//===== compare
-void radiotimer_schedule(uint16_t offset) {
- timer_irq_disable(TIMER_1);
- timer_set(TIMER_1, 1, offset);
- current_period = offset;
- timer_irq_enable(TIMER_1);
+void radiotimer_schedule(PORT_RADIOTIMER_WIDTH offset) {
+ DEBUG("%s\n", __PRETTY_FUNCTION__);
+ timer_irq_disable(OWSN_TIMER);
+ timer_set(OWSN_TIMER, 1, HWTIMER_TICKS(offset)*10);
+ timer_irq_enable(OWSN_TIMER);
//set radiotimer irpstatus
radiotimer_vars.overflowORcompare = RADIOTIMER_COMPARE;
}
void radiotimer_cancel(void) {
- timer_irq_disable(TIMER_1);
- timer_clear(TIMER_1, 1);
- current_period = 0;
- timer_irq_enable(TIMER_1);
+ DEBUG("%s\n", __PRETTY_FUNCTION__);
+ timer_irq_disable(OWSN_TIMER);
+ // timer_clear(OWSN_TIMER, 1);
+ timer_set(OWSN_TIMER, 1, HWTIMER_TICKS(current_period)*10);
+ timer_irq_enable(OWSN_TIMER);
//set radiotimer irpstatus
radiotimer_vars.overflowORcompare = RADIOTIMER_OVERFLOW;
@@ -114,15 +119,14 @@ void radiotimer_cancel(void) {
//===== capture
-inline uint16_t radiotimer_getCapturedTime(void) {
- return (uint16_t)((0xffff)&timer_read(TIMER_1));
+inline PORT_RADIOTIMER_WIDTH radiotimer_getCapturedTime(void) {
+ return (PORT_RADIOTIMER_WIDTH)(timer_read(OWSN_TIMER));
}
//=========================== private =========================================
//=========================== interrupt handlers ==============================
-
-kick_scheduler_t radiotimer_isr(void) {
+void radiotimer_isr(void) {
uint8_t taiv_temp = radiotimer_vars.overflowORcompare;
switch (taiv_temp) {
case RADIOTIMER_COMPARE:
@@ -130,19 +134,19 @@ kick_scheduler_t radiotimer_isr(void) {
if (radiotimer_vars.compare_cb!=NULL) {
radiotimer_vars.compare_cb();
// kick the OS
- return KICK_SCHEDULER;
+ // return KICK_SCHEDULER;
}
break;
case RADIOTIMER_OVERFLOW: // timer overflows
DEBUG("%s of\n", __PRETTY_FUNCTION__);
if (radiotimer_vars.overflow_cb!=NULL) {
//Wait until last write operation on RTC registers has finished
- timer_reset(TIMER_1);
+ timer_set(OWSN_TIMER, 1, HWTIMER_TICKS(current_period)*10);
// call the callback
radiotimer_vars.overflow_cb();
DEBUG("returned...\n");
// kick the OS
- return KICK_SCHEDULER;
+ // return KICK_SCHEDULER;
}
break;
case RADIOTIMER_NONE: // this should not happen
@@ -151,5 +155,5 @@ kick_scheduler_t radiotimer_isr(void) {
DEBUG("%s default\n", __PRETTY_FUNCTION__);
// while(1); // this should not happen
}
- return DO_NOT_KICK_SCHEDULER;
+ // return DO_NOT_KICK_SCHEDULER;
}
\ No newline at end of file
diff --git a/bsp/boards/riot-adaption/riot.h b/bsp/boards/riot-adaption/riot.h
new file mode 100644
index 0000000..982241c
--- /dev/null
+++ b/bsp/boards/riot-adaption/riot.h
@@ -0,0 +1,36 @@
+/*
+ * Copyright (C) 2014 Freie Universität Berlin
+ *
+ * This file is subject to the terms and conditions of the GNU Lesser
+ * General Public License v2.1. See the file LICENSE in the top level
+ * directory for more details.
+ */
+
+/**
+ * @{
+ *
+ * @file
+ * @brief RIOT specific definitions for OpenWSN
+ *
+ * @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
+ */
+
+#ifndef __RIOT_H
+#define __RIOT_H
+
+#include "thread.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/**
+ * @brief The peripheral timer to use with OpenWSN
+ */
+#define OWSN_TIMER TIMER_1
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* __RIOT_H */
+/** @} */
\ No newline at end of file
diff --git a/bsp/boards/riot-adaption/spi_ow.c b/bsp/boards/riot-adaption/spi_ow.c
deleted file mode 100644
index 56193f6..0000000
--- a/bsp/boards/riot-adaption/spi_ow.c
+++ /dev/null
@@ -1,321 +0,0 @@
-#include "stdio.h"
-#include "stdint.h"
-#include "string.h"
-#include "spi_ow.h"
-#include "spi.h"
-#include "leds.h"
-#include "board.h"
-#include "radio.h"
-#include "periph/gpio.h"
-#include "periph_conf.h"
-#include "at86rf231.h"
-
-#define ENABLE_DEBUG (0)
-#include "debug.h"
-
-//=========================== defines =========================================
-
-//=========================== variables =======================================
-
-typedef struct {
- // information about the current transaction
- uint8_t* pNextTxByte;
- uint8_t numTxedBytes;
- uint8_t txBytesLeft;
- spi_return_t returnType;
- uint8_t* pNextRxByte;
- uint8_t maxRxBytes;
- spi_first_t isFirst;
- spi_last_t isLast;
- // state of the module
- uint8_t busy;
-#ifdef SPI_IN_INTERRUPT_MODE
- // callback when module done
- spi_cbt callback;
-#endif
-} spi_vars_t;
-
-volatile spi_vars_t spi_vars;
-
-//=========================== prototypes ======================================
-// inline static void RESET_CLR(void) { GPIOC->BRR = 1<<1; }
-// inline static void RESET_SET(void) { GPIOC->BSRR = 1<<1; }
-// inline static void CSn_SET(void) { GPIOA->BSRR = 1<<4; }
-// inline static void CSn_CLR(void) { GPIOA->BRR = 1<<4; }
-// inline static void SLEEP_CLR(void) { GPIOA->BRR = 1<<2; }
-static inline void RESET_CLR(void)
-{
- SPI_0_RESET_PORT->BRR = (1 << SPI_0_RESET_PIN);
-}
-static inline void RESET_SET(void)
-{
- SPI_0_RESET_PORT->BSRR = (1 << SPI_0_RESET_PIN);
-}
-static inline void CSn_SET(void)
-{
- SPI_0_CS_PORT->BSRR = (1 << SPI_0_CS_PIN);
-}
-static inline void CSn_CLR(void)
-{
- SPI_0_CS_PORT->BRR = (1 << SPI_0_CS_PIN);
-}
-static inline void SLEEP_CLR(void)
-{
- SPI_0_SLEEP_PORT->BRR = (1 << SPI_0_SLEEP_PIN);
-}
-
-//=========================== public ==========================================
-
-void spi_init_ow(void) {
- // clear variables
- memset(&spi_vars,0,sizeof(spi_vars_t));
-
- /* set up GPIO pins */
- /* SCLK and MOSI*/
- GPIOA->CRL &= ~(0xf << (5 * 4));
- GPIOA->CRL |= (0xb << (5 * 4));
- GPIOA->CRL &= ~(0xf << (7 * 4));
- GPIOA->CRL |= (0xb << (7 * 4));
- /* MISO */
- gpio_init_in(SPI_0_MISO_GPIO, GPIO_NOPULL);
-
- /* SPI init */
- spi_init_master(SPI_0, SPI_CONF_FIRST_RISING, 4500000);
-
- spi_poweron(SPI_0);
-
- /* IRQ0 */
- gpio_init_in(SPI_0_IRQ0_GPIO, GPIO_NOPULL);
- gpio_init_int(SPI_0_IRQ0_GPIO, GPIO_NOPULL, GPIO_RISING, radio_isr);
-
- /* Connect EXTI4 Line to PC4 pin */
- gpio_irq_enable(SPI_0_IRQ0_GPIO);
-
- /* CS */
- gpio_init_out(SPI_0_CS_GPIO, GPIO_NOPULL);
- /* SLEEP */
- gpio_init_out(SPI_0_SLEEP_GPIO, GPIO_NOPULL);
- /* RESET */
- gpio_init_out(SPI_0_RESET_GPIO, GPIO_NOPULL);
-
- // force reset
- RESET_CLR();
- CSn_SET();
- SLEEP_CLR();
-
- for (uint16_t j=0;j<0xFFFF;j++); //small wait
-
- RESET_SET();
- // /* set up GPIO pins */
- // /* SCLK and MOSI*/
- // GPIOA->CRL &= ~(0xf << (5 * 4));
- // GPIOA->CRL |= (0xb << (5 * 4));
- // GPIOA->CRL &= ~(0xf << (7 * 4));
- // GPIOA->CRL |= (0xb << (7 * 4));
- // /* MISO */
- // gpio_init_in(SPI_0_MISO_GPIO, GPIO_NOPULL);
-
- // /* SPI init */
- // spi_init_master(SPI_0, SPI_CONF_FIRST_RISING, 4500000);
-
- // spi_poweron(SPI_0);
-
- // /* IRQ0 */
- // gpio_init_in(SPI_0_IRQ0_GPIO, GPIO_NOPULL);
- // gpio_init_int(SPI_0_IRQ0_GPIO, GPIO_NOPULL, GPIO_RISING, radio_isr);
-
- // /* Connect EXTI4 Line to PC4 pin */
- // gpio_irq_enable(SPI_0_IRQ0_GPIO);
-
- // /* CS */
- // gpio_init_out(SPI_0_CS_GPIO, GPIO_NOPULL);
- // /* SLEEP */
- // gpio_init_out(SPI_0_SLEEP_GPIO, GPIO_NOPULL);
- // /* RESET */
- // gpio_init_out(SPI_0_RESET_GPIO, GPIO_NOPULL);
-
- // /* force reset */
- // RESET_CLR();
- // CSn_SET();
- // SLEEP_CLR();
-
- // vtimer_usleep(AT86RF231_TIMING__RESET);
-
- // RESET_SET();
-
- // /* Wait until TRX_OFF is entered */
- // vtimer_usleep(AT86RF231_TIMING__RESET_TO_TRX_OFF);
-
- // /* Send a FORCE TRX OFF command */
- // at86rf231_reg_write(AT86RF231_REG__TRX_STATE, AT86RF231_TRX_STATE__FORCE_TRX_OFF);
-
- // /* Wait until TRX_OFF state is entered from P_ON */
- // vtimer_usleep(AT86RF231_TIMING__SLEEP_TO_TRX_OFF);
-
- // /* busy wait for TRX_OFF state */
- // uint8_t status;
- // uint8_t max_wait = 100; // TODO : move elsewhere, this is in 10us
-
- // do {
- // status = at86rf231_get_status();
-
- // vtimer_usleep(10);
-
- // if (!--max_wait) {
- // printf("at86rf231 : ERROR : could not enter TRX_OFF mode\n");
- // break;
- // }
- // } while ((status & AT86RF231_TRX_STATUS_MASK__TRX_STATUS)
- // != AT86RF231_TRX_STATUS__TRX_OFF);
-
-}
-
-#ifdef SPI_IN_INTERRUPT_MODE
-void spi_setCallback(spi_cbt cb) {
- spi_vars.callback = cb;
-}
-#endif
-
-void spi_txrx(uint8_t* bufTx,
- uint8_t lenbufTx,
- spi_return_t returnType,
- uint8_t* bufRx,
- uint8_t maxLenBufRx,
- spi_first_t isFirst,
- spi_last_t isLast) {
-
-#ifdef SPI_IN_INTERRUPT_MODE
- // disable interrupts
- NVIC_RESETPRIMASK();
-#endif
-
- // register spi frame to send
- spi_vars.pNextTxByte = bufTx;
- spi_vars.numTxedBytes = 0;
- spi_vars.txBytesLeft = lenbufTx;
- spi_vars.returnType = returnType;
- spi_vars.pNextRxByte = bufRx;
- spi_vars.maxRxBytes = maxLenBufRx;
- spi_vars.isFirst = isFirst;
- spi_vars.isLast = isLast;
-
- // SPI is now busy
- spi_vars.busy = 1;
-
-
- // lower CS signal to have slave listening
- if (spi_vars.isFirst==SPI_FIRST) {
- CSn_CLR();
- }
-
-#ifdef SPI_IN_INTERRUPT_MODE
- // implementation 1. use a callback function when transaction finishes
-
- // write first byte to TX buffer
- SPI_I2S_SendData(SPI1,*spi_vars.pNextTxByte);
-
- // re-enable interrupts
- NVIC_SETPRIMASK();
-#else
- // implementation 2. busy wait for each byte to be sent
- // send all bytes
- while (spi_vars.txBytesLeft>0) {
- // write next byte to TX buffer
- // SPI_I2S_SendData(SPI1,*spi_vars.pNextTxByte);
- spi_transfer_byte(SPI_0, *((char*)spi_vars.pNextTxByte), NULL);
-
- // busy wait on the interrupt flag
-// uint16_t c = 0;
-// while (SPI_I2S_GetFlagStatus(SPI1,SPI_I2S_FLAG_RXNE) == RESET)
-// ;// if (c++ == 10000) {
-// // //DEBUG("spi_txrx timeout\n");
-// // break;
-// // }
-
-// // clear the interrupt flag
-// SPI_I2S_ClearFlag(SPI1, SPI_I2S_FLAG_RXNE);
- // save the byte just received in the RX buffer
- switch (spi_vars.returnType) {
- case SPI_FIRSTBYTE:
- if (spi_vars.numTxedBytes==0) {
- spi_transfer_byte(SPI_0, 0, (char*)spi_vars.pNextRxByte);
- // *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- }
- break;
- case SPI_BUFFER:
- spi_transfer_byte(SPI_0, 0, (char*)spi_vars.pNextRxByte);
- // *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- spi_vars.pNextRxByte++;
- break;
- case SPI_LASTBYTE:
- spi_transfer_byte(SPI_0, 0, (char*)spi_vars.pNextRxByte);
- // *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- break;
- }
- // one byte less to go
- spi_vars.pNextTxByte++;
- spi_vars.numTxedBytes++;
- spi_vars.txBytesLeft--;
- }
-
- // put CS signal high to signal end of transmission to slave
- if (spi_vars.isLast==SPI_LAST) {
- CSn_SET();
- }
-
- // SPI is not busy anymore
- spi_vars.busy = 0;
-#endif
-}
-
-//=========================== private =========================================
-
-//=========================== interrupt handlers ==============================
-
-kick_scheduler_t spi_isr(void) {
-#ifdef SPI_IN_INTERRUPT_MODE
- // save the byte just received in the RX buffer
- switch (spi_vars.returnType) {
- case SPI_FIRSTBYTE:
- if (spi_vars.numTxedBytes==0) {
- *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- }
- break;
- case SPI_BUFFER:
- *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- spi_vars.pNextRxByte++;
- break;
- case SPI_LASTBYTE:
- *spi_vars.pNextRxByte = SPI_I2S_ReceiveData(SPI1);
- break;
- }
-
- // one byte less to go
- spi_vars.pNextTxByte++;
- spi_vars.numTxedBytes++;
- spi_vars.txBytesLeft--;
-
- if (spi_vars.txBytesLeft>0) {
- // write next byte to TX buffer
- SPI_SendData(SPI1,*spi_vars.pNextTxByte);
- } else {
- // put CS signal high to signal end of transmission to slave
- if (spi_vars.isLast==SPI_LAST) {
- GPIO_SetBits(GPIOA, GPIO_Pin_4);
- }
- // SPI is not busy anymore
- spi_vars.busy = 0;
-
- // SPI is done!
- if (spi_vars.callback!=NULL) {
- // call the callback
- spi_vars.callback();
- // kick the OS
- return 1;
- }
- }
-#else
- while(1);// this should never happen
- return 1;
-#endif
-}
\ No newline at end of file
diff --git a/bsp/boards/riot-adaption/uart_ow.c b/bsp/boards/riot-adaption/uart_ow.c
index c2bcb4f..bd62ee6 100644
--- a/bsp/boards/riot-adaption/uart_ow.c
+++ b/bsp/boards/riot-adaption/uart_ow.c
@@ -1,4 +1,4 @@
-#include "uart_ow.h"
+#include "uart.h"
#include "leds.h"
#include "periph/uart.h"
@@ -22,7 +22,7 @@ volatile uart_vars_t uart_vars;
void uart_init_ow(void)
{
// reset local variables
- memset(&uart_vars,0,sizeof(uart_vars_t));
+ memset((void*)&uart_vars,0,sizeof(uart_vars_t));
//when this value is 0, we are send the first data
uart_vars.startOrend = 0;
@@ -76,9 +76,9 @@ void uart_writeByte(uint8_t byteToWrite)
uint8_t uart_readByte(void)
{
- // uint16_t temp;
+ uint16_t temp = 0;
// temp = USART_ReceiveData(USART1);
- // return (uint8_t)temp;
+ return (uint8_t)temp;
}
//=========================== interrupt handlers ==============================
diff --git a/bsp/boards/uart.h b/bsp/boards/uart.h
index 4f02a23..57f93cf 100644
--- a/bsp/boards/uart.h
+++ b/bsp/boards/uart.h
@@ -31,7 +31,7 @@ typedef void (*uart_rx_cbt)(void);
//=========================== prototypes ======================================
-void uart_init(void);
+void uart_init_ow(void);
void uart_setCallbacks(uart_tx_cbt txCb, uart_rx_cbt rxCb);
void uart_enableInterrupts(void);
void uart_disableInterrupts(void);
diff --git a/drivers/common/Makefile b/drivers/common/Makefile
index fbf6584..c703506 100644
--- a/drivers/common/Makefile
+++ b/drivers/common/Makefile
@@ -1,2 +1,8 @@
+INCLUDES += -I$(OPENWSN_ROOT)/openstack/02a-MAClow \
+ -I$(OPENWSN_ROOT)/openstack/02b-MAChigh \
+ -I$(OPENWSN_ROOT)/openstack/03a-IPHC \
+ -I$(OPENWSN_ROOT)/openstack/03b-IPv6 \
+ -I$(OPENWSN_ROOT)/openstack/cross-layers \
+ -I$(CURDIR)
include $(RIOTBASE)/Makefile.base
\ No newline at end of file
diff --git a/drivers/common/openserial.c b/drivers/common/openserial.c
index c54cfff..ebb2743 100644
--- a/drivers/common/openserial.c
+++ b/drivers/common/openserial.c
@@ -1,48 +1,48 @@
-/**
-\brief Definition of the "openserial" driver.
-
-\author Fabien Chraim <chraim@eecs.berkeley.edu>, March 2012.
-*/
-
-#include "opendefs.h"
-#include "openserial.h"
-#include "IEEE802154E.h"
-#include "neighbors.h"
-#include "sixtop.h"
-#include "icmpv6echo.h"
-#include "idmanager.h"
-#include "openqueue.h"
-#include "openbridge.h"
-#include "leds.h"
-#include "schedule.h"
-#include "uart.h"
-#include "opentimers.h"
-#include "openhdlc.h"
-
-//=========================== variables =======================================
-
-openserial_vars_t openserial_vars;
-
-//=========================== prototypes ======================================
-
-owerror_t openserial_printInfoErrorCritical(
- char severity,
- uint8_t calling_component,
- uint8_t error_code,
- errorparameter_t arg1,
- errorparameter_t arg2
-);
-// HDLC output
-void outputHdlcOpen(void);
-void outputHdlcWrite(uint8_t b);
-void outputHdlcClose(void);
-// HDLC input
-void inputHdlcOpen(void);
-void inputHdlcWrite(uint8_t b);
-void inputHdlcClose(void);
-
-//=========================== public ==========================================
-
+/**
+\brief Definition of the "openserial" driver.
+
+\author Fabien Chraim <chraim@eecs.berkeley.edu>, March 2012.
+*/
+
+#include "opendefs.h"
+#include "openserial.h"
+#include "IEEE802154E.h"
+#include "neighbors.h"
+#include "sixtop.h"
+#include "icmpv6echo.h"
+#include "idmanager.h"
+#include "openqueue.h"
+#include "openbridge.h"
+#include "leds.h"
+#include "schedule.h"
+#include "uart.h"
+#include "opentimers.h"
+#include "openhdlc.h"
+
+//=========================== variables =======================================
+
+openserial_vars_t openserial_vars;
+
+//=========================== prototypes ======================================
+
+owerror_t openserial_printInfoErrorCritical(
+ char severity,
+ uint8_t calling_component,
+ uint8_t error_code,
+ errorparameter_t arg1,
+ errorparameter_t arg2
+);
+// HDLC output
+void outputHdlcOpen(void);
+void outputHdlcWrite(uint8_t b);
+void outputHdlcClose(void);
+// HDLC input
+void inputHdlcOpen(void);
+void inputHdlcWrite(uint8_t b);
+void inputHdlcClose(void);
+
+//=========================== public ==========================================
+
void openserial_init(void) {
// uint16_t crc;
@@ -76,9 +76,9 @@ void openserial_init(void) {
// // set callbacks
// uart_setCallbacks(isr_openserial_tx,
// isr_openserial_rx);
-}
-
-owerror_t openserial_printStatus(uint8_t statusElement,uint8_t* buffer, uint8_t length) {
+}
+
+owerror_t openserial_printStatus(uint8_t statusElement,uint8_t* buffer, uint8_t length) {
// uint8_t i;
// INTERRUPT_DECLARATION();
@@ -94,17 +94,17 @@ owerror_t openserial_printStatus(uint8_t statusElement,uint8_t* buffer, uint8_t
// }
// outputHdlcClose();
// ENABLE_INTERRUPTS();
-
- return E_SUCCESS;
-}
-
-owerror_t openserial_printInfoErrorCritical(
- char severity,
- uint8_t calling_component,
- uint8_t error_code,
- errorparameter_t arg1,
- errorparameter_t arg2
- ) {
+
+ return E_SUCCESS;
+}
+
+owerror_t openserial_printInfoErrorCritical(
+ char severity,
+ uint8_t calling_component,
+ uint8_t error_code,
+ errorparameter_t arg1,
+ errorparameter_t arg2
+ ) {
// INTERRUPT_DECLARATION();
// DISABLE_INTERRUPTS();
@@ -121,11 +121,11 @@ owerror_t openserial_printInfoErrorCritical(
// outputHdlcWrite((uint8_t) (arg2 & 0x00ff));
// outputHdlcClose();
// ENABLE_INTERRUPTS();
-
- return E_SUCCESS;
-}
-
-owerror_t openserial_printData(uint8_t* buffer, uint8_t length) {
+
+ return E_SUCCESS;
+}
+
+owerror_t openserial_printData(uint8_t* buffer, uint8_t length) {
// uint8_t i;
// uint8_t asn[5];
// INTERRUPT_DECLARATION();
@@ -149,70 +149,70 @@ owerror_t openserial_printData(uint8_t* buffer, uint8_t length) {
// }
// outputHdlcClose();
// ENABLE_INTERRUPTS();
-
- return E_SUCCESS;
-}
-
-owerror_t openserial_printInfo(uint8_t calling_component, uint8_t error_code,
- errorparameter_t arg1,
- errorparameter_t arg2) {
- return openserial_printInfoErrorCritical(
- SERFRAME_MOTE2PC_INFO,
- calling_component,
- error_code,
- arg1,
- arg2
- );
-}
-
-owerror_t openserial_printError(uint8_t calling_component, uint8_t error_code,
- errorparameter_t arg1,
- errorparameter_t arg2) {
- // blink error LED, this is serious
+
+ return E_SUCCESS;
+}
+
+owerror_t openserial_printInfo(uint8_t calling_component, uint8_t error_code,
+ errorparameter_t arg1,
+ errorparameter_t arg2) {
+ return openserial_printInfoErrorCritical(
+ SERFRAME_MOTE2PC_INFO,
+ calling_component,
+ error_code,
+ arg1,
+ arg2
+ );
+}
+
+owerror_t openserial_printError(uint8_t calling_component, uint8_t error_code,
+ errorparameter_t arg1,
+ errorparameter_t arg2) {
+ // blink error LED, this is serious
// leds_error_toggle();
-
- return openserial_printInfoErrorCritical(
- SERFRAME_MOTE2PC_ERROR,
- calling_component,
- error_code,
- arg1,
- arg2
- );
-}
-
-owerror_t openserial_printCritical(uint8_t calling_component, uint8_t error_code,
- errorparameter_t arg1,
- errorparameter_t arg2) {
- // blink error LED, this is serious
+
+ return openserial_printInfoErrorCritical(
+ SERFRAME_MOTE2PC_ERROR,
+ calling_component,
+ error_code,
+ arg1,
+ arg2
+ );
+}
+
+owerror_t openserial_printCritical(uint8_t calling_component, uint8_t error_code,
+ errorparameter_t arg1,
+ errorparameter_t arg2) {
+ // blink error LED, this is serious
// leds_error_blink();
-
+
// // schedule for the mote to reboot in 10s
// opentimers_start(10000,
// TIMER_ONESHOT,TIME_MS,
// board_reset);
-
- return openserial_printInfoErrorCritical(
- SERFRAME_MOTE2PC_CRITICAL,
- calling_component,
- error_code,
- arg1,
- arg2
- );
-}
-
+
+ return openserial_printInfoErrorCritical(
+ SERFRAME_MOTE2PC_CRITICAL,
+ calling_component,
+ error_code,
+ arg1,
+ arg2
+ );
+}
+
uint8_t openserial_getNumDataBytes(void) {
- uint8_t inputBufFill;
+ uint8_t inputBufFill = 0;
// INTERRUPT_DECLARATION();
-
+
// DISABLE_INTERRUPTS();
// inputBufFill = openserial_vars.inputBufFill;
// ENABLE_INTERRUPTS();
-
- return inputBufFill-1; // removing the command byte
-}
-
-uint8_t openserial_getInputBuffer(uint8_t* bufferToWrite, uint8_t maxNumBytes) {
- uint8_t numBytesWritten;
+
+ return inputBufFill-1; // removing the command byte
+}
+
+uint8_t openserial_getInputBuffer(uint8_t* bufferToWrite, uint8_t maxNumBytes) {
+ uint8_t numBytesWritten = 0;
// uint8_t inputBufFill;
// INTERRUPT_DECLARATION();
@@ -229,10 +229,10 @@ uint8_t openserial_getInputBuffer(uint8_t* bufferToWrite, uint8_t maxNumBytes) {
// numBytesWritten = inputBufFill-1;
// memcpy(bufferToWrite,&(openserial_vars.inputBuf[1]),numBytesWritten);
// }
-
- return numBytesWritten;
-}
-
+
+ return numBytesWritten;
+}
+
void openserial_startInput(void) {
// INTERRUPT_DECLARATION();
@@ -263,8 +263,8 @@ void openserial_startInput(void) {
// uart_writeByte(openserial_vars.reqFrame[openserial_vars.reqFrameIdx]);
// #endif
// ENABLE_INTERRUPTS();
-}
-
+}
+
void openserial_startOutput(void) {
// //schedule a task to get new status in the output buffer
// uint8_t debugPrintCounter;
@@ -347,8 +347,8 @@ void openserial_startOutput(void) {
// openserial_stop();
// }
// ENABLE_INTERRUPTS();
-}
-
+}
+
void openserial_stop(void) {
// uint8_t inputBufFill;
// uint8_t cmdByte;
@@ -405,16 +405,16 @@ void openserial_stop(void) {
// openserial_vars.inputBufFill = 0;
// openserial_vars.busyReceiving = FALSE;
// ENABLE_INTERRUPTS();
-}
-
-/**
-\brief Trigger this module to print status information, over serial.
-
-debugPrint_* functions are used by the openserial module to continuously print
-status information about several modules in the OpenWSN stack.
-
-\returns TRUE if this function printed something, FALSE otherwise.
-*/
+}
+
+/**
+\brief Trigger this module to print status information, over serial.
+
+debugPrint_* functions are used by the openserial module to continuously print
+status information about several modules in the OpenWSN stack.
+
+\returns TRUE if this function printed something, FALSE otherwise.
+*/
bool debugPrint_outBufferIndexes(void) {
// uint16_t temp_buffer[2];
// INTERRUPT_DECLARATION();
@@ -423,72 +423,72 @@ bool debugPrint_outBufferIndexes(void) {
// temp_buffer[1] = openserial_vars.outputBufIdxR;
// ENABLE_INTERRUPTS();
// openserial_printStatus(STATUS_OUTBUFFERINDEXES,(uint8_t*)temp_buffer,sizeof(temp_buffer));
- return TRUE;
-}
-
-//=========================== private =========================================
-
-//===== hdlc (output)
-
-/**
-\brief Start an HDLC frame in the output buffer.
-*/
+ return TRUE;
+}
+
+//=========================== private =========================================
+
+//===== hdlc (output)
+
+/**
+\brief Start an HDLC frame in the output buffer.
+*/
port_INLINE void outputHdlcOpen(void) {
// // initialize the value of the CRC
// openserial_vars.outputCrc = HDLC_CRCINIT;
-
+
// // write the opening HDLC flag
// openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
-}
-/**
-\brief Add a byte to the outgoing HDLC frame being built.
-*/
-port_INLINE void outputHdlcWrite(uint8_t b) {
-
+}
+/**
+\brief Add a byte to the outgoing HDLC frame being built.
+*/
+port_INLINE void outputHdlcWrite(uint8_t b) {
+
// // iterate through CRC calculator
// openserial_vars.outputCrc = crcIteration(openserial_vars.outputCrc,b);
-
+
// // add byte to buffer
// if (b==HDLC_FLAG || b==HDLC_ESCAPE) {
// openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_ESCAPE;
// b = b^HDLC_ESCAPE_MASK;
// }
// openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = b;
-
-}
-/**
-\brief Finalize the outgoing HDLC frame.
-*/
+
+}
+/**
+\brief Finalize the outgoing HDLC frame.
+*/
port_INLINE void outputHdlcClose(void) {
// uint16_t finalCrc;
-
+
// // finalize the calculation of the CRC
// finalCrc = ~openserial_vars.outputCrc;
-
+
// // write the CRC value
// outputHdlcWrite((finalCrc>>0)&0xff);
// outputHdlcWrite((finalCrc>>8)&0xff);
-
+
// // write the closing HDLC flag
// openserial_vars.outputBuf[openserial_vars.outputBufIdxW++] = HDLC_FLAG;
-}
-
-//===== hdlc (input)
-
-/**
-\brief Start an HDLC frame in the input buffer.
-*/
+}
+
+//===== hdlc (input)
+
+/**
+\brief Start an HDLC frame in the input buffer.
+*/
port_INLINE void inputHdlcOpen(void) {
// // reset the input buffer index
// openserial_vars.inputBufFill = 0;
-
+
// // initialize the value of the CRC
// openserial_vars.inputCrc = HDLC_CRCINIT;
-}
-/**
-\brief Add a byte to the incoming HDLC frame.
-*/
-port_INLINE void inputHdlcWrite(uint8_t b) {
+}
+/**
+\brief Add a byte to the incoming HDLC frame.
+*/
+port_INLINE void inputHdlcWrite(uint8_t b) {
// if (b==HDLC_ESCAPE) {
// openserial_vars.inputEscaping = TRUE;
// } else {
@@ -496,37 +496,37 @@ port_INLINE void inputHdlcWrite(uint8_t b) {
// b = b^HDLC_ESCAPE_MASK;
// openserial_vars.inputEscaping = FALSE;
// }
-
+
// // add byte to input buffer
// openserial_vars.inputBuf[openserial_vars.inputBufFill] = b;
// openserial_vars.inputBufFill++;
-
+
// // iterate through CRC calculator
// openserial_vars.inputCrc = crcIteration(openserial_vars.inputCrc,b);
// }
-}
-/**
-\brief Finalize the incoming HDLC frame.
-*/
+}
+/**
+\brief Finalize the incoming HDLC frame.
+*/
port_INLINE void inputHdlcClose(void) {
-
+
// // verify the validity of the frame
// if (openserial_vars.inputCrc==HDLC_CRCGOOD) {
// // the CRC is correct
-
+
// // remove the CRC from the input buffer
// openserial_vars.inputBufFill -= 2;
// } else {
// // the CRC is incorrect
-
+
// // drop the incoming fram
// openserial_vars.inputBufFill = 0;
// }
-}
-
-//=========================== interrupt handlers ==============================
-
-//executed in ISR, called from scheduler.c
+}
+
+//=========================== interrupt handlers ==============================
+
+//executed in ISR, called from scheduler.c
void isr_openserial_tx(void) {
// switch (openserial_vars.mode) {
// case MODE_INPUT:
@@ -547,9 +547,9 @@ void isr_openserial_tx(void) {
// default:
// break;
// }
-}
-
-// executed in ISR, called from scheduler.c
+}
+
+// executed in ISR, called from scheduler.c
void isr_openserial_rx(void) {
// uint8_t rxbyte;
// uint8_t inputBufFill;
@@ -570,13 +570,13 @@ void isr_openserial_rx(void) {
// rxbyte!=HDLC_FLAG
// ) {
// // start of frame
-
+
// // I'm now receiving
// openserial_vars.busyReceiving = TRUE;
-
+
// // create the HDLC frame
// inputHdlcOpen();
-
+
// // add the byte just received
// inputHdlcWrite(rxbyte);
// } else if (
@@ -584,7 +584,7 @@ void isr_openserial_rx(void) {
// rxbyte!=HDLC_FLAG
// ) {
// // middle of frame
-
+
// // add the byte just received
// inputHdlcWrite(rxbyte);
// if (openserial_vars.inputBufFill+1>SERIAL_INPUT_BUFFER_SIZE){
@@ -601,28 +601,28 @@ void isr_openserial_rx(void) {
// rxbyte==HDLC_FLAG
// ) {
// // end of frame
-
+
// // finalize the HDLC frame
// inputHdlcClose();
-
+
// if (openserial_vars.inputBufFill==0){
// // invalid HDLC frame
// openserial_printError(COMPONENT_OPENSERIAL,ERR_WRONG_CRC_INPUT,
// (errorparameter_t)inputBufFill,
// (errorparameter_t)0);
-
+
// }
-
+
// openserial_vars.busyReceiving = FALSE;
// openserial_stop();
// }
-
+
// openserial_vars.lastRxByte = rxbyte;
-}
-
-//======== SERIAL ECHO =============
-
-void openserial_echo(uint8_t* buf, uint8_t bufLen){
+}
+
+//======== SERIAL ECHO =============
+
+void openserial_echo(uint8_t* buf, uint8_t bufLen){
// INTERRUPT_DECLARATION();
// // echo back what you received
// openserial_printData(
@@ -633,4 +633,4 @@ void openserial_echo(uint8_t* buf, uint8_t bufLen){
// DISABLE_INTERRUPTS();
// openserial_vars.inputBufFill = 0;
// ENABLE_INTERRUPTS();
-}
+}
diff --git a/drivers/common/opentimers.c b/drivers/common/opentimers.c
index 5c6ba4f..cd5c550 100644
--- a/drivers/common/opentimers.c
+++ b/drivers/common/opentimers.c
@@ -9,9 +9,12 @@ at most MAX_NUM_TIMERS timers.
#include "opendefs.h"
#include "opentimers.h"
-#include "bsp_timer.h"
+#include "board_ow.h"
#include "leds.h"
+#include "riot.h"
+#include "periph/timer.h"
+
//=========================== define ==========================================
//=========================== variables =======================================
@@ -22,9 +25,19 @@ opentimers_vars_t opentimers_vars;
//=========================== prototypes ======================================
void opentimers_timer_callback(void);
+extern void radiotimer_isr(void);
//=========================== public ==========================================
+void timers_isr(int channel) {
+ if (channel) {
+ radiotimer_isr();
+ }
+ else {
+ opentimers_timer_callback();
+ }
+}
+
/**
\brief Initialize this module.
@@ -45,7 +58,8 @@ void opentimers_init(void) {
}
// set callback for bsp_timers module
- bsp_timer_set_callback(opentimers_timer_callback);
+ // bsp_timer_set_callback(opentimers_timer_callback);
+ timer_init(OWSN_TIMER, 1, &timers_isr);
}
/**
@@ -121,9 +135,13 @@ opentimer_id_t opentimers_start(uint32_t duration, timer_type_t type, time_type_
) {
opentimers_vars.currentTimeout = opentimers_vars.timersBuf[id].ticks_remaining;
if (opentimers_vars.running==FALSE) {
- bsp_timer_reset();
+ // bsp_timer_reset();
+ timer_reset(OWSN_TIMER);
+ timer_set_absolute(OWSN_TIMER, 0, 0);
+ timer_set_absolute(OWSN_TIMER, 1, 0);
}
- bsp_timer_scheduleIn(opentimers_vars.timersBuf[id].ticks_remaining);
+ // bsp_timer_scheduleIn(opentimers_vars.timersBuf[id].ticks_remaining);
+ timer_set(OWSN_TIMER, 0, opentimers_vars.timersBuf[id].ticks_remaining);
}
opentimers_vars.running = TRUE;
@@ -274,7 +292,8 @@ void opentimers_timer_callback(void) {
if (found==TRUE) {
// at least one timer pending
opentimers_vars.currentTimeout = min_timeout;
- bsp_timer_scheduleIn(opentimers_vars.currentTimeout);
+ // bsp_timer_scheduleIn(opentimers_vars.currentTimeout);
+ timer_set(OWSN_TIMER, 0, opentimers_vars.currentTimeout);
} else {
// no more timers pending
opentimers_vars.running = FALSE;
@@ -355,7 +374,8 @@ void opentimers_sleepTimeCompesation(uint16_t sleepTime)
if (found==TRUE) {
// at least one timer pending
opentimers_vars.currentTimeout = min_timeout;
- bsp_timer_scheduleIn(opentimers_vars.currentTimeout);
+ // bsp_timer_scheduleIn(opentimers_vars.currentTimeout);
+ timer_set(OWSN_TIMER, 0, opentimers_vars.currentTimeout);
} else {
// no more timers pending
opentimers_vars.running = FALSE;
diff --git a/kernel/openos/scheduler.c b/kernel/openos/scheduler.c
index 367513c..a5589ff 100644
--- a/kernel/openos/scheduler.c
+++ b/kernel/openos/scheduler.c
@@ -10,6 +10,11 @@
#include "debugpins.h"
#include "leds.h"
+#include "thread.h"
+
+#define ENABLE_DEBUG (0)
+#include "debug.h"
+
//=========================== variables =======================================
scheduler_vars_t scheduler_vars;
@@ -18,14 +23,13 @@ scheduler_dbg_t scheduler_dbg;
//=========================== prototypes ======================================
void consumeTask(uint8_t taskId);
-
-//=========================== public ==========================================
-
+
+//=========================== public ==========================================
+
void scheduler_init(void) {
-
- // initialization module variables
- memset(&scheduler_vars,0,sizeof(scheduler_vars_t));
- memset(&scheduler_dbg,0,sizeof(scheduler_dbg_t));
+ // initialization module variables
+ memset(&scheduler_vars,0,sizeof(scheduler_vars_t));
+ memset(&scheduler_dbg,0,sizeof(scheduler_dbg_t));
// enable the scheduler's interrupt so SW can wake up the scheduler
SCHEDULER_ENABLE_INTERRUPT();
@@ -53,7 +57,8 @@ void scheduler_start(void) {
scheduler_dbg.numTasksCur--;
}
debugpins_task_clr();
- board_sleep();
+ // board_sleep();
+ thread_yield();
debugpins_task_set(); // IAR should halt here if nothing to do
}
}
@@ -63,6 +68,7 @@ void scheduler_start(void) {
taskList_item_t** taskListWalker;
INTERRUPT_DECLARATION();
+ DEBUG("owsn scheduler: push back task %p.\n", (void *)cb);
DISABLE_INTERRUPTS();
// find an empty task container
diff --git a/openapps/Makefile b/openapps/Makefile
index ab615ba..57aa5c8 100644
--- a/openapps/Makefile
+++ b/openapps/Makefile
@@ -2,7 +2,11 @@
DIRS += $(CURDIR)/c6t \
$(CURDIR)/uecho \
- $(CURDIR)/techo
+ $(CURDIR)/techo \
+ $(CURDIR)/cinfo \
+ $(CURDIR)/cleds \
+ $(CURDIR)/cstorm \
+ $(CURDIR)/cwellknown
INCLUDES += -I$(CURDIR)/c6t \
-I$(CURDIR)/techo \
diff --git a/openapps/cstorm/cstorm.c b/openapps/cstorm/cstorm.c
index ffcf106..c0cdcc3 100644
--- a/openapps/cstorm/cstorm.c
+++ b/openapps/cstorm/cstorm.c
@@ -196,7 +196,7 @@ void cstorm_task_cb(void) {
// content-type option
packetfunctions_reserveHeaderSize(pkt,2);
- pkt->payload[0] = (COAP_OPTION_NUM_CONTENTFORMAT-COAP_OPTION_NUM_URIPATH) << 4 | sizeof(cstorm_payload)-1;
+ pkt->payload[0] = (((COAP_OPTION_NUM_CONTENTFORMAT-COAP_OPTION_NUM_URIPATH) << 4) | (sizeof(cstorm_payload)-1));
pkt->payload[1] = COAP_MEDTYPE_APPOCTETSTREAM;
numOptions++;
diff --git a/openapps/uecho/uecho.c b/openapps/uecho/uecho.c
index 1141c51..d98f0fe 100644
--- a/openapps/uecho/uecho.c
+++ b/openapps/uecho/uecho.c
@@ -5,8 +5,13 @@
#include "openserial.h"
#include "packetfunctions.h"
-//=========================== variables =======================================
+#include "riot.h"
+
+#define ENABLE_DEBUG (0)
+#include "debug.h"
+//=========================== variables =======================================
+uint8_t expect_echo;
//=========================== prototypes ======================================
//=========================== public ==========================================
@@ -17,37 +22,43 @@ void uecho_init(void) {
void uecho_receive(OpenQueueEntry_t* request) {
uint16_t temp_l4_destination_port;
OpenQueueEntry_t* reply;
-
- reply = openqueue_getFreePacketBuffer(COMPONENT_UECHO);
- if (reply==NULL) {
- openserial_printError(
- COMPONENT_UECHO,
- ERR_NO_FREE_PACKET_BUFFER,
- (errorparameter_t)0,
- (errorparameter_t)0
- );
- return;
+
+ if (!expect_echo) {
+ reply = openqueue_getFreePacketBuffer(COMPONENT_UECHO);
+ if (reply==NULL) {
+ openserial_printError(
+ COMPONENT_UECHO,
+ ERR_NO_FREE_PACKET_BUFFER,
+ (errorparameter_t)0,
+ (errorparameter_t)0
+ );
+ return;
+ }
+
+ reply->owner = COMPONENT_UECHO;
+
+ // reply with the same OpenQueueEntry_t
+ reply->creator = COMPONENT_UECHO;
+ reply->l4_protocol = IANA_UDP;
+ temp_l4_destination_port = request->l4_destination_port;
+ reply->l4_destination_port = request->l4_sourcePortORicmpv6Type;
+ reply->l4_sourcePortORicmpv6Type = temp_l4_destination_port;
+ reply->l3_destinationAdd.type = ADDR_128B;
+
+ // copy source to destination to echo.
+ memcpy(&reply->l3_destinationAdd.addr_128b[0],&request->l3_sourceAdd.addr_128b[0],16);
+
+ packetfunctions_reserveHeaderSize(reply,request->length);
+ memcpy(&reply->payload[0],&request->payload[0],request->length);
+ openqueue_freePacketBuffer(request);
+
+ if ((openudp_send(reply))==E_FAIL) {
+ openqueue_freePacketBuffer(reply);
+ }
}
-
- reply->owner = COMPONENT_UECHO;
-
- // reply with the same OpenQueueEntry_t
- reply->creator = COMPONENT_UECHO;
- reply->l4_protocol = IANA_UDP;
- temp_l4_destination_port = request->l4_destination_port;
- reply->l4_destination_port = request->l4_sourcePortORicmpv6Type;
- reply->l4_sourcePortORicmpv6Type = temp_l4_destination_port;
- reply->l3_destinationAdd.type = ADDR_128B;
-
- // copy source to destination to echo.
- memcpy(&reply->l3_destinationAdd.addr_128b[0],&request->l3_sourceAdd.addr_128b[0],16);
-
- packetfunctions_reserveHeaderSize(reply,request->length);
- memcpy(&reply->payload[0],&request->payload[0],request->length);
- openqueue_freePacketBuffer(request);
-
- if ((openudp_send(reply))==E_FAIL) {
- openqueue_freePacketBuffer(reply);
+ else {
+ openqueue_freePacketBuffer(request);
+ expect_echo = FALSE;
}
}
@@ -59,4 +70,29 @@ bool uecho_debugPrint(void) {
return FALSE;
}
+void uecho_send(uint8_t *dest_addr)
+{
+ OpenQueueEntry_t *request;
+ request = openqueue_getFreePacketBuffer(COMPONENT_UECHO);
+
+ if (request==NULL) {
+ DEBUG("UECHO: ERROR, no free packet.\n");
+ return;
+ }
+
+ request->owner = COMPONENT_UECHO;
+ request->creator = COMPONENT_UECHO;
+ request->l4_protocol = IANA_UDP;
+ request->l4_destination_port = UDP_PORTS_16b_SRC_16b_DEST_INLINE;
+ request->l4_sourcePortORicmpv6Type = UDP_PORTS_16b_SRC_16b_DEST_INLINE;
+ request->l3_destinationAdd.type = ADDR_128B;
+ memcpy(&(request->l3_destinationAdd.addr_128b[0]), dest_addr, 16);
+
+ packetfunctions_reserveHeaderSize(request, 13);
+ expect_echo = TRUE;
+ if ((openudp_send(request))==E_FAIL) {
+ openqueue_freePacketBuffer(request);
+ }
+}
+
//=========================== private =========================================
\ No newline at end of file
diff --git a/openstack/02a-MAClow/IEEE802154E.c b/openstack/02a-MAClow/IEEE802154E.c
index 461a8bd..c0038a7 100644
--- a/openstack/02a-MAClow/IEEE802154E.c
+++ b/openstack/02a-MAClow/IEEE802154E.c
@@ -16,6 +16,9 @@
#include "adaptive_sync.h"
#include "processIE.h"
+#define ENABLE_DEBUG (0)
+#include "debug.h"
+
//=========================== variables =======================================
ieee154e_vars_t ieee154e_vars;
@@ -1849,9 +1852,11 @@ void changeIsSync(bool newIsSync) {
ieee154e_vars.isSync = newIsSync;
if (ieee154e_vars.isSync==TRUE) {
+ DEBUG("Synced.\n");
leds_sync_on();
resetStats();
} else {
+ DEBUG("Unsynced.\n");
leds_sync_off();
schedule_resetBackoff();
}
diff --git a/openstack/02a-MAClow/IEEE802154E.h b/openstack/02a-MAClow/IEEE802154E.h
index fd3fe17..ef34b71 100644
--- a/openstack/02a-MAClow/IEEE802154E.h
+++ b/openstack/02a-MAClow/IEEE802154E.h
@@ -127,10 +127,10 @@ typedef enum {
// - duration_in_seconds = ticks / 32768
enum ieee154e_atomicdurations_enum {
// time-slot related
- TsTxOffset = 131, // 4000us
- TsLongGT = 43, // 1300us
- TsTxAckDelay = 151, // 4606us
- TsShortGT = 16, // 500us
+ TsTxOffset = 4000, // 4000us
+ TsLongGT = 1300, // 1300us
+ TsTxAckDelay = 4606, // 4606us
+ TsShortGT = 500, // 500us
TsSlotDuration = PORT_TsSlotDuration, // 15000us
// execution speed related
maxTxDataPrepare = PORT_maxTxDataPrepare,
@@ -141,9 +141,9 @@ enum ieee154e_atomicdurations_enum {
delayTx = PORT_delayTx, // between GO signal and SFD
delayRx = PORT_delayRx, // between GO signal and start listening
// radio watchdog
- wdRadioTx = 33, // 1000us (needs to be >delayTx)
- wdDataDuration = 164, // 5000us (measured 4280us with max payload)
- wdAckDuration = 98, // 3000us (measured 1000us)
+ wdRadioTx = 1000, // 1000us (needs to be >delayTx)
+ wdDataDuration = 5000, // 5000us (measured 4280us with max payload)
+ wdAckDuration = 3000, // 3000us (measured 1000us)
};
//shift of bytes in the linkOption bitmap
diff --git a/openstack/02b-MAChigh/schedule.c b/openstack/02b-MAChigh/schedule.c
index fafb6f6..933534f 100644
--- a/openstack/02b-MAChigh/schedule.c
+++ b/openstack/02b-MAChigh/schedule.c
@@ -52,21 +52,21 @@ void schedule_init(void) {
);
running_slotOffset++;
}
-
- // shared TXRX anycast slot(s)
- memset(&temp_neighbor,0,sizeof(temp_neighbor));
- temp_neighbor.type = ADDR_ANYCAST;
- for (i=0;i<NUMSHAREDTXRX;i++) {
- schedule_addActiveSlot(
- running_slotOffset, // slot offset
- CELLTYPE_TXRX, // type of slot
- TRUE, // shared?
- 0, // channel offset
- &temp_neighbor // neighbor
- );
- running_slotOffset++;
- }
-
+
+ // // shared TXRX anycast slot(s)
+ // memset(&temp_neighbor,0,sizeof(temp_neighbor));
+ // temp_neighbor.type = ADDR_ANYCAST;
+ // for (i=0;i<NUMSHAREDTXRX;i++) {
+ // schedule_addActiveSlot(
+ // running_slotOffset, // slot offset
+ // CELLTYPE_TXRX, // type of slot
+ // TRUE, // shared?
+ // 0, // channel offset
+ // &temp_neighbor // neighbor
+ // );
+ // running_slotOffset++;
+ // }
+
// serial RX slot(s)
memset(&temp_neighbor,0,sizeof(temp_neighbor));
schedule_addActiveSlot(
diff --git a/openstack/Makefile b/openstack/Makefile
index 33de77f..5dfd42f 100644
--- a/openstack/Makefile
+++ b/openstack/Makefile
@@ -15,4 +15,6 @@ INCLUDES += -I$(CURDIR)/../drivers/common \
-I$(CURDIR)/04-TRAN \
-I$(CURDIR)/cross-layers
+# CFLAGS += -DDAGROOT
+
include $(RIOTBASE)/Makefile.base
diff --git a/openstack/cross-layers/idmanager.c b/openstack/cross-layers/idmanager.c
index a6f5e2c..1b21536 100644
--- a/openstack/cross-layers/idmanager.c
+++ b/openstack/cross-layers/idmanager.c
@@ -9,24 +9,25 @@
idmanager_vars_t idmanager_vars;
-//=========================== prototypes ======================================
-
-//=========================== public ==========================================
-
-void idmanager_init(void) {
-
- // reset local variables
- memset(&idmanager_vars, 0, sizeof(idmanager_vars_t));
-
- // isDAGroot
-#ifdef DAGROOT
- idmanager_vars.isDAGroot = TRUE;
-#else
- idmanager_vars.isDAGroot = FALSE;
-#endif
-
- // myPANID
- idmanager_vars.myPANID.type = ADDR_PANID;
+//=========================== prototypes ======================================
+
+//=========================== public ==========================================
+// #define DAGROOT
+void idmanager_init(uint8_t role) {
+
+ // reset local variables
+ memset(&idmanager_vars, 0, sizeof(idmanager_vars_t));
+
+ // isDAGroot
+// #ifdef DAGROOT
+// idmanager_vars.isDAGroot = TRUE;
+// #else
+// idmanager_vars.isDAGroot = FALSE;
+// #endif
+ idmanager_vars.isDAGroot = role;
+
+ // myPANID
+ idmanager_vars.myPANID.type = ADDR_PANID;
idmanager_vars.myPANID.panid[0] = 0xca;
idmanager_vars.myPANID.panid[1] = 0xfe;
diff --git a/openstack/cross-layers/idmanager.h b/openstack/cross-layers/idmanager.h
index 26bfc04..a99d8c2 100644
--- a/openstack/cross-layers/idmanager.h
+++ b/openstack/cross-layers/idmanager.h
@@ -42,7 +42,7 @@ typedef struct {
//=========================== prototypes ======================================
-void idmanager_init(void);
+void idmanager_init(uint8_t role);
bool idmanager_getIsDAGroot(void);
void idmanager_setIsDAGroot(bool newRole);
open_addr_t* idmanager_getMyID(uint8_t type);
diff --git a/openstack/openstack.c b/openstack/openstack.c
index cc72deb..3e87a76 100644
--- a/openstack/openstack.c
+++ b/openstack/openstack.c
@@ -36,6 +36,9 @@
//===== applications
#include "openapps.h"
+#define ENABLE_DEBUG (0)
+#include "debug.h"
+
//=========================== variables =======================================
//=========================== prototypes ======================================
@@ -44,14 +47,15 @@
//=========================== private =========================================
-void openstack_init(void) {
+void openstack_init(uint8_t role) {
+ DEBUG("%s\n",__PRETTY_FUNCTION__);
//===== drivers
openserial_init();
//===== stack
//-- cross-layer
- idmanager_init(); // call first since initializes EUI64 and isDAGroot
+ idmanager_init(role); // call first since initializes EUI64 and isDAGroot
openqueue_init();
openrandom_init();
opentimers_init();
diff --git a/openstack/openstack.h b/openstack/openstack.h
index 55042df..bde13b7 100644
--- a/openstack/openstack.h
+++ b/openstack/openstack.h
@@ -17,6 +17,6 @@
//=========================== prototypes ======================================
-void openstack_init(void);
+void openstack_init(uint8_t role);
#endif
diff --git a/projects/common/03oos_openwsn/03oos_openwsn.c b/projects/common/03oos_openwsn/03oos_openwsn.c
index 3f4b36e..70f1750 100644
--- a/projects/common/03oos_openwsn/03oos_openwsn.c
+++ b/projects/common/03oos_openwsn/03oos_openwsn.c
@@ -1,57 +1,67 @@
/**
-\brief This project runs the full OpenWSN stack.
-
-\author Thomas Watteyne <watteyne@eecs.berkeley.edu>, August 2010
-*/
-
+\brief This project runs the full OpenWSN stack.
+
+\author Thomas Watteyne <watteyne@eecs.berkeley.edu>, August 2010
+\author Thomas Eichinger <thomas.eichinger@fu-berlin.de>, December 2014
+*/
+
#include "thread.h"
#include "board_ow.h"
#include "leds.h"
-#include "scheduler.h"
-#include "openstack.h"
-#include "opendefs.h"
-
+#include "scheduler.h"
+#include "openstack.h"
+#include "opendefs.h"
+#include "idmanager.h"
+
#include "03oos_openwsn.h"
+#include "riot.h"
+
#define ENABLE_DEBUG (0)
#include "debug.h"
-static char openwsn_stack[THREAD_STACKSIZE_MAIN];
-int openwsn_pid = -1;
+static char openwsn_stack[THREAD_STACKSIZE_MAIN*2];
+kernel_pid_t openwsn_pid = -1;
+uint8_t owsn_mop;
void openwsn_init(void);
void* openwsn_start(void *arg);
-void openwsn_start_thread(void) {
+void openwsn_start_thread(int argc, char **argv) {
DEBUG("%s\n",__PRETTY_FUNCTION__);
- openwsn_pid = thread_create(openwsn_stack, THREAD_STACKSIZE_MAIN,
- PRIORITY_OPENWSN-2, CREATE_STACKTEST,
- openwsn_start, NULL, "openwsn thread");
+ if (argc < 2) {
+ printf("usage: %s (r|n)\n", argv[0]);
+ puts("\tr\tinitialise as DAGROOT.");
+ puts("\tn\tinitialise as node.");
+ return;
+ }
+
+ char command = argv[1][0];
+ if (command == 'r') {
+ printf("Starting OpenWSN as root ... ");
+ owsn_mop = 1;
+ openwsn_pid = thread_create(openwsn_stack, THREAD_STACKSIZE_MAIN,
+ PRIORITY_OPENWSN, CREATE_STACKTEST,
+ openwsn_start, (void*)&owsn_mop, "openwsn thread");
+ }
+ else {
+ printf("Starting OpenWSN as node ... ");
+ owsn_mop = 0;
+ openwsn_pid = thread_create(openwsn_stack, THREAD_STACKSIZE_MAIN,
+ PRIORITY_OPENWSN, CREATE_STACKTEST,
+ openwsn_start, (void*)&owsn_mop, "openwsn thread");
+ }
}
void* openwsn_start(void *arg) {
DEBUG("%s\n",__PRETTY_FUNCTION__);
- (void)arg;
leds_all_off();
board_init_ow();
scheduler_init();
- openstack_init();
- puts("OpenWSN thread started.");
+ openstack_init(*((uint8_t*)arg));
+ puts("DONE");
scheduler_start();
return NULL;
}
-int mote_main(void) {
-
- // initialize
- board_init();
- scheduler_init();
- openstack_init();
-
- // indicate
-
- // start
- scheduler_start();
- return 0; // this line should never be reached
-}
diff --git a/projects/common/03oos_openwsn/03oos_openwsn.h b/projects/common/03oos_openwsn/03oos_openwsn.h
index 5a9f1fa..8125096 100644
--- a/projects/common/03oos_openwsn/03oos_openwsn.h
+++ b/projects/common/03oos_openwsn/03oos_openwsn.h
@@ -4,10 +4,10 @@
\author Thomas Watteyne <watteyne@eecs.berkeley.edu>, August 2010
*/
-#ifndef __openwsn_H
-#define __openwsn_H
-
-void openwsn_start_thread(void);
+#ifndef __openwsn_H
+#define __openwsn_H
+
+void openwsn_start_thread(int argc, char **argv);
//=========================== define ==========================================
diff --git a/projects/common/03oos_openwsn/Makefile b/projects/common/03oos_openwsn/Makefile
index 47289c6..5ebc02a 100644
--- a/projects/common/03oos_openwsn/Makefile
+++ b/projects/common/03oos_openwsn/Makefile
@@ -1,3 +1,5 @@
#MODULE = openwsn
+INCLUDES += -I$(OPENWSN_ROOT)/openstack/cross-layers
+
include $(RIOTBASE)/Makefile.base
--
2.2.0