1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/net/ccn_lite
Christian Mehlis b675629a42 tune CCNL_RIOT_CHUNK_SIZE
this constant is used for two test cases:

1. populate + interest /riot/text
  -> static content has this=90 bytes size

2. appserver + interest /riot/appserver/test
  -> dynamic content is created with exact
     CCNL_RIOT_CHUNK_SIZE bytes
  -> CCNL_RIOT_CHUNK_SIZE can be any value the
     transceiver can handle
2013-11-29 21:47:08 +01:00
..
include tune CCNL_RIOT_CHUNK_SIZE 2013-11-29 21:47:08 +01:00
util get rid of static buffer 2013-11-29 21:47:08 +01:00
ccn-lite-relay.c get rid of static buffer 2013-11-29 21:47:08 +01:00
ccnl-core.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-core.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-ext-appserver.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-ext-debug.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-ext-frag.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-ext-mgmt.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-ext.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-includes.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-pdu.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-pdu.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-platform.c import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-platform.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl-riot-compat.c get rid of static buffer 2013-11-29 21:47:08 +01:00
ccnl-riot-compat.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnl.h import ccn lite 2013-11-07 00:37:38 +01:00
ccnx.h import ccn lite 2013-11-07 00:37:38 +01:00
Makefile import ccn lite 2013-11-07 00:37:38 +01:00
README.md import ccn lite 2013-11-07 00:37:38 +01:00

CCN lite port of RIOT

RIOT's support for CCN messages is based on the work of Christian Tschudin from University of Basel (CCN-lite code available here).

The network stack can handle multiple faces based on the transceiver or from the local device via RIOT's message system. To communicate with the stack, one can send messages via RIOTs message system to the CCN-lite relay thread or via a physical network transceiver.

All incoming messages get processed in the main io loop which you can find here.

The public api on the ccn network stack one can find in ccn_lite/include (see in file "ccnl-riot.h"). Client related functions are located in ccn_lite/include/util (see in file "ccn-riot-client.h").

To deal with the ccn lite network stack one only needs these two api declarations.

Running Test Application

A test applications are provided in the projects repository.

ccn-lite-client

It uses RIOTs shell for user interaction. The network stack is started on demand in it's own thread. You have to enter "ccn" in the shell.

A bunch of ccn user land code is provide to construct interests and content objects. To request a file e.g. /riot/text, the user land code request the first segment (chunk): /riot/text/0 and stalls until its received. If this chunk has the default chunk size the next chunk is requested, ... If a smaller chunk arrives the user land code prints out the complete file which was requested.

You can test this functionality by typing "interest /riot/test" in the shell. See HOWTO.md in the projects directory.

ccn-lite-relay

It's a stand alone ccn relay without interactive user control The network stack is started on boot up and is configured set the device address and to serve requests for "/riot/test". The ccn stack is ready to server requests coming over the transceiver.

Hardware support

The CCN-lite stack is currently tested and proved to run on the native port of RIOT and the MSBA2 embedded hardware. On the MSBA2 platform (32 Bit) CCN-lite only needs a stack of 800 bytes. It uses the heap for the CS, FIB and PIT.

More

This README is still under construction.