46 #if ALLWIZE_LORAWAN_REDUCE_SIZE
51 for (uint8_t i=0; i<4; i++) {
52 uid = (uid << 8) + DevAddr[i];
72 tmp[0] = (raw.
c & 0x0F) << 4;
81 memcpy(&tmp[9], raw.
data, raw.
len);
101 uint8_t LoRaWAN_Data[64] = {0};
102 uint8_t LoRaWAN_Data_Length = 0;
103 uint8_t MIC[4] = {0};
106 uint8_t tmpData[Data_Length];
107 for (
int i = 0; i < Data_Length; i++) {
108 tmpData[i] = Data[i];
123 LoRaWAN_Data[6] = (
_counter & 0x00FF);
124 LoRaWAN_Data[7] = ((
_counter >> 8) & 0x00FF);
127 LoRaWAN_Data[8] = Frame_Port;
130 LoRaWAN_Data_Length = 9;
133 for(i = 0; i < Data_Length; i++) {
134 LoRaWAN_Data[LoRaWAN_Data_Length + i] = tmpData[i];
136 LoRaWAN_Data_Length += Data_Length;
142 for(i = 0; i < 4; i++) {
143 LoRaWAN_Data[LoRaWAN_Data_Length + i] = MIC[i];
145 LoRaWAN_Data_Length += 4;
147 #if defined(ALLWIZE_DEBUG_PORT)
148 ALLWIZE_DEBUG_PORT.print(
"[LORAWAN] PHYPayload: ");
150 for(i = 0; i < LoRaWAN_Data_Length; i++) {
151 snprintf(buff,
sizeof(buff),
"%02X", LoRaWAN_Data[i]);
152 ALLWIZE_DEBUG_PORT.print(buff);
154 ALLWIZE_DEBUG_PORT.println();
157 #if ALLWIZE_LORAWAN_REDUCE_SIZE
159 #define ALLWIZE_LORAWAN_SKIP_BYTES 9
161 #define ALLWIZE_LORAWAN_SKIP_BYTES 0
183 uint8_t Number_of_Blocks = 0x00;
184 uint8_t Incomplete_Block_Size = 0x00;
189 Number_of_Blocks = Data_Length / 16;
190 Incomplete_Block_Size = Data_Length % 16;
191 if (Incomplete_Block_Size != 0) {
195 for (i = 1; i <= Number_of_Blocks; i++) {
203 Block_A[5] = Direction;
210 Block_A[10] = (Frame_Counter & 0x00FF);
211 Block_A[11] = ((Frame_Counter >> 8) & 0x00FF);
224 if (i != Number_of_Blocks) {
225 for (j = 0; j < 16; j++) {
226 *Data = *Data ^ Block_A[j];
230 if (Incomplete_Block_Size == 0) {
231 Incomplete_Block_Size = 16;
233 for (j = 0; j < Incomplete_Block_Size; j++) {
234 *Data = *Data ^ Block_A[j];
255 uint8_t Key_K1[16] = {
256 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
257 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
259 uint8_t Key_K2[16] = {
260 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
261 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
266 uint8_t Old_Data[16] = {
267 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
268 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
270 uint8_t New_Data[16] = {
271 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
272 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
275 uint8_t Number_of_Blocks = 0x00;
276 uint8_t Incomplete_Block_Size = 0x00;
277 uint8_t Block_Counter = 0x01;
286 Block_B[5] = Direction;
293 Block_B[10] = (Frame_Counter & 0x00FF);
294 Block_B[11] = ((Frame_Counter >> 8) & 0x00FF);
300 Block_B[15] = Data_Length;
303 Number_of_Blocks = Data_Length / 16;
304 Incomplete_Block_Size = Data_Length % 16;
306 if (Incomplete_Block_Size != 0) {
318 for (i = 0; i < 16; i++) {
319 Old_Data[i] = Block_B[i];
323 while (Block_Counter < Number_of_Blocks) {
326 for (i = 0; i < 16; i++) {
332 XOR(New_Data, Old_Data);
338 for (i = 0; i < 16; i++) {
339 Old_Data[i] = New_Data[i];
349 if (Incomplete_Block_Size == 0) {
352 for (i = 0; i < 16; i++) {
358 XOR(New_Data, Key_K1);
361 XOR(New_Data, Old_Data);
370 for (i = 0; i < 16; i++) {
371 if (i < Incomplete_Block_Size) {
375 if (i == Incomplete_Block_Size) {
378 if (i > Incomplete_Block_Size) {
384 XOR(New_Data, Key_K2);
387 XOR(New_Data, Old_Data);
394 Final_MIC[0] = New_Data[0];
395 Final_MIC[1] = New_Data[1];
396 Final_MIC[2] = New_Data[2];
397 Final_MIC[3] = New_Data[3];
417 if ((K1[0] & 0x80) == 0x80) {
428 K1[15] = K1[15] ^ 0x87;
432 for (i = 0; i < 16; i++) {
437 if ((K2[0] & 0x80) == 0x80) {
448 K2[15] = K2[15] ^ 0x87;
461 uint8_t Overflow = 0;
464 for (i = 0; i < 16; i++) {
469 if ((Data[i + 1] & 0x80) == 0x80) {
479 Data[i] = (Data[i] << 1) + Overflow;
494 for (i = 0; i < 16; i++) {
495 New_Data[i] = New_Data[i] ^ Old_Data[i];
508 {0x63,0x7C,0x77,0x7B,0xF2,0x6B,0x6F,0xC5,0x30,0x01,0x67,0x2B,0xFE,0xD7,0xAB,0x76},
509 {0xCA,0x82,0xC9,0x7D,0xFA,0x59,0x47,0xF0,0xAD,0xD4,0xA2,0xAF,0x9C,0xA4,0x72,0xC0},
510 {0xB7,0xFD,0x93,0x26,0x36,0x3F,0xF7,0xCC,0x34,0xA5,0xE5,0xF1,0x71,0xD8,0x31,0x15},
511 {0x04,0xC7,0x23,0xC3,0x18,0x96,0x05,0x9A,0x07,0x12,0x80,0xE2,0xEB,0x27,0xB2,0x75},
512 {0x09,0x83,0x2C,0x1A,0x1B,0x6E,0x5A,0xA0,0x52,0x3B,0xD6,0xB3,0x29,0xE3,0x2F,0x84},
513 {0x53,0xD1,0x00,0xED,0x20,0xFC,0xB1,0x5B,0x6A,0xCB,0xBE,0x39,0x4A,0x4C,0x58,0xCF},
514 {0xD0,0xEF,0xAA,0xFB,0x43,0x4D,0x33,0x85,0x45,0xF9,0x02,0x7F,0x50,0x3C,0x9F,0xA8},
515 {0x51,0xA3,0x40,0x8F,0x92,0x9D,0x38,0xF5,0xBC,0xB6,0xDA,0x21,0x10,0xFF,0xF3,0xD2},
516 {0xCD,0x0C,0x13,0xEC,0x5F,0x97,0x44,0x17,0xC4,0xA7,0x7E,0x3D,0x64,0x5D,0x19,0x73},
517 {0x60,0x81,0x4F,0xDC,0x22,0x2A,0x90,0x88,0x46,0xEE,0xB8,0x14,0xDE,0x5E,0x0B,0xDB},
518 {0xE0,0x32,0x3A,0x0A,0x49,0x06,0x24,0x5C,0xC2,0xD3,0xAC,0x62,0x91,0x95,0xE4,0x79},
519 {0xE7,0xC8,0x37,0x6D,0x8D,0xD5,0x4E,0xA9,0x6C,0x56,0xF4,0xEA,0x65,0x7A,0xAE,0x08},
520 {0xBA,0x78,0x25,0x2E,0x1C,0xA6,0xB4,0xC6,0xE8,0xDD,0x74,0x1F,0x4B,0xBD,0x8B,0x8A},
521 {0x70,0x3E,0xB5,0x66,0x48,0x03,0xF6,0x0E,0x61,0x35,0x57,0xB9,0x86,0xC1,0x1D,0x9E},
522 {0xE1,0xF8,0x98,0x11,0x69,0xD9,0x8E,0x94,0x9B,0x1E,0x87,0xE9,0xCE,0x55,0x28,0xDF},
523 {0x8C,0xA1,0x89,0x0D,0xBF,0xE6,0x42,0x68,0x41,0x99,0x2D,0x0F,0xB0,0x54,0xBB,0x16}
534 uint8_t Row, Column, Round = 0;
535 uint8_t Round_Key[16];
539 for (Column = 0; Column < 4; Column++) {
540 for (Row = 0; Row < 4; Row++) {
541 State[Row][Column] = Data[Row + (Column << 2)];
546 memcpy(&Round_Key[0], &Key[0], 16);
552 for (Round = 1; Round < 10; Round++) {
555 for (Column = 0; Column < 4; Column++) {
556 for (Row = 0; Row < 4; Row++) {
576 for (Column = 0; Column < 4; Column++) {
577 for (Row = 0; Row < 4; Row++) {
592 for (Column = 0; Column < 4; Column++) {
593 for (Row = 0; Row < 4; Row++) {
594 Data[Row + (Column << 2)] = State[Row][Column];
610 for (Collum = 0; Collum < 4; Collum++) {
611 for (Row = 0; Row < 4; Row++) {
612 State[Row][Collum] ^= Round_Key[Row + (Collum << 2)];
634 return pgm_read_byte(&(
S_Table[((Byte >> 4) & 0x0F)][((Byte >> 0) & 0x0F)]));
648 Buffer = State[1][0];
650 State[1][0] = State[1][1];
651 State[1][1] = State[1][2];
652 State[1][2] = State[1][3];
653 State[1][3] = Buffer;
655 Buffer = State[2][0];
656 State[2][0] = State[2][2];
657 State[2][2] = Buffer;
658 Buffer = State[2][1];
659 State[2][1] = State[2][3];
660 State[2][3] = Buffer;
662 Buffer = State[3][3];
663 State[3][3] = State[3][2];
664 State[3][2] = State[3][1];
665 State[3][1] = State[3][0];
666 State[3][0] = Buffer;
680 for (Collum = 0; Collum < 4; Collum++) {
681 for (Row = 0; Row < 4; Row++) {
682 a[Row] = State[Row][Collum];
683 b[Row] = (State[Row][Collum] << 1);
685 if ((State[Row][Collum] & 0x80) == 0x80) {
690 State[0][Collum] = b[0] ^ a[1] ^ b[1] ^ a[2] ^ a[3];
691 State[1][Collum] = a[0] ^ b[1] ^ a[2] ^ b[2] ^ a[3];
692 State[2][Collum] = a[0] ^ a[1] ^ b[2] ^ a[3] ^ b[3];
693 State[3][Collum] = a[0] ^ b[0] ^ a[1] ^ a[2] ^ b[3];
706 uint8_t i, j, b, Rcon;
732 for (i = 0; i < 4; i++) {
733 for (j = 0; j < 4; j++) {
734 Round_Key[j + (i << 2)] ^= Temp[j];
735 Temp[j] = Round_Key[j + (i << 2)];