mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
ba3088c4bd
into separate patch files
236 lines
10 KiB
Diff
236 lines
10 KiB
Diff
*** stock_iot-lab_M3/openwsn/02a-MAClow/IEEE802154.c Thu Apr 24 11:01:36 2014
|
|
--- riot-openwsn-wip/openwsn/02a-MAClow/IEEE802154.c Thu Mar 27 11:10:40 2014
|
|
***************
|
|
*** 16,35 ****
|
|
|
|
Note that we are writing the field from the end of the header to the beginning.
|
|
|
|
! \param msg [in,out] The message to append the header to.
|
|
! \param frameType [in] Type of IEEE802.15.4 frame.
|
|
! \param securityEnabled [in] Is security enabled on this frame?
|
|
! \param nextHop [in] Address of the next hop
|
|
*/
|
|
void ieee802154_prependHeader(OpenQueueEntry_t* msg,
|
|
uint8_t frameType,
|
|
bool securityEnabled,
|
|
uint8_t sequenceNumber,
|
|
open_addr_t* nextHop) {
|
|
uint8_t temp_8b;
|
|
|
|
// previousHop address (always 64-bit)
|
|
! packetfunctions_writeAddress(msg,idmanager_getMyID(ADDR_64B),LITTLE_ENDIAN);
|
|
// nextHop address
|
|
if (packetfunctions_isBroadcastMulticast(nextHop)) {
|
|
//broadcast address is always 16-bit
|
|
--- 16,42 ----
|
|
|
|
Note that we are writing the field from the end of the header to the beginning.
|
|
|
|
! \param[in,out] msg The message to append the header to.
|
|
! \param[in] frameType Type of IEEE802.15.4 frame.
|
|
! \param[in] ielistpresent Is the IE list present¿
|
|
! \param[in] frameVersion IEEE802.15.4 frame version.
|
|
! \param[in] securityEnabled Is security enabled on this frame?
|
|
! \param[in] sequenceNumber Sequence number of this frame.
|
|
! \param[in] nextHop Address of the next hop
|
|
*/
|
|
void ieee802154_prependHeader(OpenQueueEntry_t* msg,
|
|
uint8_t frameType,
|
|
+ uint8_t ielistpresent,
|
|
+ uint8_t frameversion,
|
|
bool securityEnabled,
|
|
uint8_t sequenceNumber,
|
|
open_addr_t* nextHop) {
|
|
uint8_t temp_8b;
|
|
|
|
+ //General IEs here (those that are carried in all packets) -- None by now.
|
|
+
|
|
// previousHop address (always 64-bit)
|
|
! packetfunctions_writeAddress(msg,idmanager_getMyID(ADDR_64B),OW_LITTLE_ENDIAN);
|
|
// nextHop address
|
|
if (packetfunctions_isBroadcastMulticast(nextHop)) {
|
|
//broadcast address is always 16-bit
|
|
***************
|
|
*** 41,47 ****
|
|
switch (nextHop->type) {
|
|
case ADDR_16B:
|
|
case ADDR_64B:
|
|
! packetfunctions_writeAddress(msg,nextHop,LITTLE_ENDIAN);
|
|
break;
|
|
default:
|
|
openserial_printCritical(COMPONENT_IEEE802154,ERR_WRONG_ADDR_TYPE,
|
|
--- 48,54 ----
|
|
switch (nextHop->type) {
|
|
case ADDR_16B:
|
|
case ADDR_64B:
|
|
! packetfunctions_writeAddress(msg,nextHop,OW_LITTLE_ENDIAN);
|
|
break;
|
|
default:
|
|
openserial_printCritical(COMPONENT_IEEE802154,ERR_WRONG_ADDR_TYPE,
|
|
***************
|
|
*** 51,57 ****
|
|
|
|
}
|
|
// destpan
|
|
! packetfunctions_writeAddress(msg,idmanager_getMyID(ADDR_PANID),LITTLE_ENDIAN);
|
|
//dsn
|
|
packetfunctions_reserveHeaderSize(msg,sizeof(uint8_t));
|
|
*((uint8_t*)(msg->payload)) = sequenceNumber;
|
|
--- 58,64 ----
|
|
|
|
}
|
|
// destpan
|
|
! packetfunctions_writeAddress(msg,idmanager_getMyID(ADDR_PANID),OW_LITTLE_ENDIAN);
|
|
//dsn
|
|
packetfunctions_reserveHeaderSize(msg,sizeof(uint8_t));
|
|
*((uint8_t*)(msg->payload)) = sequenceNumber;
|
|
***************
|
|
*** 72,77 ****
|
|
--- 79,88 ----
|
|
}
|
|
}
|
|
temp_8b |= IEEE154_ADDR_EXT << IEEE154_FCF_SRC_ADDR_MODE;
|
|
+ //poipoi xv IE list present
|
|
+ temp_8b |= ielistpresent << IEEE154_FCF_IELIST_PRESENT;
|
|
+ temp_8b |= frameversion << IEEE154_FCF_FRAME_VERSION;
|
|
+
|
|
*((uint8_t*)(msg->payload)) = temp_8b;
|
|
//fcf (1st byte)
|
|
packetfunctions_reserveHeaderSize(msg,sizeof(uint8_t));
|
|
***************
|
|
*** 93,100 ****
|
|
|
|
Note We are writing the fields from the begnning of the header to the end.
|
|
|
|
! \param msg [in,out] The message just received.
|
|
! \param ieee802514_header [out] The internal header to write the data to.
|
|
*/
|
|
void ieee802154_retrieveHeader(OpenQueueEntry_t* msg,
|
|
ieee802154_header_iht* ieee802514_header) {
|
|
--- 104,111 ----
|
|
|
|
Note We are writing the fields from the begnning of the header to the end.
|
|
|
|
! \param[in,out] msg The message just received.
|
|
! \param[out] ieee802514_header The internal header to write the data to.
|
|
*/
|
|
void ieee802154_retrieveHeader(OpenQueueEntry_t* msg,
|
|
ieee802154_header_iht* ieee802514_header) {
|
|
***************
|
|
*** 117,122 ****
|
|
--- 128,141 ----
|
|
// fcf, byte 2
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
temp_8b = *((uint8_t*)(msg->payload)+ieee802514_header->headerLength);
|
|
+ //poipoi xv IE list present
|
|
+ ieee802514_header->ieListPresent = (temp_8b >> IEEE154_FCF_IELIST_PRESENT ) & 0x01;//1b
|
|
+ ieee802514_header->frameVersion = (temp_8b >> IEEE154_FCF_FRAME_VERSION ) & 0x03;//2b
|
|
+
|
|
+ if (ieee802514_header->ieListPresent==TRUE && ieee802514_header->frameVersion!=IEEE154_FRAMEVERSION){
|
|
+ return; //invalid packet accordint to p.64 IEEE15.4e
|
|
+ }
|
|
+
|
|
switch ( (temp_8b >> IEEE154_FCF_DEST_ADDR_MODE ) & 0x03 ) {
|
|
case IEEE154_ADDR_NONE:
|
|
ieee802514_header->dest.type = ADDR_NONE;
|
|
***************
|
|
*** 159,165 ****
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_PANID,
|
|
&ieee802514_header->panid,
|
|
! LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 2;
|
|
// dest
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
--- 178,184 ----
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_PANID,
|
|
&ieee802514_header->panid,
|
|
! OW_LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 2;
|
|
// dest
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
***************
|
|
*** 171,177 ****
|
|
((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_16B,
|
|
&ieee802514_header->dest,
|
|
! LITTLE_ENDIAN
|
|
);
|
|
ieee802514_header->headerLength += 2;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
--- 190,196 ----
|
|
((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_16B,
|
|
&ieee802514_header->dest,
|
|
! OW_LITTLE_ENDIAN
|
|
);
|
|
ieee802514_header->headerLength += 2;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
***************
|
|
*** 180,186 ****
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_64B,
|
|
&ieee802514_header->dest,
|
|
! LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 8;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
--- 199,205 ----
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_64B,
|
|
&ieee802514_header->dest,
|
|
! OW_LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 8;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
***************
|
|
*** 194,200 ****
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_16B,
|
|
&ieee802514_header->src,
|
|
! LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 2;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
--- 213,219 ----
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_16B,
|
|
&ieee802514_header->src,
|
|
! OW_LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 2;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
***************
|
|
*** 202,213 ****
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_64B,
|
|
&ieee802514_header->src,
|
|
! LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 8;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
// no need for a default, since case would have been caught above
|
|
}
|
|
// apply topology filter
|
|
if (topology_isAcceptablePacket(ieee802514_header)==FALSE) {
|
|
// the topology filter does accept this packet, return
|
|
--- 221,237 ----
|
|
packetfunctions_readAddress(((uint8_t*)(msg->payload)+ieee802514_header->headerLength),
|
|
ADDR_64B,
|
|
&ieee802514_header->src,
|
|
! OW_LITTLE_ENDIAN);
|
|
ieee802514_header->headerLength += 8;
|
|
if (ieee802514_header->headerLength>msg->length) { return; } // no more to read!
|
|
break;
|
|
// no need for a default, since case would have been caught above
|
|
}
|
|
+
|
|
+ if (ieee802514_header->ieListPresent==TRUE && ieee802514_header->frameVersion!=IEEE154_FRAMEVERSION){
|
|
+ return; //invalid packet accordint to p.64 IEEE15.4e
|
|
+ }
|
|
+
|
|
// apply topology filter
|
|
if (topology_isAcceptablePacket(ieee802514_header)==FALSE) {
|
|
// the topology filter does accept this packet, return
|