1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/net/ccn_lite/ccnl-riot-compat.c

149 lines
4.0 KiB
C
Raw Normal View History

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>
#include <stdlib.h>
2013-10-28 10:25:17 +01:00
#include <string.h>
#include <inttypes.h>
#include "msg.h"
#include "thread.h"
2013-10-28 10:25:17 +01: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;
char relay_helper_stack[THREAD_STACKSIZE_MAIN];
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
2014-11-11 23:34:59 +01:00
memset(&p, 0, sizeof(ieee802154_packet_t));
2014-07-19 23:50:11 +02:00
p.frame.payload_len = size;
2014-11-11 23:34:59 +01:00
p.frame.fcf.frame_type = IEEE_802154_DATA_FRAME;
2014-07-19 23:50:11 +02:00
p.frame.fcf.dest_addr_m = IEEE_802154_SHORT_ADDR_M;
2014-11-11 23:34:59 +01:00
p.frame.fcf.src_addr_m = IEEE_802154_SHORT_ADDR_M;
p.frame.dest_addr[1] = (to & 0xff);
p.frame.dest_addr[0] = (to >> 8);
2014-07-19 23:50:11 +02:00
p.frame.payload = buf;
2014-11-11 23:34:59 +01:00
p.frame.dest_pan_id = IEEE_802154_DEFAULT_PAN_ID;
2014-07-19 23:50:11 +02:00
#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);
2014-11-11 21:51:52 +01:00
uint8_t *buf2 = ccnl_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;
m.content.ptr = (char *) rmsg;
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;
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 *);
kernel_pid_t riot_start_helper_thread(void)
{
2014-07-18 20:35:32 +02:00
return thread_create(relay_helper_stack, sizeof(relay_helper_stack),
THREAD_PRIORITY_MAIN - 2, CREATE_STACKTEST,
2014-07-18 20:35:32 +02:00
ccnl_riot_relay_helper_start, NULL, "relay-helper");
}
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";
case ENOBUFFER:
return "ENOBUFFER";
2013-10-28 10:25:17 +01:00
default:
return "UNKNOWN";
}
}