interface FrameTx as CfpTx;
interface Purge;
} uses {
- interface ResourceTransferred as TokenTransferred;
- interface ResourceTransfer as TokenToBeaconTransmit;
- interface ResourceRequested as TokenRequested;
+ interface TransferableResource as RadioToken;
interface Alarm<TSymbolIEEE802154,uint32_t> as CfpSlotAlarm;
interface Alarm<TSymbolIEEE802154,uint32_t> as CfpEndAlarm;
interface SuperframeStructure as OutgoingSF;
return IEEE154_INVALID_HANDLE;
}
- async event void TokenTransferred.transferred()
+ async event void RadioToken.transferredFrom(uint8_t fromClient)
{
// the CFP has started, this component now owns the token -
- // because GTS is not implemented we pass it back to the
- // BeaconTransmitP component
- call TokenToBeaconTransmit.transfer();
+ // because GTS is not implemented we pass it on
+#ifndef IEEE154_BEACON_SYNC_DISABLED
+ call RadioToken.transferTo(RADIO_CLIENT_BEACONSYNCHRONIZE);
+#else
+ call RadioToken.transferTo(RADIO_CLIENT_BEACONTRANSMIT);
+#endif
}
async event void CfpEndAlarm.fired() {}
async event void RadioRx.enableRxDone(){}
event message_t* RadioRx.received(message_t *frame, const ieee154_timestamp_t *timestamp){return frame;}
- async event void TokenRequested.requested()
+ event void RadioToken.granted()
{
- // someone (e.g. SCAN component) requested access to the radio, we
- // should pass the token back to BeaconTransmitP, which can release it
- // call TokenToBeaconTransmit.transfer();
- }
-
- async event void TokenRequested.immediateRequested(){ }
+ ASSERT(0); // should never happen, because we never call RadioToken.request()
+ }
}