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"
|
|
|
|
#include "rpl_structs.h"
|
|
|
|
|
|
|
|
#include "demo.h"
|
|
|
|
|
|
|
|
#define ENABLE_DEBUG (1)
|
|
|
|
#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];
|
|
|
|
|
|
|
|
/* prints current IPv6 adresses */
|
2014-01-18 01:14:23 +01:00
|
|
|
void rpl_udp_ip(char *unused)
|
2014-01-06 10:10:47 +01:00
|
|
|
{
|
|
|
|
(void) unused;
|
|
|
|
ipv6_iface_print_addrs();
|
|
|
|
}
|
|
|
|
|
2014-01-18 01:14:23 +01:00
|
|
|
void rpl_udp_set_id(char *id_str)
|
2014-01-06 10:10:47 +01:00
|
|
|
{
|
|
|
|
int res = sscanf(id_str, "set %hu", &id);
|
|
|
|
|
|
|
|
if (res < 1) {
|
|
|
|
printf("Usage: init address\n");
|
|
|
|
printf("\taddress must be an 8 bit integer\n");
|
|
|
|
printf("\n\t(Current address is %u)\n", id);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("Set node ID to %u\n", id);
|
|
|
|
}
|
|
|
|
|
2014-01-18 01:14:23 +01:00
|
|
|
void rpl_udp_monitor(void)
|
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);
|
|
|
|
if (m.type == PKT_PENDING) {
|
|
|
|
p = (radio_packet_t*) m.content.ptr;
|
|
|
|
|
|
|
|
DEBUG("Received packet from ID %u\n", p->src);
|
|
|
|
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]);
|
|
|
|
}
|
|
|
|
p->processing--;
|
|
|
|
DEBUG("\n");
|
|
|
|
}
|
|
|
|
else if (m.type == IPV6_PACKET_RECEIVED) {
|
|
|
|
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-01-06 10:10:47 +01:00
|
|
|
printf(" from %s ", ipv6_addr_to_str(addr_str, &ipv6_buf->srcaddr));
|
|
|
|
if (ipv6_buf->nextheader == IPV6_PROTO_NUM_ICMPV6) {
|
|
|
|
icmpv6_buf = (icmpv6_hdr_t*) &ipv6_buf[(LL_HDR_LEN + IPV6_HDR_LEN) + ipv6_ext_hdr_len];
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
else if (m.type == ENOBUFFER) {
|
|
|
|
puts("Transceiver buffer full");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("Unknown packet received, type %04X\n", m.type);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
transceiver_command_t tcmd;
|
|
|
|
|
2014-01-18 01:14:23 +01:00
|
|
|
void rpl_udp_ignore(char *addr) {
|
2014-01-06 10:10:47 +01:00
|
|
|
uint16_t a;
|
|
|
|
if (transceiver_pid < 0) {
|
|
|
|
puts("Transceiver not runnning.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
msg_t mesg;
|
|
|
|
mesg.type = DBG_IGN;
|
|
|
|
mesg.content.ptr = (char*) &tcmd;
|
|
|
|
|
|
|
|
tcmd.transceivers = TRANSCEIVER_CC1100;
|
|
|
|
tcmd.data = &a;
|
|
|
|
a = atoi(addr + strlen("ign "));
|
|
|
|
if (strlen(addr) > strlen("ign ")) {
|
|
|
|
printf("sending to transceiver (%u): %u\n", transceiver_pid, (*(uint8_t*)tcmd.data));
|
|
|
|
msg_send(&mesg, transceiver_pid, 1);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
puts("Usage:\tign <addr>");
|
|
|
|
}
|
|
|
|
}
|