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
René Kijewski f49bd3e660 make: add Makefile.features telling the BOARDs' features
Please see #1715.
Closes #1715.

This PR implements the new Makefile variables "FEATURES_PROVIDED" and
"FEATURES_REQUIRED". A board *can* have a new file `Makefile.features`
which looks like:

```make
FEATURES_PROVIDED = transceiver
```

An application can have a corresponding line

```make
FEATURES_REQUIRED = transceiver
```

If the selected BOARD does not fulfil the requirements of the
application, then a *warning* is issued at compile time.

This change only includes the feature "transceiver", further features
are expected to be listed in further PRs. The requirement "transceiver"
is automatically added if the application uses the module
"defaulttransceiver".

`make buildtest` understands the new feature listing, so the user won't
need to add boards to `BOARD_BLACKLIST` manually.

Part of the change are the added Make targets
* `info-features-missing`, which prints the required features
  `\setminus` the provided features. The output is empty if there are no
  features missing.
* `info-boards-features-missing`, the same as `info-features-missing`
  but as a table for all boards, but heeded `BOARD_WHITELIST` and
  `BOARD_BLACKLIST`.

Applications don't have to use this new feature. This change does not
break existing Makefile.
2014-10-06 17:42:11 +02:00
..
HOWTO ccnl: adapt HOWTO to new features 2014-07-18 20:08:29 +02:00
main.c lint: reduce scope 2014-09-12 11:50:12 +02:00
Makefile make: add Makefile.features telling the BOARDs' features 2014-10-06 17:42:11 +02:00
README.md Documentation: Create README.md for the CCN-lite client and relay 2014-05-26 14:11:30 +02:00

This application is a showcase of the Content Centric Networking (CCN) capabilities in RIOT.

The example consists in two parts: clients and relays.

This file documents the client functionalities.

A client opens a shell to enable the following:

  • start the CCN stack: The command ccn X starts the CCN stack and sets the content store size to X chunks. Chunk size is by default set to 802.15.4 packet payload (set it differently if needed). Note that X must be bigger or equal to 15 if you plan to publish content using Way 1 described below.

  • publishing content locally: Two alternative ways are defined to do that.

  • Way 1: pre-provision the local CCN stack cache with X dummy chunks, with the command populate. Chunk size is by default set to 802.15.4 packet payload (set it differently if needed). The default name of the content is /riot/text.

  • Way 2: start a application in a different thread with the command appserver. This application will register a prefix /riot/appserver/test in the CCN network stack Forwarding Information Base (FIB). Note that from the view of the CCN network stack, there is no difference between local faces connecting to local appplications and network faces connecting to real network interfaces. When the application recieves an interest it replies with chunck /riot/appserver/test/0. Note that actual interest parsing is not implemented in the application.

  • subscribing to receive content: the command interest fetches a remote file through the CCN network stack. This starts an application executed by the shell thread, which creates an interest message and routes this message hop by hop towards the publisher of the content (or a cache containing a copy) using the CCN stack. By default the content being fetched is /riot/text. One can also specify a name of content to fetch with the command interest valid-name. By valid, it is meant that the name should have structure like /a/b/c and the application will then request chunks with syntax /a/b/c/0 etc.