1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/examples/ccn-lite-client/main.c

344 lines
8.8 KiB
C
Raw Normal View History

2014-02-03 22:47:31 +01:00
/*
2014-01-06 10:10:47 +01:00
* Copyright (C) 2013 Freie Universität Berlin
*
* 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-03 22:47:31 +01:00
*/
/**
* @ingroup examples
* @{
*
* @file
* @brief CCN Lite interactive shell example application
*
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
2014-01-06 10:10:47 +01:00
*
2014-02-03 22:47:31 +01:00
* @}
2014-01-06 10:10:47 +01:00
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <inttypes.h>
#include "msg.h"
#include "thread.h"
#include "posix_io.h"
#include "shell.h"
#include "board_uart0.h"
#include "transceiver.h"
2014-04-18 18:41:00 +02:00
#include "vtimer.h"
2014-01-06 10:10:47 +01:00
#include "ps.h"
#include "ltc4150.h"
#define ENABLE_DEBUG (0)
2014-01-06 10:10:47 +01:00
#include "debug.h"
#include "ccn_lite/ccnl-riot.h"
#include "ccn_lite/util/ccnl-riot-client.h"
#define RIOT_CCN_APPSERVER (1)
#define RIOT_CCN_TESTS (0)
static const char DEFAULT_INTEREST[] = "/ccnx/0.7.1/doc/technical/CanonicalOrder.txt";
2014-07-18 20:35:32 +02:00
char relay_stack[KERNEL_CONF_STACKSIZE_MAIN];
2014-01-06 10:10:47 +01:00
#if RIOT_CCN_APPSERVER
2014-07-18 20:35:32 +02:00
char appserver_stack[KERNEL_CONF_STACKSIZE_MAIN];
2014-01-06 10:10:47 +01:00
#endif
static volatile kernel_pid_t _relay_pid = KERNEL_PID_UNDEF, _appserver_pid = KERNEL_PID_UNDEF;
2014-01-06 10:10:47 +01:00
#define SHELL_MSG_BUFFER_SIZE (64)
msg_t msg_buffer_shell[SHELL_MSG_BUFFER_SIZE];
shell_t shell;
unsigned char big_buf[3 * 1024];
char small_buf[PAYLOAD_SIZE];
#if RIOT_CCN_APPSERVER
2014-02-24 23:39:23 +01:00
static void riot_ccn_appserver(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
if (_appserver_pid != KERNEL_PID_UNDEF) {
2014-01-06 10:10:47 +01:00
/* already running */
return;
}
_appserver_pid = thread_create(
appserver_stack, sizeof(appserver_stack),
PRIORITY_MAIN - 1, CREATE_STACKTEST,
ccnl_riot_appserver_start, (void *) _relay_pid, "appserver");
DEBUG("ccn-lite appserver on thread_id %" PRIkernel_pid "...\n", _appserver_pid);
2014-01-06 10:10:47 +01:00
}
#endif
2014-02-24 23:39:23 +01:00
static void riot_ccn_express_interest(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
if (argc < 2) {
strncpy(small_buf, DEFAULT_INTEREST, sizeof(small_buf));
2014-01-06 10:10:47 +01:00
}
else {
strncpy(small_buf, argv[1], sizeof(small_buf));
2014-01-06 10:10:47 +01:00
}
DEBUG("in='%s'\n", small_buf);
int content_len = ccnl_riot_client_get(_relay_pid, small_buf, (char *) big_buf); // small_buf=name to request
2014-01-06 10:10:47 +01:00
if (content_len == 0) {
puts("riot_get returned 0 bytes...aborting!");
return;
}
puts("####################################################");
big_buf[content_len] = '\0';
printf("data='%s'\n", big_buf);
puts("####################################################");
puts("done");
}
static void riot_ccn_register_prefix(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
if (argc < 4) {
puts("enter: prefix </path/to/abc> <type> <faceid>");
2014-01-06 10:10:47 +01:00
return;
}
strncpy(small_buf, argv[1], 100);
DEBUG("prefix='%s'\n", small_buf);
2014-01-06 10:10:47 +01:00
char *type = argv[2];
char *faceid = argv[3]; // 0=trans;1=msg
2014-01-06 10:10:47 +01:00
int content_len = ccnl_riot_client_publish(_relay_pid, small_buf, faceid, type, big_buf);
2014-01-06 10:10:47 +01:00
DEBUG("shell received: '%s'\n", big_buf);
DEBUG("received %d bytes.\n", content_len);
puts("done");
}
2014-06-30 21:43:46 +02:00
static void riot_ccn_relay_config(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
if (_relay_pid == KERNEL_PID_UNDEF) {
2014-06-30 21:43:46 +02:00
puts("ccnl stack not running");
2014-01-06 10:10:47 +01:00
return;
}
2014-02-24 23:39:23 +01:00
if (argc < 2) {
2014-06-30 21:43:46 +02:00
printf("%s: <max_cache_entries>\n", argv[0]);
return;
}
2014-06-30 21:43:46 +02:00
msg_t m;
m.content.value = atoi(argv[1]);
m.type = CCNL_RIOT_CONFIG_CACHE;
2014-10-20 16:49:40 +02:00
msg_send(&m, _relay_pid);
2014-06-30 21:43:46 +02:00
}
static void riot_ccn_transceiver_start(kernel_pid_t _relay_pid)
2014-06-30 21:43:46 +02:00
{
transceiver_init(TRANSCEIVER);
int transceiver_pid = transceiver_start();
DEBUG("transceiver on thread_id %d...\n", transceiver_pid);
/* register for transceiver events */
uint8_t reg = transceiver_register(TRANSCEIVER, _relay_pid);
2014-06-30 21:43:46 +02:00
if (reg != 1) {
DEBUG("transceiver register failed\n");
2014-01-06 10:10:47 +01:00
}
2014-06-30 21:43:46 +02:00
/* set channel to CCNL_CHAN */
msg_t mesg;
transceiver_command_t tcmd;
int32_t c = CCNL_DEFAULT_CHANNEL;
tcmd.transceivers = TRANSCEIVER;
tcmd.data = &c;
mesg.content.ptr = (char *) &tcmd;
mesg.type = SET_CHANNEL;
msg_send_receive(&mesg, &mesg, transceiver_pid);
if (c == -1) {
puts("[transceiver] Error setting/getting channel");
}
else {
2014-06-30 21:43:46 +02:00
printf("[transceiver] Got channel: %" PRIi32 "\n", c);
2014-01-06 10:10:47 +01:00
}
2014-06-30 21:43:46 +02:00
}
2014-01-06 10:10:47 +01:00
2014-06-30 21:43:46 +02:00
static void riot_ccn_relay_start(void)
{
if (_relay_pid != KERNEL_PID_UNDEF) {
DEBUG("ccn-lite relay on thread_id %d...please stop it first!\n", _relay_pid);
2014-06-30 21:43:46 +02:00
/* already running */
return;
2014-01-06 10:10:47 +01:00
}
_relay_pid = thread_create(
relay_stack, sizeof(relay_stack),
PRIORITY_MAIN - 2, CREATE_STACKTEST,
2014-07-18 20:35:32 +02:00
ccnl_riot_relay_start, NULL, "relay");
DEBUG("ccn-lite relay on thread_id %" PRIkernel_pid "...\n", _relay_pid);
2014-06-30 21:43:46 +02:00
riot_ccn_transceiver_start(_relay_pid);
2014-01-06 10:10:47 +01:00
}
2014-02-24 23:39:23 +01:00
static void riot_ccn_relay_stop(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
msg_t m;
m.content.value = 0;
m.type = CCNL_RIOT_HALT;
2014-10-20 16:49:40 +02:00
msg_send(&m, _relay_pid);
2014-01-06 10:10:47 +01:00
/* mark relay as not running */
_relay_pid = 0;
2014-01-06 10:10:47 +01:00
}
#if RIOT_CCN_TESTS
2014-02-24 23:39:23 +01:00
static void riot_ccn_pit_test(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
char name[] = "/riot/test";
char *prefix[CCNL_MAX_NAME_COMP];
char *cp = strtok(name, "/");
int i = 0;
while (i < (CCNL_MAX_NAME_COMP - 1) && cp) {
prefix[i++] = cp;
cp = strtok(NULL, "/");
}
//prefix[i] = 0; //segment to request
prefix[i + 1] = 0;
msg_t m;
riot_ccnl_msg_t rmsg;
char segment_string[16]; //max=999\0
2014-04-18 18:41:00 +02:00
timex_t now;
2014-01-06 10:10:47 +01:00
int segment;
for (segment = 0; segment < 200; segment++) {
memset(segment_string, 0, 16);
snprintf(segment_string, 16, "%d", segment);
prefix[i] = segment_string;
2014-02-10 20:53:28 +01:00
unsigned int interest_nonce = genrand_uint32();
int interest_len = mkInterest(prefix, &interest_nonce, (unsigned char *) small_buf);
2014-01-06 10:10:47 +01:00
rmsg.payload = &small_buf;
rmsg.size = interest_len;
m.content.ptr = (char *) &rmsg;
m.type = CCNL_RIOT_MSG;
2014-10-20 16:49:40 +02:00
msg_send(&m, _relay_pid);
2014-01-06 10:10:47 +01:00
if ((segment % 50) == 0) {
2014-04-18 18:41:00 +02:00
vtimer_now(&now);
2014-01-06 10:10:47 +01:00
printf("done: %d - %ld.%ld\n", segment, now.tv_sec, now.tv_usec);
}
}
printf("done: tried to send %d interests\n", segment);
}
2014-02-24 23:39:23 +01:00
static void riot_ccn_fib_test(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
char type[] = "newTRANSface";
char faceid[] = "42";
riot_new_face(_relay_pid, type, faceid, big_buf);
2014-01-06 10:10:47 +01:00
2014-04-18 18:41:00 +02:00
timex_t now;
2014-01-06 10:10:47 +01:00
int i = -1;
do {
i++;
snprintf(small_buf, sizeof(small_buf), "/riot/test/fib/%d/", i);
riot_register_prefix(_relay_pid, small_buf, faceid, big_buf);
2014-01-06 10:10:47 +01:00
if (i % 50 == 0) {
2014-04-18 18:41:00 +02:00
vtimer_now(&now);
2014-01-06 10:10:47 +01:00
printf("done: %d - %ld.%ld\n", i, now.tv_sec, now.tv_usec);
}
}
while (0 == strcmp((const char *) big_buf, "prefixreg cmd worked"));
DEBUG("%d: '%s'\n", i, big_buf);
printf("done: %d\n", i - 1);
}
#endif
2014-02-24 23:39:23 +01:00
static void riot_ccn_populate(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
msg_t m;
m.content.value = 0;
m.type = CCNL_RIOT_POPULATE;
2014-10-20 16:49:40 +02:00
msg_send(&m, _relay_pid);
2014-01-06 10:10:47 +01:00
}
2014-02-24 23:39:23 +01:00
static void riot_ccn_stat(int argc, char **argv)
2014-01-06 10:10:47 +01:00
{
2014-02-24 23:39:23 +01:00
(void) argc; /* the function takes no arguments */
(void) argv;
2014-01-06 10:10:47 +01:00
msg_t m;
m.content.value = 0;
m.type = CCNL_RIOT_PRINT_STAT;
2014-10-20 16:49:40 +02:00
msg_send(&m, _relay_pid);
2014-01-06 10:10:47 +01:00
}
static const shell_command_t sc[] = {
{ "haltccn", "stops ccn relay", riot_ccn_relay_stop },
{ "interest", "express an interest", riot_ccn_express_interest },
{ "populate", "populate the cache of the relay with data", riot_ccn_populate },
{ "prefix", "registers a prefix to a face", riot_ccn_register_prefix },
{ "stat", "prints out forwarding statistics", riot_ccn_stat },
2014-06-30 21:43:46 +02:00
{ "config", "changes the runtime config of the ccn lite relay", riot_ccn_relay_config },
2014-01-06 10:10:47 +01:00
#if RIOT_CCN_APPSERVER
{ "appserver", "starts an application server to reply to interests", riot_ccn_appserver },
#endif
#if RIOT_CCN_TESTS
{ "pittest", "starts a test for the size and speed of pit operations", riot_ccn_pit_test },
{ "fibtest", "starts a test for the size and speed of fib operations", riot_ccn_fib_test },
#endif
{ NULL, NULL, NULL }
};
2014-06-30 21:43:46 +02:00
int main(void)
2014-01-06 10:10:47 +01:00
{
2014-06-30 21:43:46 +02:00
puts("CCN!");
2014-01-06 10:10:47 +01:00
if (msg_init_queue(msg_buffer_shell, SHELL_MSG_BUFFER_SIZE) != 0) {
DEBUG("msg init queue failed...abording\n");
2014-06-30 21:43:46 +02:00
return -1;
2014-01-06 10:10:47 +01:00
}
2014-06-30 21:43:46 +02:00
riot_ccn_relay_start();
puts("starting shell...");
puts(" posix open");
2014-01-06 10:10:47 +01:00
posix_open(uart0_handler_pid, 0);
2014-06-30 21:43:46 +02:00
puts(" shell init");
2014-01-06 10:10:47 +01:00
shell_init(&shell, sc, UART0_BUFSIZE, uart0_readc, uart0_putc);
2014-06-30 21:43:46 +02:00
puts(" shell run");
2014-01-06 10:10:47 +01:00
shell_run(&shell);
return 0;
}