]> oss.titaniummirror.com Git - tinyos-2.x.git/blobdiff - tos/chips/rf2xx/rf212/RF212ActiveMessageC.nc
support ActiveMessageC and Ieee154MessageC simultaneously
[tinyos-2.x.git] / tos / chips / rf2xx / rf212 / RF212ActiveMessageC.nc
index 18ffdf6a2535c389b1c2e21a13ff43a6356be47d..10f7c5fa7a95126233958210861e33844e650fdb 100644 (file)
 
 #include <RadioConfig.h>
 
+#ifdef IEEE154FRAMES_ENABLED
+#error "You cannot use ActiveMessageC with IEEE154FRAMES_ENABLED defined"
+#endif
+
 configuration RF212ActiveMessageC
 {
        provides 
@@ -32,12 +36,13 @@ configuration RF212ActiveMessageC
                interface AMSend[am_id_t id];
                interface Receive[am_id_t id];
                interface Receive as Snoop[am_id_t id];
+               interface SendNotifier[am_id_t id];
 
                interface Packet;
                interface AMPacket;
+
                interface PacketAcknowledgements;
                interface LowPowerListening;
-
 #ifdef PACKET_LINK
                interface PacketLink;
 #endif
@@ -56,145 +61,31 @@ configuration RF212ActiveMessageC
 
 implementation
 {
-       components RF212ActiveMessageP, RadioAlarmC;
-
-#ifdef RADIO_DEBUG
-       components AssertC;
-#endif
-
-       RF212ActiveMessageP.IEEE154MessageLayer -> IEEE154MessageLayerC;
-       RF212ActiveMessageP.RadioAlarm -> RadioAlarmC.RadioAlarm[unique("RadioAlarm")];
-       RF212ActiveMessageP.PacketTimeStamp -> TimeStampingLayerC;
-       Packet = RF212ActiveMessageP;
-
-// -------- Active Message
-
-       components ActiveMessageLayerC;
-       ActiveMessageLayerC.Config -> RF212ActiveMessageP;
-       ActiveMessageLayerC.SubSend -> LowpanNetworkLayerC;
-       ActiveMessageLayerC.SubReceive -> LowpanNetworkLayerC;
-       AMSend = ActiveMessageLayerC;
-       Receive = ActiveMessageLayerC.Receive;
-       Snoop = ActiveMessageLayerC.Snoop;
-       AMPacket = ActiveMessageLayerC;
-
-// -------- Lowpan Network
-
-#ifdef TFRAMES_ENABLED
-       components new DummyLayerC() as LowpanNetworkLayerC;
-#else
-       components LowpanNetworkLayerC;
-       LowpanNetworkLayerC.Config -> RF212ActiveMessageP;
-#endif
-       LowpanNetworkLayerC.SubSend -> UniqueLayerC;
-       LowpanNetworkLayerC.SubReceive -> LowPowerListeningLayerC;
+       components RF212RadioC;
 
-// -------- IEEE154 Packet
+       SplitControl = RF212RadioC;
 
-       components IEEE154MessageLayerC;
-       IEEE154MessageLayerC.Config -> RF212ActiveMessageP;
+       AMSend = RF212RadioC;
+       Receive = RF212RadioC.Receive;
+       Snoop = RF212RadioC.Snoop;
+       SendNotifier = RF212RadioC;
 
-// -------- UniqueLayer Send part (wired twice)
-
-       components UniqueLayerC;
-       UniqueLayerC.Config -> RF212ActiveMessageP;
-       UniqueLayerC.SubSend -> LowPowerListeningLayerC;
-
-// -------- Low Power Listening 
-
-#ifdef LOW_POWER_LISTENING
-       components LowPowerListeningLayerC;
-       LowPowerListeningLayerC.Config -> RF212ActiveMessageP;
-       LowPowerListeningLayerC.PacketAcknowledgements -> SoftwareAckLayerC;
-#else  
-       components LowPowerListeningDummyC as LowPowerListeningLayerC;
-#endif
-       LowPowerListeningLayerC.SubControl -> MessageBufferLayerC;
-       LowPowerListeningLayerC.SubSend -> PacketLinkLayerC;
-       LowPowerListeningLayerC.SubReceive -> MessageBufferLayerC;
-       SplitControl = LowPowerListeningLayerC;
-       LowPowerListening = LowPowerListeningLayerC;
-
-// -------- Packet Link
+       Packet = RF212RadioC.PacketForActiveMessage;
+       AMPacket = RF212RadioC;
 
+       PacketAcknowledgements = RF212RadioC;
+       LowPowerListening = RF212RadioC;
 #ifdef PACKET_LINK
-       components PacketLinkLayerC;
-       PacketLink = PacketLinkLayerC;
-       PacketLinkLayerC.PacketLinkMetadata -> RF212ActiveMessageP;
-       PacketLinkLayerC.PacketAcknowledgements -> SoftwareAckLayerC;
-#else
-       components new DummyLayerC() as PacketLinkLayerC;
+       PacketLink = RF212RadioC;
 #endif
-       PacketLinkLayerC.SubSend -> MessageBufferLayerC;
-
-// -------- MessageBuffer
-
-       components MessageBufferLayerC;
-       MessageBufferLayerC.Packet -> RF212ActiveMessageP;
-       MessageBufferLayerC.RadioSend -> TrafficMonitorLayerC;
-       MessageBufferLayerC.RadioReceive -> UniqueLayerC;
-       MessageBufferLayerC.RadioState -> TrafficMonitorLayerC;
-       RadioChannel = MessageBufferLayerC;
-
-// -------- UniqueLayer receive part (wired twice)
-
-       UniqueLayerC.SubReceive -> TrafficMonitorLayerC;
-
-// -------- Traffic Monitor
-
-       components TrafficMonitorLayerC;
-       TrafficMonitorLayerC.Config -> RF212ActiveMessageP;
-       TrafficMonitorLayerC.SubSend -> CollisionAvoidanceLayerC;
-       TrafficMonitorLayerC.SubReceive -> CollisionAvoidanceLayerC;
-       TrafficMonitorLayerC.SubState -> RF212DriverLayerC;
-
-// -------- CollisionAvoidance
-
-#ifdef SLOTTED_MAC
-       components SlottedCollisionLayerC as CollisionAvoidanceLayerC;
-#else
-       components RandomCollisionLayerC as CollisionAvoidanceLayerC;
-#endif
-       CollisionAvoidanceLayerC.Config -> RF212ActiveMessageP;
-       CollisionAvoidanceLayerC.SubSend -> SoftwareAckLayerC;
-       CollisionAvoidanceLayerC.SubReceive -> SoftwareAckLayerC;
-
-// -------- SoftwareAcknowledgement
-
-       components SoftwareAckLayerC;
-       SoftwareAckLayerC.Config -> RF212ActiveMessageP;
-       SoftwareAckLayerC.SubSend -> CsmaLayerC;
-       SoftwareAckLayerC.SubReceive -> RF212DriverLayerC;
-       PacketAcknowledgements = SoftwareAckLayerC;
-
-// -------- Carrier Sense
-
-       components new DummyLayerC() as CsmaLayerC;
-       CsmaLayerC.Config -> RF212ActiveMessageP;
-       CsmaLayerC -> RF212DriverLayerC.RadioSend;
-       CsmaLayerC -> RF212DriverLayerC.RadioCCA;
-
-// -------- RF212 Driver
-
-       components RF212DriverLayerC;
-       RF212DriverLayerC.PacketRF212Metadata -> RF212ActiveMessageP;
-       RF212DriverLayerC.RF212DriverConfig -> RF212ActiveMessageP;
-       RF212DriverLayerC.PacketTimeStamp -> TimeStampingLayerC;
-       PacketTransmitPower = RF212DriverLayerC.PacketTransmitPower;
-       PacketLinkQuality = RF212DriverLayerC.PacketLinkQuality;
-       PacketRSSI = RF212DriverLayerC.PacketRSSI;
-       LocalTimeRadio = RF212DriverLayerC;
-
-// -------- MetadataFlags
 
-       components MetadataFlagsLayerC;
-       MetadataFlagsLayerC.PacketFlagsMetadata -> RF212ActiveMessageP;
+       RadioChannel = RF212RadioC;
 
-// -------- TimeStamping
+       PacketLinkQuality = RF212RadioC.PacketLinkQuality;
+       PacketTransmitPower = RF212RadioC.PacketTransmitPower;
+       PacketRSSI = RF212RadioC.PacketRSSI;
 
-       components TimeStampingLayerC;
-       TimeStampingLayerC.LocalTimeRadio -> RF212DriverLayerC;
-       TimeStampingLayerC.PacketTimeStampMetadata -> RF212ActiveMessageP;
-       PacketTimeStampRadio = TimeStampingLayerC;
-       PacketTimeStampMilli = TimeStampingLayerC;
+       LocalTimeRadio = RF212RadioC;
+       PacketTimeStampMilli = RF212RadioC;
+       PacketTimeStampRadio = RF212RadioC;
 }