A library implementing IEEE 802.15.4 PHY functionality for the MCR20A transceiver. The PHY sublayer provides two services: the PHY data service and the PHY management service interfacing to the PHY sublayer management entity (PLME) service access point (SAP) (known as PLME-SAP). The PHY data service enables the transmission and reception of PHY protocol data units (PSDUs) over the media (radio).
Fork of fsl_phy_mcr20a by
The Freescale PHY Layer deals with the physical burst which is to be sent and/or received. It performs modulation and demodulation, transmitter and receiver switching, fragmentation, scrambling, interleaving, and error correction coding. The communication to the upper protocol layers is carried out through the Layer 1 Interface.
The PHY Layer is capable of executing the following sequences:
- I (Idle)
- R (Receive Sequence conditionally followed by a TxAck)
- T (Transmit Sequence)
- C (Standalone CCA)
- CCCA (Continuous CCA)
- TR (Transmit/Receive Sequence - transmit unconditionally followed by either an R or RxAck)
In addition to these sequences the PHY Layer also integrates a packet processor which determines whether the packet is MAC-compliant, and if it is, whether it is addressed to the end device. Another feature of the packet processor is Source Address Matching which can be viewed as an extension of packet filtering; however its function is very specific to its intended application (data-polling and indirect queue management by a PAN Coordinator).
Documentation
Diff: PHY/PhyDebug.h
- Revision:
- 0:764779eedf2d
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/PHY/PhyDebug.h Tue Aug 18 12:41:42 2015 +0000 @@ -0,0 +1,145 @@ +/*! +* Copyright (c) 2015, Freescale Semiconductor, Inc. +* All rights reserved. +* +* \file PhyDebug.h +* +* Redistribution and use in source and binary forms, with or without modification, +* are permitted provided that the following conditions are met: +* +* o Redistributions of source code must retain the above copyright notice, this list +* of conditions and the following disclaimer. +* +* o Redistributions in binary form must reproduce the above copyright notice, this +* list of conditions and the following disclaimer in the documentation and/or +* other materials provided with the distribution. +* +* o Neither the name of Freescale Semiconductor, Inc. nor the names of its +* contributors may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR +* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON +* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ + +#ifndef _PHY_DEBUG_H_ +#define _PHY_DEBUG_H_ + + +/************************************************************************************ +************************************************************************************* +* Includes +************************************************************************************* +************************************************************************************/ +//#include "MacPhyDebug.h" + + +// a value of zero disables the logging of that event +#define PDBG_SET_EVENT_TRIGGER 0x01 // 2 parameters +#define PDBG_SET_EVENT_TIMEOUT 0x02 // 3 parameters +#define PDBG_DISABLE_EVENT_TIMEOUT 0x03 +#define PDBG_READ_CLOCK 0x04 +#define PDBG_INIT_EVENT_TIMER 0 + +#define PDBG_WTRMRK_VECT_INTERRUPT 0x06 +#define PDBG_TIMERS_VECT_INTERRUPT 0x07 +#define PDBG_TX_VECT_INTERRUPT 0x08 +#define PDBG_RX_VECT_INTERRUPT 0x09 + +#define PDBG_CCA_CONFIRM_IDLE 0x0A +#define PDBG_CCA_CONFIRM_BUSY 0x0B +#define PDBG_DATA_CONFIRM 0x0C +#define PDBG_DATA_INDICATION 0x0D +#define PDBG_ED_CONFIRM 0x0E +#define PDBG_SYNC_LOSS_INDICATION 0x0F + +#define PDBG_UNLOCK_IRQ 0x10 +#define PDBG_WTRMARK_IRQ 0x11 +#define PDBG_START_INDICATION 0x12 +#define PDBG_TIMEOUT_INDICATION 0x13 +#define PDBG_TMR1_IRQ 0x14 +#define PDBG_TMR4_IRQ 0x15 +#define PDBG_FILTER_FAIL_IRQ 0x16 +#define PDBG_TX_IRQ 0x17 +#define PDBG_RX_IRQ 0x18 // 1 parameter +#define PDBG_CCA_IRQ 0x19 +#define PDBG_SEQ_IRQ 0x1A // 1 parameter + +#define PDBG_PHY_INIT 0x20 +#define PDBG_PHY_ABORT 0x21 +#define PDBG_PP_SET_PROMISC 0 +#define PDBG_PP_SET_PANID_PAN0 0x23 +#define PDBG_PP_SET_SHORTADDR_PAN0 0x24 +#define PDBG_PP_SET_LONGADDR_PAN0 0x25 +#define PDBG_PP_SET_MACROLE_PAN0 0x26 +#define PDBG_PP_ADD_INDIRECT 0x27 // 1 parameter +#define PDBG_PP_REMOVE_INDIRECT 0x28 // 1 parameter +#define PDBG_PP_READ_LATEST_INDEX 0x29 // 1 parameter + +#define PDBG_DATA_REQUEST 0x30 +#define PDBG_PLME_RX_REQUEST 0x31 +#define PDBG_PLME_CCA_ED_REQUEST 0x32 +#define PDBG_PLME_SET_CHAN_REQUEST 0x33 +#define PDBG_PLME_SET_POWER_REQUEST 0x34 +#define PDBG_PLME_WAIT_REQUEST 0x35 + +#define PDBG_PP_SET_PANID_PAN1 0x36 +#define PDBG_PP_SET_SHORTADDR_PAN1 0x37 +#define PDBG_PP_SET_LONGADDR_PAN1 0x38 +#define PDBG_PP_SET_MACROLE_PAN1 0x39 + +//simple events - without timestamp +//***** PDBG_MAC_FUNCTION_CALL PDBG_SIMPLE_EVENT // 3 parameters +#define PDBG_READ_FSM PDBG_SIMPLE_EVENT + 0x01 // 1 parameter +#define PDBG_FILTER_FAIL_CODE PDBG_SIMPLE_EVENT + 0x02 // 2 parameters + + +#ifdef MAC_PHY_DEBUG + +#define DEBUG_LOG_ENTRIES 768 + +#define PHY_DEBUG_LOG(item) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogTime(item);} +#define PHY_DEBUG_LOG1(item,param) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogTime(PDBG_EXTENDED_EVENT | item);PhyDebugLogParam1(item,param);} +#define PHY_DEBUG_LOG2(item,param1,param2) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogTime(PDBG_EXTENDED_EVENT | item);PhyDebugLogParam2(item,param1,param2);} +#define PHY_DEBUG_LOG3(item,param1,param2,param3) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogTime(PDBG_EXTENDED_EVENT | item);PhyDebugLogParam3(item,param1,param2,param3);} + +#define PHY_DEBUG_LOG_SIMPLE1(item,param) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogParam1(item,param);} +#define PHY_DEBUG_LOG_SIMPLE2(item,param1,param2) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogParam2(item,param1,param2);} +#define PHY_DEBUG_LOG_SIMPLE3(item,param1,param2,param3) if(PDBG_RESERVED_EVENT!=item){PhyDebugLogParam3(item,param1,param2,param3);} + +void PhyUnexpectedTransceiverReset(void); + +void PhyDebugLogTime(uint8_t item); +void PhyDebugLogParam1(uint8_t item, uint8_t param1); +void PhyDebugLogParam2(uint8_t item, uint8_t param1, uint8_t param2); +void PhyDebugLogParam3(uint8_t item, uint8_t param1, uint8_t param2, uint8_t param3); + + +#else /* not def MAC_PHY_DEBUG */ + +#define PhyUnexpectedTransceiverReset() + +#define PHY_DEBUG_LOG(item) +#define PHY_DEBUG_LOG1(item,param) +#define PHY_DEBUG_LOG2(item,param1,param2) +#define PHY_DEBUG_LOG3(item,param1,param2,param3) + +#define PHY_DEBUG_LOG_SIMPLE1(item,param) +#define PHY_DEBUG_LOG_SIMPLE2(item,param1,param2) +#define PHY_DEBUG_LOG_SIMPLE3(item,param1,param2,param3) + +#endif /* MAC_PHY_DEBUG */ + + +#endif /* _PHY_DEBUG_H_ */ + + +