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
Lucas Jenss 426170b064 Improve naming of thread stacksize/priority constants
As discussed in #2725, this commit renames a number of stacksize constants to
better convey their intended usage. In addition, constants for thread priority
are given a `THREAD_` prefix. Changes are:

* KERNEL_CONF_STACKSIZE_PRINTF renamed to THREAD_EXTRA_STACKSIZE_PRINTF
* KERNEL_CONF_STACKSIZE_DEFAULT renamed to THREAD_STACKSIZE_DEFAULT
* KERNEL_CONF_STACKSIZE_IDLE renamed to THREAD_STACKSIZE_IDLE
* KERNEL_CONF_STACKSIZE_MAIN renamed to THREAD_STACKSIZE_MAIN
* Move thread stacksizes from kernel.h to thread.h, since the prefix changed
* PRIORITY_MIN renamed to THREAD_PRIORITY_MIN
* PRIORITY_IDLE renamed to THREAD_PRIORITY_IDLE
* PRIORITY_MAIN renamed to THREAD_PRIORITY_MAIN
* Move thread priorities from kernel.h to thread.h since the prefix has changed
* MINIMUM_STACK_SIZE renamed to THREAD_STACKSIZE_MINIMUM for consistency
2015-05-21 00:14:23 +02:00
..
util ccn-lite: use always ccnl_malloc 2014-11-11 21:51:52 +01:00
ccn-lite-relay.c ccnl: convert C++ comments into C style comments 2014-12-16 09:35:46 +01:00
ccnl-core.c *: add missing blank lines 2015-03-21 16:34:59 +01:00
ccnl-core.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnl-ext-appserver.c ccnl: correct debug output 2015-03-05 16:27:37 +01:00
ccnl-ext-debug.c
ccnl-ext-frag.c
ccnl-ext-mgmt.c
ccnl-ext.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnl-includes.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnl-pdu.c
ccnl-pdu.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnl-platform.c
ccnl-platform.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnl-riot-compat.c Improve naming of thread stacksize/priority constants 2015-05-21 00:14:23 +02:00
ccnl-riot-compat.h transceiver: use transceiver specific broadcast 2015-04-19 20:35:11 +02:00
ccnl.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
ccnx.h c++: sys: add extern C to header files 2014-11-08 20:09:55 +01:00
Makefile
README.md

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 the RIOT message system to the CCN-lite relay thread or via a physical network transceiver.

All incoming messages are processed in the main IO loop, which you can find here.

The public API of the ccn network stack is defined in sys/net/include/ccn_lite/ccnl-riot.h. Client related functions are defined in sys/net/include/ccn_lite/util/ccn-riot-client.h.

To work with the CCN-lite network stack, only these two API declarations need to be considered.

Running Test Application

Test applications are provided in the example directory.

ccn-lite-client

The CCN-lite client uses the RIOT shell for user interaction. The network stack is started on demand in its own thread. You have to enter ccn <CS size> in the shell. Further details are explained in examples/ccn-lite-client/README.md.

ccn-lite-relay

The CCN-lite relay is an application without interactive user control. Further details are explained in examples/ccn-lite-relay/README.md.

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.

Reference

If you are using this implementation in a scientific context, please cite the implementation as follows:

  • Emmanuel Baccelli, Christian Mehlis, Oliver Hahm, Thomas C. Schmidt, and Matthias Wählisch, "Information Centric Networking in the IoT: Experiments with NDN in the Wild," in Proc. of 1st ACM Conference on Information-Centric Networking (ICN). New York: ACM, pp. 77-86.

The paper is publicly available.

More

This README is still under construction.