2014-02-06 16:55:35 +01:00
|
|
|
/*
|
2014-08-04 19:08:22 +02:00
|
|
|
* Copyright (C) 2013, 2014 INRIA
|
2014-02-06 16:55:35 +01:00
|
|
|
*
|
2014-07-31 19:45:27 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-02-06 16:55:35 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup examples
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief UDP RPL example application
|
|
|
|
*
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "msg.h"
|
|
|
|
#include "sixlowpan/ip.h"
|
|
|
|
#include "transceiver.h"
|
|
|
|
#include "ieee802154_frame.h"
|
2014-08-06 13:48:18 +02:00
|
|
|
#include "rpl/rpl_structs.h"
|
2014-01-06 10:10:47 +01:00
|
|
|
|
2014-08-04 17:52:39 +02:00
|
|
|
#include "rpl_udp.h"
|
2014-01-06 10:10:47 +01:00
|
|
|
|
2014-03-03 10:59:19 +01:00
|
|
|
#define ENABLE_DEBUG (0)
|
2014-01-06 10:10:47 +01:00
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
#define LL_HDR_LEN (0x4)
|
|
|
|
#define IPV6_HDR_LEN (0x28)
|
|
|
|
|
|
|
|
extern uint8_t ipv6_ext_hdr_len;
|
|
|
|
|
|
|
|
msg_t msg_q[RCV_BUFFER_SIZE];
|
|
|
|
|
2014-02-24 23:39:23 +01:00
|
|
|
void rpl_udp_set_id(int argc, char **argv)
|
2014-01-06 10:10:47 +01:00
|
|
|
{
|
2014-02-24 23:39:23 +01:00
|
|
|
if (argc != 2) {
|
|
|
|
printf("Usage: %s address\n", argv[0]);
|
2014-10-25 18:34:38 +02:00
|
|
|
#if defined(MODULE_CC110X_LEGACY_CSMA) || defined(MODULE_CC110X_LEGACY)
|
2014-01-06 10:10:47 +01:00
|
|
|
printf("\taddress must be an 8 bit integer\n");
|
2014-10-25 18:34:38 +02:00
|
|
|
#else
|
|
|
|
printf("\taddress must be an 16 bit integer\n");
|
|
|
|
#endif
|
2014-01-06 10:10:47 +01:00
|
|
|
printf("\n\t(Current address is %u)\n", id);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-02-24 23:39:23 +01:00
|
|
|
id = atoi(argv[1]);
|
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
printf("Set node ID to %u\n", id);
|
|
|
|
}
|
|
|
|
|
2014-03-04 20:20:01 +01:00
|
|
|
void *rpl_udp_monitor(void *arg)
|
2014-01-06 10:10:47 +01:00
|
|
|
{
|
2014-03-04 20:20:01 +01:00
|
|
|
(void) arg;
|
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
msg_t m;
|
|
|
|
radio_packet_t *p;
|
|
|
|
ipv6_hdr_t *ipv6_buf;
|
|
|
|
uint8_t icmp_type, icmp_code;
|
|
|
|
icmpv6_hdr_t *icmpv6_buf = NULL;
|
|
|
|
|
|
|
|
msg_init_queue(msg_q, RCV_BUFFER_SIZE);
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
msg_receive(&m);
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
if (m.type == PKT_PENDING) {
|
2014-01-25 11:22:09 +01:00
|
|
|
p = (radio_packet_t *) m.content.ptr;
|
2014-01-06 10:10:47 +01:00
|
|
|
|
2014-03-03 10:59:19 +01:00
|
|
|
DEBUGF("Received packet from ID %u\n", p->src);
|
2014-01-06 10:10:47 +01:00
|
|
|
DEBUG("\tLength:\t%u\n", p->length);
|
|
|
|
DEBUG("\tSrc:\t%u\n", p->src);
|
|
|
|
DEBUG("\tDst:\t%u\n", p->dst);
|
|
|
|
DEBUG("\tLQI:\t%u\n", p->lqi);
|
|
|
|
DEBUG("\tRSSI:\t%i\n", (int8_t) p->rssi);
|
|
|
|
|
|
|
|
for (uint8_t i = 0; i < p->length; i++) {
|
|
|
|
DEBUG("%02X ", p->data[i]);
|
|
|
|
}
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
p->processing--;
|
|
|
|
DEBUG("\n");
|
|
|
|
}
|
|
|
|
else if (m.type == IPV6_PACKET_RECEIVED) {
|
2014-01-25 11:22:09 +01:00
|
|
|
ipv6_buf = (ipv6_hdr_t *) m.content.ptr;
|
2014-01-18 01:15:29 +01:00
|
|
|
printf("IPv6 datagram received (next header: %02X)", ipv6_buf->nextheader);
|
2014-02-13 16:06:25 +01:00
|
|
|
printf(" from %s ", ipv6_addr_to_str(addr_str, IPV6_MAX_ADDR_STR_LEN,
|
|
|
|
&ipv6_buf->srcaddr));
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
if (ipv6_buf->nextheader == IPV6_PROTO_NUM_ICMPV6) {
|
2014-01-25 11:22:09 +01:00
|
|
|
icmpv6_buf = (icmpv6_hdr_t *) &ipv6_buf[(LL_HDR_LEN + IPV6_HDR_LEN) + ipv6_ext_hdr_len];
|
2014-01-06 10:10:47 +01:00
|
|
|
icmp_type = icmpv6_buf->type;
|
|
|
|
icmp_code = icmpv6_buf->code;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ipv6_buf->nextheader == IPV6_PROTO_NUM_ICMPV6) {
|
|
|
|
DEBUG("\t ICMP type: %02X ", icmp_type);
|
|
|
|
DEBUG("\t ICMP code: %02X ", icmp_code);
|
2014-06-20 20:00:20 +02:00
|
|
|
(void) icmp_type;
|
|
|
|
(void) icmp_code;
|
2014-01-06 10:10:47 +01:00
|
|
|
}
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-01-06 10:10:47 +01:00
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
else if (m.type == ENOBUFFER) {
|
|
|
|
puts("Transceiver buffer full");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("Unknown packet received, type %04X\n", m.type);
|
|
|
|
}
|
|
|
|
}
|
2014-03-04 20:20:01 +01:00
|
|
|
|
|
|
|
return NULL;
|
2014-01-06 10:10:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
transceiver_command_t tcmd;
|
|
|
|
|
2014-02-24 23:39:23 +01:00
|
|
|
void rpl_udp_ignore(int argc, char **argv)
|
2014-01-25 11:22:09 +01:00
|
|
|
{
|
2014-01-06 10:10:47 +01:00
|
|
|
uint16_t a;
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-08-06 11:52:00 +02:00
|
|
|
if (transceiver_pid == KERNEL_PID_UNDEF) {
|
2014-01-06 10:10:47 +01:00
|
|
|
puts("Transceiver not runnning.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
msg_t mesg;
|
|
|
|
mesg.type = DBG_IGN;
|
2014-01-25 11:22:09 +01:00
|
|
|
mesg.content.ptr = (char *) &tcmd;
|
2014-01-06 10:10:47 +01:00
|
|
|
|
|
|
|
tcmd.transceivers = TRANSCEIVER_CC1100;
|
|
|
|
tcmd.data = &a;
|
2014-01-25 11:22:09 +01:00
|
|
|
|
2014-02-24 23:39:23 +01:00
|
|
|
if (argc == 2) {
|
2014-10-16 13:32:36 +02:00
|
|
|
/* cppcheck: a is actually read via tcmd.data */
|
|
|
|
/* cppcheck-suppress unreadVariable */
|
2014-02-24 23:39:23 +01:00
|
|
|
a = atoi(argv[1]);
|
2014-07-06 22:57:56 +02:00
|
|
|
printf("sending to transceiver (%" PRIkernel_pid "): %u\n", transceiver_pid, (*(uint8_t *)tcmd.data));
|
2014-10-20 16:49:40 +02:00
|
|
|
msg_send(&mesg, transceiver_pid);
|
2014-01-06 10:10:47 +01:00
|
|
|
}
|
|
|
|
else {
|
2014-02-24 23:39:23 +01:00
|
|
|
printf("Usage: %s <addr>\n", argv[0]);
|
2014-01-06 10:10:47 +01:00
|
|
|
}
|
|
|
|
}
|