]> oss.titaniummirror.com Git - tinyos-2.x.git/commitdiff
patch to fix timesync.receive() bug that returned the wrong length
authorkusy <kusy>
Mon, 30 Nov 2009 21:19:03 +0000 (21:19 +0000)
committerkusy <kusy>
Mon, 30 Nov 2009 21:19:03 +0000 (21:19 +0000)
tos/chips/cc2420/CC2420TimeSyncMessage.h
tos/chips/cc2420/CC2420TimeSyncMessageC.nc
tos/chips/cc2420/CC2420TimeSyncMessageP.nc

index a744fd385bc0972f4f81dfb36ac618a12c8ad4c0..3051750c3a5c32a383076d32b4a9713eaf62b2a6 100644 (file)
 #ifndef __TIMESYNCMESSAGE_H__
 #define __TIMESYNCMESSAGE_H__
 
+#ifndef AM_TIMESYNCMSG
+#define AM_TIMESYNCMSG 0x3D
+#endif
+
 // this value is sent in the air
 typedef nx_uint32_t timesync_radio_t;
 
+typedef struct timesync_footer_t
+{
+       nx_am_id_t type;
+  timesync_radio_t timestamp;
+} timesync_footer_t;
+
+
 #endif//__TIMESYNCMESSAGE_H__
index 94ed0c9ab45e467b32983baf8954fb387530a667..ae8ed312bc82766869b267837292b1a3977e0d5d 100644 (file)
@@ -30,6 +30,7 @@
 
 #include <Timer.h>
 #include <AM.h>
+#include "CC2420TimeSyncMessage.h"
 
 configuration CC2420TimeSyncMessageC
 {
@@ -40,7 +41,9 @@ configuration CC2420TimeSyncMessageC
         interface Receive as Snoop[am_id_t id];
         interface Packet;
         interface AMPacket;
-
+        interface PacketAcknowledgements;
+        interface LowPowerListening;
+    
         interface TimeSyncAMSend<T32khz, uint32_t> as TimeSyncAMSend32khz[am_id_t id];
         interface TimeSyncPacket<T32khz, uint32_t> as TimeSyncPacket32khz;
 
@@ -61,10 +64,10 @@ implementation
 
         Packet = CC2420TimeSyncMessageP;
         // use the AMSenderC infrastructure to avoid concurrent send clashes
-        components AMQueueP, ActiveMessageC;
-        CC2420TimeSyncMessageP.SubSend -> AMQueueP.Send[unique(UQ_AMQUEUE_SEND)];
-        CC2420TimeSyncMessageP.AMPacket -> ActiveMessageC;
-        CC2420TimeSyncMessageP.SubPacket -> ActiveMessageC;
+        components new AMSenderC(AM_TIMESYNCMSG);
+        CC2420TimeSyncMessageP.SubSend -> AMSenderC;
+       CC2420TimeSyncMessageP.SubAMPacket -> AMSenderC;
+        CC2420TimeSyncMessageP.SubPacket -> AMSenderC;
 
         CC2420TimeSyncMessageP.PacketTimeStamp32khz -> CC2420PacketC;
         CC2420TimeSyncMessageP.PacketTimeStampMilli -> CC2420PacketC;
@@ -75,8 +78,14 @@ implementation
         CC2420TimeSyncMessageP.LocalTimeMilli -> LocalTimeMilliC;
         CC2420TimeSyncMessageP.Leds -> LedsC;
 
+        components ActiveMessageC;
         SplitControl = CC2420ActiveMessageC;
-        Receive = CC2420ActiveMessageC.Receive;
-        Snoop = CC2420ActiveMessageC.Snoop;
-        AMPacket = CC2420ActiveMessageC;
+        PacketAcknowledgements = CC2420ActiveMessageC;
+        LowPowerListening = CC2420ActiveMessageC;
+        
+        Receive = CC2420TimeSyncMessageP.Receive;
+        Snoop = CC2420TimeSyncMessageP.Snoop;
+        AMPacket = CC2420TimeSyncMessageP;
+        CC2420TimeSyncMessageP.SubReceive -> ActiveMessageC.Receive[AM_TIMESYNCMSG];
+        CC2420TimeSyncMessageP.SubSnoop -> ActiveMessageC.Snoop[AM_TIMESYNCMSG];
 }
