2013-10-28 10:25:17 +01:00
|
|
|
/*
|
|
|
|
* @f ccnl-riot-compat.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013, Christian Mehlis, Freie University Berlin
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2013-11-21 10:17:55 +01:00
|
|
|
#include <stdlib.h>
|
2013-10-28 10:25:17 +01:00
|
|
|
#include <string.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
|
|
|
|
#include "msg.h"
|
2014-04-17 18:21:31 +02:00
|
|
|
#include "thread.h"
|
2013-10-28 10:25:17 +01:00
|
|
|
|
2014-08-01 02:13:29 +02:00
|
|
|
#include "ieee802154_frame.h"
|
|
|
|
|
2013-10-28 10:25:17 +01:00
|
|
|
#include "ccnl.h"
|
|
|
|
#include "ccnl-core.h"
|
|
|
|
#include "ccnl-pdu.h"
|
|
|
|
#include "ccnl-riot-compat.h"
|
|
|
|
|
2014-07-18 21:15:04 +02:00
|
|
|
#if defined (MODULE_AT86RF231) || defined(MODULE_CC2420) || defined(MODULE_MC1322X)
|
2014-07-19 23:50:11 +02:00
|
|
|
ieee802154_packet_t p;
|
|
|
|
#else
|
2013-10-28 10:25:17 +01:00
|
|
|
radio_packet_t p;
|
2014-07-19 23:50:11 +02:00
|
|
|
#endif
|
|
|
|
|
2013-10-28 10:25:17 +01:00
|
|
|
transceiver_command_t tcmd;
|
|
|
|
msg_t mesg, rep;
|
|
|
|
|
2014-07-06 17:00:08 +02:00
|
|
|
char relay_helper_stack[KERNEL_CONF_STACKSIZE_MAIN];
|
2014-04-17 18:21:31 +02:00
|
|
|
|
2013-10-28 10:25:17 +01:00
|
|
|
int riot_send_transceiver(uint8_t *buf, uint16_t size, uint16_t to)
|
|
|
|
{
|
|
|
|
DEBUGMSG(1, "this is a RIOT TRANSCEIVER based connection\n");
|
|
|
|
DEBUGMSG(1, "size=%" PRIu16 " to=%" PRIu16 "\n", size, to);
|
|
|
|
|
|
|
|
if (size > PAYLOAD_SIZE) {
|
2014-04-19 20:49:53 +02:00
|
|
|
DEBUGMSG(1, "size > PAYLOAD_SIZE: %d > %d\n", size, PAYLOAD_SIZE);
|
2013-10-28 10:25:17 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-07-19 23:50:11 +02:00
|
|
|
#if MODULE_AT86RF231 || MODULE_CC2420 || MODULE_MC1322X
|
|
|
|
p.frame.payload_len = size;
|
|
|
|
p.frame.fcf.dest_addr_m = IEEE_802154_SHORT_ADDR_M;
|
|
|
|
memset(p.frame.dest_addr, 0, sizeof(p.frame.dest_addr));
|
|
|
|
memcpy(&(p.frame.dest_addr[6]), &to, sizeof(uint16_t));
|
|
|
|
p.frame.payload = buf;
|
|
|
|
#else
|
2013-10-28 10:25:17 +01:00
|
|
|
p.length = size;
|
|
|
|
p.dst = (to == RIOT_BROADCAST) ? 0 : to;
|
|
|
|
p.data = buf;
|
2014-07-19 23:50:11 +02:00
|
|
|
#endif
|
2013-10-28 10:25:17 +01:00
|
|
|
|
2014-04-10 22:36:58 +02:00
|
|
|
tcmd.transceivers = TRANSCEIVER;
|
2013-10-28 10:25:17 +01:00
|
|
|
tcmd.data = &p;
|
|
|
|
|
|
|
|
mesg.type = SND_PKT;
|
|
|
|
mesg.content.ptr = (char *) &tcmd;
|
|
|
|
msg_send_receive(&mesg, &rep, transceiver_pid);
|
|
|
|
|
|
|
|
return size;
|
|
|
|
}
|
|
|
|
|
|
|
|
int riot_send_msg(uint8_t *buf, uint16_t size, uint16_t to)
|
|
|
|
{
|
|
|
|
DEBUGMSG(1, "this is a RIOT MSG based connection\n");
|
|
|
|
DEBUGMSG(1, "size=%" PRIu16 " to=%" PRIu16 "\n", size, to);
|
|
|
|
|
2013-11-21 10:17:55 +01:00
|
|
|
uint8_t *buf2 = malloc(sizeof(riot_ccnl_msg_t) + size);
|
|
|
|
if (!buf2) {
|
|
|
|
DEBUGMSG(1, " malloc failed...dorpping msg!\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
riot_ccnl_msg_t *rmsg = (riot_ccnl_msg_t *) buf2;
|
|
|
|
rmsg->payload = buf2 + sizeof(riot_ccnl_msg_t);
|
|
|
|
rmsg->size = size;
|
|
|
|
|
|
|
|
memcpy(rmsg->payload, buf, size);
|
2013-10-28 10:25:17 +01:00
|
|
|
|
|
|
|
msg_t m;
|
|
|
|
m.type = CCNL_RIOT_MSG;
|
2013-11-21 10:17:55 +01:00
|
|
|
m.content.ptr = (char *) rmsg;
|
2014-07-06 22:57:56 +02:00
|
|
|
DEBUGMSG(1, "sending msg to pid=%" PRIkernel_pid "\n", to);
|
2014-10-20 16:49:40 +02:00
|
|
|
msg_send(&m, to);
|
2013-10-28 10:25:17 +01:00
|
|
|
|
|
|
|
return size;
|
|
|
|
}
|
|
|
|
|
2013-12-18 19:31:38 +01:00
|
|
|
void riot_send_nack(uint16_t to)
|
|
|
|
{
|
|
|
|
msg_t m;
|
|
|
|
m.type = CCNL_RIOT_NACK;
|
2014-07-06 22:57:56 +02:00
|
|
|
DEBUGMSG(1, "sending NACK msg to pid=%" PRIkernel_pid"\n", to);
|
2014-10-20 16:49:40 +02:00
|
|
|
msg_try_send(&m, to);
|
2013-12-18 19:31:38 +01:00
|
|
|
}
|
|
|
|
|
2014-07-18 20:35:32 +02:00
|
|
|
void *ccnl_riot_relay_helper_start(void *);
|
2014-04-17 18:21:31 +02:00
|
|
|
|
2014-08-07 15:06:50 +02:00
|
|
|
kernel_pid_t riot_start_helper_thread(void)
|
2014-04-17 18:21:31 +02:00
|
|
|
{
|
2014-07-18 20:35:32 +02:00
|
|
|
return thread_create(relay_helper_stack, sizeof(relay_helper_stack),
|
|
|
|
PRIORITY_MAIN - 2, CREATE_STACKTEST,
|
|
|
|
ccnl_riot_relay_helper_start, NULL, "relay-helper");
|
2014-04-17 18:21:31 +02:00
|
|
|
}
|
|
|
|
|
2014-05-07 06:17:11 +02:00
|
|
|
char *riot_ccnl_event_to_string(int event)
|
2013-10-28 10:25:17 +01:00
|
|
|
{
|
|
|
|
switch (event) {
|
|
|
|
case PKT_PENDING:
|
|
|
|
return "PKT_PENDING";
|
|
|
|
|
|
|
|
case CCNL_RIOT_MSG:
|
|
|
|
return "RIOT_MSG";
|
|
|
|
|
|
|
|
case CCNL_RIOT_HALT:
|
|
|
|
return "RIOT_HALT";
|
|
|
|
|
|
|
|
case CCNL_RIOT_POPULATE:
|
|
|
|
return "RIOT_POPULATE";
|
|
|
|
|
2013-12-04 01:12:19 +01:00
|
|
|
case CCNL_RIOT_PRINT_STAT:
|
|
|
|
return "CCNL_RIOT_PRINT_STAT";
|
|
|
|
|
2014-03-02 19:12:21 +01:00
|
|
|
case ENOBUFFER:
|
|
|
|
return "ENOBUFFER";
|
|
|
|
|
2013-10-28 10:25:17 +01:00
|
|
|
default:
|
|
|
|
return "UNKNOWN";
|
|
|
|
}
|
|
|
|
}
|