]> oss.titaniummirror.com Git - tinyos-2.x.git/blobdiff - tos/chips/cc2420/packet/CC2420PacketC.nc
Merge TinyOS 2.1.1 into master.
[tinyos-2.x.git] / tos / chips / cc2420 / packet / CC2420PacketC.nc
index a1ef8065ac342b78a164b3476dc5bfb065aaaf9a..9e3415546b1c8d1efb0811ab236f04383d77f9ee 100644 (file)
  * @author Chad Metcalf
  */
 
-#include "IEEE802154.h"
-#include "message.h"
-
-module CC2420PacketC {
+configuration CC2420PacketC {
 
   provides {
     interface CC2420Packet;
     interface PacketAcknowledgements as Acks;
     interface CC2420PacketBody;
+    interface LinkPacketMetadata;
+
+    interface PacketTimeStamp<T32khz, uint32_t> as PacketTimeStamp32khz;
+    interface PacketTimeStamp<TMilli, uint32_t> as PacketTimeStampMilli;
+    interface PacketTimeSyncOffset;
   }
 
 }
 
 implementation {
-
-
-  /***************** PacketAcknowledgement Commands ****************/
-  async command error_t Acks.requestAck( message_t* p_msg ) {
-    (call CC2420PacketBody.getHeader( p_msg ))->fcf |= 1 << IEEE154_FCF_ACK_REQ;
-    return SUCCESS;
-  }
-
-  async command error_t Acks.noAck( message_t* p_msg ) {
-    (call CC2420PacketBody.getHeader( p_msg ))->fcf &= ~(1 << IEEE154_FCF_ACK_REQ);
-    return SUCCESS;
-  }
-
-  async command bool Acks.wasAcked( message_t* p_msg ) {
-    return (call CC2420PacketBody.getMetadata( p_msg ))->ack;
-  }
-
-  /***************** CC2420Packet Commands ****************/
-  async command void CC2420Packet.setPower( message_t* p_msg, uint8_t power ) {
-    if ( power > 31 )
-      power = 31;
-    (call CC2420PacketBody.getMetadata( p_msg ))->tx_power = power;
-  }
-
-  async command uint8_t CC2420Packet.getPower( message_t* p_msg ) {
-    return (call CC2420PacketBody.getMetadata( p_msg ))->tx_power;
-  }
-   
-  async command int8_t CC2420Packet.getRssi( message_t* p_msg ) {
-    return (call CC2420PacketBody.getMetadata( p_msg ))->rssi;
-  }
-
-  async command uint8_t CC2420Packet.getLqi( message_t* p_msg ) {
-    return (call CC2420PacketBody.getMetadata( p_msg ))->lqi;
-  }
-
-  /***************** CC2420PacketBody Commands ****************/
-  async command cc2420_header_t *CC2420PacketBody.getHeader( message_t* msg ) {
-    return (cc2420_header_t*)( msg->data - sizeof( cc2420_header_t ) );
-  }
-
-  async command cc2420_metadata_t *CC2420PacketBody.getMetadata( message_t* msg ) {
-    return (cc2420_metadata_t*)msg->metadata;
-  }
-
+  components CC2420PacketP;
+  CC2420Packet         = CC2420PacketP;
+  Acks                 = CC2420PacketP;
+  CC2420PacketBody     = CC2420PacketP;
+  LinkPacketMetadata   = CC2420PacketP;
+  PacketTimeStamp32khz = CC2420PacketP;
+  PacketTimeStampMilli = CC2420PacketP;
+  PacketTimeSyncOffset = CC2420PacketP;
+
+  components Counter32khz32C, new CounterToLocalTimeC(T32khz);
+  CounterToLocalTimeC.Counter -> Counter32khz32C;
+  CC2420PacketP.LocalTime32khz -> CounterToLocalTimeC;
+
+  //DummyTimer is introduced to compile apps that use no timers
+  components HilTimerMilliC, new TimerMilliC() as DummyTimer;
+  CC2420PacketP.LocalTimeMilli -> HilTimerMilliC;
 }