index 70e677ae111f712854dcd52c38f6389cdf143740..446a48fb4283207ea2e542dd160d5f7b5b8a0226 100644 (file)
@@ -30,16 +30,23 @@ module CC2420TimeSyncMessageP
         interface TimeSyncAMSend<T32khz, uint32_t> as TimeSyncAMSend32khz[uint8_t id];
         interface TimeSyncAMSend<TMilli, uint32_t> as TimeSyncAMSendMilli[uint8_t id];
         interface Packet;
+        interface AMPacket;
 
         interface TimeSyncPacket<T32khz, uint32_t> as TimeSyncPacket32khz;
         interface TimeSyncPacket<TMilli, uint32_t> as TimeSyncPacketMilli;
+        
+        interface Receive[am_id_t id];
+        interface Receive as Snoop[am_id_t id];
     }
 
     uses
     {
-        interface Send as SubSend;
-        interface AMPacket;
+          interface AMSend as SubSend;
         interface Packet as SubPacket;
+        interface AMPacket as SubAMPacket;
+
+        interface Receive as SubReceive;
+        interface Receive as SubSnoop;
 
         interface PacketTimeStamp<T32khz,uint32_t> as PacketTimeStamp32khz;
         interface PacketTimeStamp<TMilli,uint32_t> as PacketTimeStampMilli;
@@ -54,10 +61,10 @@ module CC2420TimeSyncMessageP
 implementation
 {
     // TODO: change the Packet.payloadLength and Packet.maxPayloadLength commands to async
-    inline void* getFooter(message_t* msg)
+    inline timesync_footer_t* getFooter(message_t* msg)
     {
         // we use the payload length that we export (the smaller one)
-        return msg->data + call Packet.payloadLength(msg);
+        return (timesync_footer_t*)(msg->data + call Packet.payloadLength(msg));
     }
 
 /*----------------- Packet -----------------*/
@@ -69,34 +76,90 @@ implementation
 
     command void Packet.setPayloadLength(message_t* msg, uint8_t len)
     {
-        call SubPacket.setPayloadLength(msg, len + sizeof(timesync_radio_t));
+        call SubPacket.setPayloadLength(msg, len + sizeof(timesync_footer_t));
     }
 
     command uint8_t Packet.payloadLength(message_t* msg)
     {
-        return call SubPacket.payloadLength(msg) - sizeof(timesync_radio_t);
+        return call SubPacket.payloadLength(msg) - sizeof(timesync_footer_t);
     }
 
     command uint8_t Packet.maxPayloadLength()
     {
-        return call SubPacket.maxPayloadLength() - sizeof(timesync_radio_t);
+        return call SubPacket.maxPayloadLength() - sizeof(timesync_footer_t);
     }
 
     command void* Packet.getPayload(message_t* msg, uint8_t len)
     {
-        return call SubPacket.getPayload(msg, len + sizeof(timesync_radio_t));
+        return call SubPacket.getPayload(msg, len + sizeof(timesync_footer_t));
     }
 
+/*----------------- AMPacket -----------------*/
+
+       inline command am_addr_t AMPacket.address()
+       {
+               return call SubAMPacket.address();
+       }
+
+       inline command am_group_t AMPacket.localGroup()
+       {
+               return call SubAMPacket.localGroup();
+       }
+
+       inline command bool AMPacket.isForMe(message_t* msg)
+       {
+               return call SubAMPacket.isForMe(msg) && call SubAMPacket.type(msg) == AM_TIMESYNCMSG;
+       }
+
+       inline command am_addr_t AMPacket.destination(message_t* msg)
+       {
+               return call SubAMPacket.destination(msg);
+       }
+
+       inline command void AMPacket.setDestination(message_t* msg, am_addr_t addr)
+       {
+               call SubAMPacket.setDestination(msg, addr);
+       }
+
+       inline command am_addr_t AMPacket.source(message_t* msg)
+       {
+               return call SubAMPacket.source(msg);
+       }
+
+       inline command void AMPacket.setSource(message_t* msg, am_addr_t addr)
+       {
+               call SubAMPacket.setSource(msg, addr);
+       }
+
+       inline command am_id_t AMPacket.type(message_t* msg)
+       {
+               return getFooter(msg)->type;
+       }
+
+       inline command void AMPacket.setType(message_t* msg, am_id_t type)
+       {
+               getFooter(msg)->type = type;
+       }
+
+       inline command am_group_t AMPacket.group(message_t* msg)
+       {
+               return call SubAMPacket.group(msg);
+       }
+
+       inline command void AMPacket.setGroup(message_t* msg, am_group_t grp)
+       {
+               call SubAMPacket.setGroup(msg, grp);
+       }
+
 /*----------------- TimeSyncAMSend32khz -----------------*/
     command error_t TimeSyncAMSend32khz.send[am_id_t id](am_addr_t addr, message_t* msg, uint8_t len, uint32_t event_time)
     {
         error_t err;
-        void * timesync = msg->data + len;
-        *(timesync_radio_t*)timesync = event_time;
+        timesync_footer_t* footer = (timesync_footer_t*)(msg->data + len);
+        footer->type = id;
+        footer->timestamp = event_time;
 
-        call AMPacket.setDestination(msg, addr);
-        call AMPacket.setType(msg, id);
-        err = call SubSend.send(msg, len + sizeof(timesync_radio_t));
+        err = call SubSend.send(addr, msg, len + sizeof(timesync_footer_t));
         call PacketTimeSyncOffset.set(msg);
         return err;
     }
@@ -111,12 +174,12 @@ implementation
 
     command uint8_t TimeSyncAMSend32khz.maxPayloadLength[am_id_t id]()
     {
-        return call SubSend.maxPayloadLength() - sizeof(timesync_radio_t);
+        return call SubSend.maxPayloadLength() - sizeof(timesync_footer_t);
     }
 
     command void* TimeSyncAMSend32khz.getPayload[am_id_t id](message_t* msg, uint8_t len)
     {
-        return call SubSend.getPayload(msg, len + sizeof(timesync_radio_t));
+        return call SubSend.getPayload(msg, len + sizeof(timesync_footer_t));
     }
 
 /*----------------- TimeSyncAMSendMilli -----------------*/
@@ -144,6 +207,26 @@ implementation
         return call TimeSyncAMSend32khz.getPayload[id](msg, len);
     }
 
+/*----------------- SubReceive -------------------*/
+
+    event message_t* SubReceive.receive(message_t* msg, void* payload, uint8_t len)
+    {
+        am_id_t id = call AMPacket.type(msg);
+        return signal Receive.receive[id](msg, payload, len - sizeof(timesync_footer_t));
+    }
+
+    default event message_t* Receive.receive[am_id_t id](message_t* msg, void* payload, uint8_t len) { return msg; }
+
+/*----------------- SubSnoop -------------------*/
+
+    event message_t* SubSnoop.receive(message_t* msg, void* payload, uint8_t len)
+    {
+        am_id_t id = call AMPacket.type(msg);
+        return signal Snoop.receive[id](msg, payload, len - sizeof(timesync_footer_t));
+    }
+
+    default event message_t* Snoop.receive[am_id_t id](message_t* msg, void* payload, uint8_t len) { return msg; }
+
 /*----------------- SubSend.sendDone -------------------*/
     event void SubSend.sendDone(message_t* msg, error_t error)
     {
@@ -155,27 +238,22 @@ implementation
 /*----------------- TimeSyncPacket32khz -----------------*/
     command bool TimeSyncPacket32khz.isValid(message_t* msg)
     {
-        timesync_radio_t* timesync = getFooter(msg);
-        return call PacketTimeStamp32khz.isValid(msg) && *timesync != CC2420_INVALID_TIMESTAMP;
+        return call PacketTimeStamp32khz.isValid(msg) && getFooter(msg)->timestamp != CC2420_INVALID_TIMESTAMP;
     }
 
     command uint32_t TimeSyncPacket32khz.eventTime(message_t* msg)
     {
-        timesync_radio_t* timesync = getFooter(msg);
-
-        return (uint32_t)(*timesync) + call PacketTimeStamp32khz.timestamp(msg);
+        return (uint32_t)(getFooter(msg)->timestamp) + call PacketTimeStamp32khz.timestamp(msg);
     }
 
 /*----------------- TimeSyncPacketMilli -----------------*/
     command bool TimeSyncPacketMilli.isValid(message_t* msg)
     {
-        timesync_radio_t* timesync = getFooter(msg);
-        return call PacketTimeStampMilli.isValid(msg) && *timesync != CC2420_INVALID_TIMESTAMP;
+        return call PacketTimeStampMilli.isValid(msg) && getFooter(msg)->timestamp != CC2420_INVALID_TIMESTAMP;
     }
 
     command uint32_t TimeSyncPacketMilli.eventTime(message_t* msg)
     {
-        timesync_radio_t* timesync = getFooter(msg);
-        return ((int32_t)(*timesync) >> 5) + call PacketTimeStampMilli.timestamp(msg);
+        return ((int32_t)(getFooter(msg)->timestamp) >> 5) + call PacketTimeStampMilli.timestamp(msg);
     }
 }