diff --git a/examples/iotivity_examples/README.md b/examples/iotivity_examples/README.md deleted file mode 100644 index 947b7ddadf58cd003b4f3bc9e66d058828d7ca13..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/README.md +++ /dev/null @@ -1,336 +0,0 @@ -IoTivity Examples -=============== -These examples implement some simple clients and a server to test the IoTivity package for RIOT-OS. The pkg is based on the [IoTivity-Constrained][1] library. -All examples use the realm-local multicast address **ff03:158** instead of the link-local multicast address **ff02::158**. Every payload is [CBOR][2] encoded. -All examples have been tested on Native and SAMR21-XPRO. -##Index - - [Iotivity Examples](#examples) - - [Server Example](#server_ex) - - [Client Example](#client_ex) - - [Client_Switch Example](#client_sw_ex) - - [BR_FW Example](#br_fw_ex) - - [Scenarios](#scenarios) - - [Node-to-Node Communications](#n2n_comm) - - [Server and Client (Periodic PUT) - native target](#sc_pput_native) - - [Server and Client (Periodic PUT) - SAMR21-XPRO target](#sc_pput_samr21) - - [Server and Client_Switch - SAMR21-XPRO target](#sc_sw_samr21) - - [Linux-to-Nodes Communications](#l2n_comm) - - [Preliminary Step](#l2n_pre) - - [Start the Server](#l2n_srv) - - [Start the Border Router](#l2n_br) - - [Server output](#l2n_out) - - [Testing](#l2n_tst) - - [Good Practice](#good) - -#<a name="examples"></a>Examples - -##<a name="server_ex"></a>Server Example -This example implements an IoTivity Server that contains 4 resources. - 1. */oic/res*: returns the representation of resources available on the server. Defined [here][3]. - 2. */oic/p*: returns information about the platform on which the server runs. Defined [here][3]. - 3. */oic/d*: returns information about the device on which the server runs. Defined [here][3]. - 4. */light/1* : it is a light (LED) management resource (implemented in resources/res-light.c). Resource Type: *oic.r.light*. - - GET: returns the status of the LED. The payload is: `{state: true/false}` - - PUT: changes the status of the LED. The payload is: `{state: true/false}` - - OBSERVE: the registered client is notified when the status changes. The payload is the same of the GET response. - -## <a name="client_ex"></a>Client Example -This example implements a simple client. It is able to discover resources with ResourceType *oic.r.light*. Once it finds a resource, it registers for OBSERVE notifications. It changes the status every second by sending a periodic PUT request. - -##<a name="client_sw_ex"></a>Client_Switch Example -This example implements a simple client. It is able to discover resources with ResourceType *oic.r.light*. Once it finds a resource, it registers for OBSERVE notifications. It changes the status when the User Button is pressed. If the button is not present it is just an observer. - -##<a name="br_fw_ex"></a>BR_FW Example -It is an "enhanced" version of the GNRC Border Router. It implements a simple forwarder (UDP server/client) for multicast requests with destination ff03::158 port 5683. - -#<a name="scenarios"></a>Scenarios -It is possible to deploy 2 different scenarios with these examples. - -##<a name="n2n_comm"></a>Node-to-Node Communications -In this scenario, we will deploy an IoTivity Client and IoTivity Server on different nodes. We can choose two different clients for this scenario: client (periodic PUT) or client_switch (PUT sent on User Button pressed). The first one runs well both on native either on SAMR21-XPRO boards, the second one runs just on SAMR21-XPRO boards. Native target hasn't the button. - -### <a name="sc_pput_native"></a>Server and Client (Periodic PUT) - native target -Create taps interfaces (to which RIOT will connect). Go to `/dist/tools/tapsetup` and type -``` -$ sudo ./tapsetup -c -``` -After this step we have created three tap interfaces: tap0, tap1 and tapbr0. -Now, we compile the server. Go to `/examples/iotivity-examples/server` and type -``` -$ make all BOARD=native -``` -Run the server by invoking -``` -$ sudo bin/native/ocf_server.elf tap0 -``` -The server output will be similar to this -``` -RIOT native interrupts/signals initialized. -LED_RED_OFF -LED_GREEN_ON -RIOT native board initialized. -RIOT native hardware initialization complete. - -main(): This is RIOT! (Version: 2017.01-devel-13-g2b77e-mattia-Latitude-E6410-pkg/iotivity) -server_oic: Waiting for address autoconfiguration...ipadapter: waiting for server requests... -ipadapter: waiting for multicast requests... -server_oic: LED0 is OFF -LED_RED_OFF -oc_main: Stack successfully initialized -server_oic: Configured network interfaces: -Iface 5 HWaddr: e6:e8:ff:6b:0c:f2 - - MTU:1500 HL:64 RTR RTR_ADV - Source address length: 6 - Link type: wired - inet6 addr: ff02::1/128 scope: local [multicast] - inet6 addr: fe80::e4e8:ffff:fe6b:cf2/64 scope: local - inet6 addr: ff02::1:ff6b:cf2/128 scope: local [multicast] - inet6 addr: ff02::2/128 scope: local [multicast] - inet6 addr: ff02::1a/128 scope: local [multicast] - inet6 addr: ff03::158/128 scope: global [multicast] -``` -It is waiting for requests. -Open a new terminal window, go to `/examples/iotivity-examples/client` and type -``` -$ make all BOARD=native -``` -Run the client by invoking -``` -$ sudo bin/native/ocf_client.elf tap1 -``` -The client runs and it starts with the discovery phase -``` -RIOT native interrupts/signals initialized. -LED_RED_OFF -LED_GREEN_ON -RIOT native board initialized. -RIOT native hardware initialization complete. - -main(): This is RIOT! (Version: 2017.01-devel-13-g2b77e-mattia-Latitude-E6410-pkg/iotivity) -LED_RED_OFF -client_oic: Waiting for address autoconfiguration...ipadapter: waiting for server requests... -ipadapter: waiting for multicast requests... -oc_main: Stack successfully initialized -client_oic: Configured network interfaces:Iface 5 HWaddr: a6:ab:89:bd:1f:80 - - MTU:1500 HL:64 RTR RTR_ADV - Source address length: 6 - Link type: wired - inet6 addr: ff02::1/128 scope: local [multicast] - inet6 addr: fe80::a4ab:89ff:febd:1f80/64 scope: local - inet6 addr: ff02::1:ffbd:1f80/128 scope: local [multicast] - inet6 addr: ff02::2/128 scope: local [multicast] - inet6 addr: ff02::1a/128 scope: local [multicast] - inet6 addr: ff03::158/128 scope: global [multicast] - -client_oic: continue discovery -Outgoing message to [ff03:0000:0000:0000:0000:0000:0000:0158]:5683 -client_oic: continue discovery -... -ipadapter: got server request -Incoming message from [fe80:0000:0000:0000:241c:c8ff:fe14:3d79]:56789 -ipadapter: waiting for server requests... -client_oic: Discovery done -client_oic: Ready... -LED_RED_ON -``` -Once the resource is discovered, the client registers as an Observer of the resource and it switches on its LED as notification of Discovery Completed. -From this point it will send a PUT request every second. -Client Output: -``` -client_oic: Sent PUT request -Outgoing message to [fe80:0000:0000:0000:241c:c8ff:fe14:3d79]:56789 -ipadapter: got server request -Incoming message from [fe80:0000:0000:0000:241c:c8ff:fe14:3d79]:56789 -ipadapter: waiting for server requests... -client_oic: PUT_light: -client_oic: PUT response OK -ipadapter: got server request -Incoming message from [fe80:0000:0000:0000:241c:c8ff:fe14:3d79]:56789 -ipadapter: waiting for server requests... -client_oic: OBSERVE_light: key state, value 0 -``` -Server output: -``` -Incoming message from [fe80:0000:0000:0000:a4ab:89ff:febd:1f80]:56789 -ipadapter: waiting for server requests... -server_oic: PUT request -server_oic: key: state value: 0 -server_oic: LED0 is OFF -LED_RED_OFF -Outgoing message to [fe80:0000:0000:0000:a4ab:89ff:febd:1f80]:56789 -server_oic: GET request -server_oic: Light state 0 -Outgoing message to [fe80:0000:0000:0000:a4ab:89ff:febd:1f80]:56789 -``` -TAPs interfaces can be easily deleted. Go to `/dist/tools/tapsetup` and type -``` -$ sudo ./tapsetup -d -``` - -###<a name="sc_pput_samr21"></a> Server and Client (Periodic PUT) - SAMR21-XPRO target -Now, we reproduce the previous scenario using two [SAMR21-XPRO][4] nodes. -Connect your nodes, go to `/examples/iotivity-examples/server` and check the list of USB-connected nodes by typing: -``` -$ make list-ttys -``` -The output will be similar to -``` -/sys/bus/usb/devices/2-1.3: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800001234', tty(s): ttyACM0 -/sys/bus/usb/devices/2-1.4: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800004321', tty(s): ttyACM1 -``` -We will use Serial Numbers in order to identify the designed node during the compilation phase. -Now, we compile the server -``` -$ make flash BOARD=samr21-xpro SERIAL=server_node_serial -``` -then we open the serial connection -``` -$ make term BOARD=samr21-xpro SERIAL=server_node_serial -``` -The server starts and it is waiting for incoming requests. -Now, open a new terminal window, go to `/examples/iotivity-examples/client` and type -``` -$ make flash BOARD=samr21-xpro SERIAL=client_node_serial -$ make term BOARD=samr21-xpro SERIAL=client_node_serial -``` -Client starts the discovery phase. Once it finds a resource (with ResourceType **oic.r.light**), it registers as an observer on the resource, then it switches on its LED and it finally starts with periodic PUT requests. The server LED will blink periodically. -Client and Server terminal outputs are similar to the outputs in case of native target. - -###<a name="sc_sw_samr21"></a> Server and Client_Switch - SAMR21-XPRO target -This deployment emulates a smart home scenario in which we have a SmartBulb (server) and a SmartSwitch (client_switch). It requires two SAMR21-XPRO nodes or similar. -Connect your nodes, go to `/examples/iotivity-examples/server` and check the list of USB-connected nodes by typing: -``` -$ make list-ttys -``` -The output will be similar to -``` -/sys/bus/usb/devices/2-1.3: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800001234', tty(s): ttyACM0 -/sys/bus/usb/devices/2-1.4: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800004321', tty(s): ttyACM1 -``` -We will use Serial Numbers in order to identify the designed node during the compilation phase. - -Now, we compile the server -``` -$ make flash BOARD=samr21-xpro SERIAL=server_node_serial -``` -then we open the serial connection -``` -$ make term BOARD=samr21-xpro SERIAL=server_node_serial -``` -The server starts and it is waiting for incoming requests. - -Now, we open a new terminal window, go to `/examples/iotivity-examples/client_switch` and type -``` -$ make flash BOARD=samr21-xpro SERIAL=client_node_serial -$ make term BOARD=samr21-xpro SERIAL=client_node_serial -``` -Client performs the discovery phase. Once it is completed, client registers as an Observer of the resource, then it switches on its LED. -Client is now ready to send a PUT request when the User Button is pressed. The server LED will change the status when the button is pressed. Terminal outputs are similar to outputs in previous examples. - -##<a name="l2n_comm"></a>Linux-to-Nodes communications -In this scenario, we will deploy an IoTivity server on a RIOT node and the IoTivity client will run on a Linux machine. This architecture requires the "enhanced" version of the Border Router [BR_FW](br_fw). It requires two SAMR21-XPRO nodes or similar. - -###<a name="l2n_pre"></a>Preliminary step -Connect your nodes, go to `/examples/iotivity-examples/server` and check the list of USB-connected nodes by typing: -``` -$ make list-ttys -``` -The output will be similar to -``` -/sys/bus/usb/devices/2-1.3: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800001234', tty(s): ttyACM0 -/sys/bus/usb/devices/2-1.4: Atmel Corp. EDBG CMSIS-DAP serial: 'ATML2127031800004321', tty(s): ttyACM1 -``` -We will use Serial Numbers in order to identify the designed node during the compilation phase. - -###<a name="l2n_srv"></a>Start the Server -Open a terminal window, go to `/examples/iotivity-examples/server` and type -``` -$ make flash BOARD=samr21-xpro SERIAL=server_node_serial -``` -then we open the serial connection -``` -$ make term BOARD=samr21-xpro SERIAL=server_node_serial -``` -The server starts the initialization phase, then it is ready for incoming requests. - -###<a name="l2n_br"></a>Start the Border Router -Step 1) Open a terminal window in `/example/iotivity-examples/br_fw/` and type -``` -$ make flash BOARD=samr21-xpro SERIAL=br_node_serial -``` -Step 2) Once the flashing is finished, we have to open a network interface. Type -``` -$ PORT=/dev/ttyACM0 make term -``` -Step 3) We have to complete the routing strategy on the BR, so in the RIOT shell type -``` -> ifconfig 7 add 2001:db8::2 -> fibroute add :: via 2001:db8::1 dev 7 -``` -Now the BR is ready. The network is configured as follow: -- Serial Port: **/dev/ttyACM0** -- Interface: **tap0** -- Address Prefix: **2001:db8::\64** -- Routing on tap0 of multicast packets with destination **ff03::158** - -It is possible to configure the network with different parameters by invoking directly the initialization script instead of executing the Step 2: -``` -$ make host-tools -$ sudo ./start_network_mcast.sh <serial-port> <tap-device> <IPv6-prefix> <IPv6-mcast> -``` -then run the Step 3 with the proper changes. - -We can check the reachability of the server by typing in another terminal window -``` -$ ping6 <IPv6 server> -``` -The IPv6 address of the server can be found by typing in the Border Router console: -``` -> routers -``` -The output will be similar to -``` -if Router state type ---------------------------------------------------- - 6 2001:db8::5859:1c2a:64c7:c48a REACHABLE REG -``` - -###<a name="l2n_out"></a>Server Output -Managing a GET request the output is like -``` -2016-11-04 14:39:32,115 - INFO # ipadapter: got server request -2016-11-04 14:39:32,121 - INFO # Incoming message from [2001:0db8:0000:0000:0000:0000:0000:0001]:56214 -2016-11-04 14:39:32,125 - INFO # ipadapter: waiting for server requests... -2016-11-04 14:39:32,128 - INFO # server_oic: GET request -2016-11-04 14:39:32,130 - INFO # server_oic: Light state 0 -2016-11-04 14:39:32,145 - INFO # Outgoing message to [2001:0db8:0000:0000:0000:0000:0000:0001]:56214 -``` -Managing a PUT request the output is like -``` -2016-11-04 14:39:35,119 - INFO # ipadapter: got server request -2016-11-04 14:39:35,125 - INFO # Incoming message from [2001:0db8:0000:0000:0000:0000:0000:0001]:56214 -2016-11-04 14:39:35,128 - INFO # ipadapter: waiting for server requests... -2016-11-04 14:39:35,134 - INFO # server_oic: PUT request -2016-11-04 14:39:35,136 - INFO # server_oic: key: state value: 1 -2016-11-04 14:39:35,138 - INFO # server_oic: LED0 is ON -2016-11-04 14:39:35,141 - INFO # Outgoing message to [2001:0db8:0000:0000:0000:0000:0000:0001]:56214 -``` - -###<a name="l2n_tst"></a>Testing -There are many different ways to test this scenario. - - - Tools: you can use [coap-cbor-cli][5] to perform get request. Put -c as argument. - - Iotivity Client: you can write an iotivity client that runs on Linux. [Here][6] and [Here][7] there are some sample clients that can be used to test this scenario. - -#<a name="good"></a>Good Practice -Discoveries and Requests are usually fast, but a timeout delay of some seconds on responses can be useful. In these examples, delays are set to 1 second for discoveries and they can be increased. For requests coming from a linux-based client, timeout delays should be higher (e.g. 5-10 seconds for discoveries and 3 seconds for requests). They can be tuned depending on the application. The minimum value is around 1 second. - -[1]: https://github.com/iotivity/iotivity-constrained/ -[2]: http://cbor.io/ -[3]: https://openconnectivity.org/resources/specifications -[4]: http://www.atmel.com/tools/ATSAMR21-XPRO.aspx -[5]: https://github.com/domabo/coap-cbor-cli -[6]: https://github.com/Agile-IoT/agile-iotivity/tree/master/IoTivity/Simple-Client-Linux -[7]: https://github.com/Agile-IoT/agile-iotivity/tree/master/IoTivity/Interactive-Client-Linux diff --git a/examples/iotivity_examples/br_fw/Makefile b/examples/iotivity_examples/br_fw/Makefile deleted file mode 100644 index f7d9388a43877a59a4daccd1696b7b88437ea712..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/br_fw/Makefile +++ /dev/null @@ -1,102 +0,0 @@ -# name of your application -APPLICATION = ocf_br_fw - -CFLAGS += -DOC_SERVER -CFLAGS += -DOC_CLIENT - -# If no BOARD is found in the environment, use this default: -BOARD ?= native - -# This has to be the absolute path to the RIOT base directory: -RIOTBASE ?= $(CURDIR)/../../.. - -BOARD_INSUFFICIENT_MEMORY := airfy-beacon chronos msb-430 msb-430h nrf51dongle \ - nrf6310 pca10000 pca10005 spark-core \ - stm32f0discovery telosb weio wsn430-v1_3b wsn430-v1_4 \ - yunjia-nrf51822 z1 nucleo-f072 - -# use ethos (ethernet over serial) for network communication and stdio over -# UART, but not on native, as native has a tap interface towards the host. -ifeq (,$(filter native,$(BOARD))) -GNRC_NETIF_NUMOF := 2 -USEMODULE += ethos gnrc_netdev2 - -# ethos baudrate can be configured from make command -ETHOS_BAUDRATE ?= 115200 -CFLAGS += '-DETHOS_UART=UART_DEV(0)' -DETHOS_BAUDRATE=$(ETHOS_BAUDRATE) -DUSE_ETHOS_FOR_STDIO -FEATURES_REQUIRED += periph_uart -endif - -# Include packages that pull up and auto-init the link layer. -# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present -USEMODULE += gnrc_netdev_default -USEMODULE += auto_init_gnrc_netif -# Specify the mandatory networking modules for 6LoWPAN border router -USEMODULE += gnrc_sixlowpan_border_router_default -# Add forwarding table -USEMODULE += fib -# Additional networking modules that can be dropped if not needed -USEMODULE += gnrc_icmpv6_echo -# Add also the shell, some shell commands -USEMODULE += shell -USEMODULE += shell_commands -USEMODULE += ps -#USEMODULE += gnrc_pktdump -# include UHCP client -USEMODULE += gnrc_uhcpc -#UDP -USEMODULE += gnrc_udp -USEMODULE += gnrc_conn_udp -#rpl -# Add a routing protocol -USEMODULE += gnrc_rpl -USEMODULE += auto_init_gnrc_rpl -USEMODULE += gnrc_ipv6_router_default -USEMODULE += gnrc_ndp_router -#Other modules -USEMODULE += pthread -USEMODULE += shell -USEMODULE += shell_commands - -SECURE ?= 0 -export SECURE - - -# Set a custom 802.15.4 channel if needed -DEFAULT_CHANNEL ?= 26 -CFLAGS += -DDEFAULT_CHANNEL=$(DEFAULT_CHANNEL) - -# Comment this out to disable code in RIOT that does safety checking -# which is not needed in a production environment but helps in the -# development process: -#CFLAGS += -DDEVELHELP - -# Use different settings when compiling for one of the following (low-memory) -# boards -LOW_MEMORY_BOARDS := nucleo-f334 - -ifneq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS))) -$(info Using low-memory configuration for iotivity_server.) -## low-memory tuning values -# lower pktbuf buffer size -CFLAGS += -DGNRC_PKTBUF_SIZE=1000 -# disable fib, rpl -DISABLE_MODULE += fib gnrc_rpl -USEMODULE += prng_minstd -endif - -# Change this to 0 show compiler invocation lines by default: -QUIET ?= 1 - -TAP ?= tap0 -IPV6_PREFIX ?= 2001:db8::/64 -IPV6_MCAST_OIC ?= ff03::158 - -include $(RIOTBASE)/Makefile.include -.PHONY: host-tools - -term: host-tools - $(Q) sudo ./start_network_mcast.sh $(PORT) $(TAP) $(IPV6_PREFIX) $(IPV6_MCAST_OIC) - -host-tools: - $(Q)env -u CC -u CFLAGS make -C $(RIOTBASE)/dist/tools diff --git a/examples/iotivity_examples/br_fw/main.c b/examples/iotivity_examples/br_fw/main.c deleted file mode 100644 index 290c83c1ed7339a2e3c2954585fc40169a2ace31..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/br_fw/main.c +++ /dev/null @@ -1,165 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file main.c - * @brief This is a BR with multicast forwarding for OIC discovery - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#include <stdio.h> - -#include "net/af.h" -#include "shell.h" -#include "xtimer.h" -#include "msg.h" -#include "net/gnrc.h" -#include "net/gnrc/conn.h" -#include "net/gnrc/ipv6.h" -#include "net/gnrc/rpl.h" -#include "net/gnrc/udp.h" -#include "net/conn/udp.h" -#include "thread.h" -#define MAIN_QUEUE_SIZE (8) -#define OIC_FW_QUEUE_SIZE (8) -#define MAX_PAYLOAD_SIZE (256) -#define MULTICAST_PORT (5683) - -#define PRINTipaddr(addr, port) \ - printf( \ - "[%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%" \ - "02x]:%d", \ - (addr)[0], (addr)[1], \ - (addr)[2], (addr)[3], \ - (addr)[4], (addr)[5], \ - (addr)[6], (addr)[7], \ - (addr)[8], (addr)[9], \ - (addr)[10], (addr)[11], \ - (addr)[12], (addr)[13], \ - (addr)[14], (addr)[15], \ - port) - -static uint8_t buffer2[MAX_PAYLOAD_SIZE]; - -static msg_t _oic_fw_msg_queue[OIC_FW_QUEUE_SIZE]; -static msg_t _main_msg_queue[MAIN_QUEUE_SIZE]; - -static kernel_pid_t interface_pid; - -char oic_forwarding_thread_stack[THREAD_STACKSIZE_DEFAULT]; - -uint8_t wk_addr[16] = { 0xff, 0x03, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0x01, 0x58 }; - -void handle_incoming_message(uint8_t *payload, int *size, uint8_t *addr, - uint8_t addr_len, uint16_t port) -{ - char *addr_str = NULL; - uint8_t buffer[*size]; - - memcpy(buffer, payload, *size); - - ipv6_addr_to_str(addr_str, (ipv6_addr_t *)addr, addr_len); - printf("forwarder: pck from "); - PRINTipaddr(addr, port); - printf("\n"); - printf("forwarder: payload size %d B\n", *size); - - conn_udp_sendto(buffer, *size, addr, 16, - wk_addr, 16, AF_INET6, - port, MULTICAST_PORT); -} - -void *start_oic_forwarding_loop(void *arg) -{ - (void)arg; - - msg_init_queue(_oic_fw_msg_queue, OIC_FW_QUEUE_SIZE); - - static uint8_t addr[16] = { 0 }; - uint8_t remote_addr[16] = { 0 }; - size_t remote_addr_len; - uint16_t remote_port; - - conn_udp_t conn; - - int n = conn_udp_create(&conn, addr, sizeof(addr), AF_INET6, MULTICAST_PORT); - - if (n != 0) { - printf("forwarder: failed to register multicast receive socket\n"); - return NULL; - } - - - ipv6_addr_t *if_addr = - gnrc_ipv6_netif_add_addr(interface_pid, (ipv6_addr_t *)&wk_addr, 128, 0); - - if (if_addr == NULL) { - printf("forwarder: error.. could not join multicast group\n"); - return NULL; - } - - gnrc_ipv6_netif_addr_get(if_addr)->valid = UINT32_MAX; - gnrc_ipv6_netif_addr_get(if_addr)->preferred = UINT32_MAX; - - while (1) { - printf("forwarder: waiting for multicast requests...\n"); - n = conn_udp_recvfrom(&conn, (char *)buffer2, MAX_PAYLOAD_SIZE, remote_addr, - &remote_addr_len, &remote_port); - if (n < 0) { - printf("forwarder_multicast_recv: error in conn_udp_recvfrom().n=%d\n", n); - continue; - } - - printf("forwarder: got multicast request\n"); - - handle_incoming_message(buffer2, &n, remote_addr, remote_addr_len, remote_port); - } - - return NULL; -} - - -int main(void) -{ - /* we need a message queue for the thread running the shell in order to - * receive potentially fast incoming networking packets */ - msg_init_queue(_main_msg_queue, MAIN_QUEUE_SIZE); - puts("RIOT border router + OIC discovery forwarder"); - - kernel_pid_t interfaces[GNRC_NETIF_NUMOF]; - size_t if_num = gnrc_netif_get(interfaces); - - if (if_num == 0) { - printf("forwarder: error.. no available network interface\n"); - return -1; - } - - interface_pid = interfaces[0]; - - thread_create(oic_forwarding_thread_stack, sizeof(oic_forwarding_thread_stack), - THREAD_PRIORITY_MAIN, THREAD_CREATE_STACKTEST, start_oic_forwarding_loop, - NULL, "oic_fw_thread"); - - /* start shell */ - puts("All up, running the shell now"); - char line_buf[SHELL_DEFAULT_BUFSIZE]; - shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE); - - - - /* should be never reached */ - return 0; -} diff --git a/examples/iotivity_examples/br_fw/start_network_mcast.sh b/examples/iotivity_examples/br_fw/start_network_mcast.sh deleted file mode 100755 index bbe6cf35f26df25dd756f1d839d957f93368eab3..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/br_fw/start_network_mcast.sh +++ /dev/null @@ -1,52 +0,0 @@ -#!/bin/sh - -ETHOS_DIR="$(dirname $(readlink -f $0))"/../../../dist/tools/ethos - -create_tap() { - ip tuntap add ${TAP} mode tap user ${USER} - ip link set ${TAP} up - sysctl -w net.ipv6.conf.${TAP}.forwarding=1 - sysctl -w net.ipv6.conf.${TAP}.accept_ra=0 - ip a a ${NETPREFIX}::1/64 dev ${TAP} - ip r d ${NETPREFIX}::/64 dev ${TAP} - ip r a ${NETPREFIX}::2 dev ${TAP} - ip r a ${NETPREFIX}::/64 via ${NETPREFIX}::2 dev ${TAP} metric 1 -} - -create_mcast_route() { - ip -6 route add ${IPMCAST} dev ${TAP} table local -} - -remove_tap() { - ip tuntap del ${TAP} mode tap -} - -cleanup() { - echo "Cleaning up..." - remove_tap - kill ${UHCPD_PID} - trap "" INT QUIT TERM EXIT -} - -start_uhcpd() { - ${UHCPD} ${TAP} ${PREFIX} > /dev/null & - UHCPD_PID=$! -} - -PORT=$1 -TAP=$2 -PREFIX=$3 -NETPREFIX=$(echo $3 | awk -v delimeter="::" '{split($0,a,delimeter)} END{print a[1]}') -IPMCAST=$4 - -UHCPD="$(readlink -f "${ETHOS_DIR}/../uhcpd/bin")/uhcpd" - -[ -z "${PORT}" -o -z "${TAP}" -o -z "${PREFIX}" -o -z "${IPMCAST}" ] && { - echo "usage: $0 <serial-port> <tap-device> <prefix> <ip-mcast>" - exit 1 -} - -trap "cleanup" INT QUIT TERM EXIT - - -create_tap && create_mcast_route && start_uhcpd && "${ETHOS_DIR}/ethos" ${TAP} ${PORT} diff --git a/examples/iotivity_examples/client/Makefile b/examples/iotivity_examples/client/Makefile deleted file mode 100644 index 2f4371cae4a30638ce726612820640b7feb7c29e..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client/Makefile +++ /dev/null @@ -1,69 +0,0 @@ -# name of your application -APPLICATION = ocf_client - -CFLAGS += -DOC_CLIENT - -# If no BOARD is found in the environment, use this default: -BOARD ?= native - -# This has to be the absolute path to the RIOT base directory: -RIOTBASE ?= $(CURDIR)/../../.. - -BOARD_INSUFFICIENT_MEMORY := airfy-beacon chronos msb-430 msb-430h nrf51dongle \ - nrf6310 pca10000 pca10005 spark-core \ - stm32f0discovery telosb weio wsn430-v1_3b wsn430-v1_4 \ - yunjia-nrf51822 z1 nucleo-f072 - -# Include packages that pull up and auto-init the link layer. -# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present -USEMODULE += gnrc_netdev_default -USEMODULE += auto_init_gnrc_netif -# Specify the mandatory networking modules for IPv6 and UDP -USEMODULE += gnrc_ipv6_router_default -USEMODULE += gnrc_udp -USEMODULE += gnrc_conn_udp -# Add a routing protocol -USEMODULE += gnrc_rpl -USEMODULE += auto_init_gnrc_rpl -# Additional networking modules that can be dropped if not needed -USEMODULE += gnrc_icmpv6_echo - -#Other modules -USEMODULE += pthread -USEMODULE += gnrc_ndp_router -USEMODULE += shell -USEMODULE += shell_commands - -USEPKG += iotivity - -SECURE ?= 0 -export SECURE - - -# Set a custom 802.15.4 channel if needed -DEFAULT_CHANNEL ?= 26 -CFLAGS += -DDEFAULT_CHANNEL=$(DEFAULT_CHANNEL) - -# Comment this out to disable code in RIOT that does safety checking -# which is not needed in a production environment but helps in the -# development process: -#CFLAGS += -DDEVELHELP - -# Use different settings when compiling for one of the following (low-memory) -# boards -LOW_MEMORY_BOARDS := nucleo-f334 - -ifneq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS))) -$(info Using low-memory configuration for iotivity_server.) -## low-memory tuning values -# lower pktbuf buffer size -CFLAGS += -DGNRC_PKTBUF_SIZE=1000 -# disable fib, rpl -DISABLE_MODULE += fib gnrc_rpl -USEMODULE += prng_minstd -endif - -# Change this to 0 show compiler invocation lines by default: -QUIET ?= 1 - -include $(RIOTBASE)/Makefile.include diff --git a/examples/iotivity_examples/client/client.c b/examples/iotivity_examples/client/client.c deleted file mode 100644 index 5ecf8da18aeb33ceccc05e11399e4db8e8252681..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client/client.c +++ /dev/null @@ -1,247 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file client.c - * @brief This is a simple IoTivity Client - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ -#include "oc_api.h" -#include "pthread_cond.h" -#include "thread.h" -#include "xtimer.h" - -#define MAX_URI_LENGTH (30) - -static void observe_light(oc_client_response_t *data); -extern int _netif_config(int argc, char **argv); - -static int quit; -static mutex_t mutex; -static pthread_cond_t cv; -static struct timespec ts; -static bool got_discovery_response = false; -static bool observe_stopped = false; -static char light_1[MAX_URI_LENGTH]; -static oc_server_handle_t light_server; -static bool light_state = false; - -static char _oc_main_stack[THREAD_STACKSIZE_MAIN]; -#define OC_QUEUE_SIZE (8) -static msg_t _oc_msg_queue[OC_QUEUE_SIZE]; - -static void -set_device_custom_property(void *data) -{ - oc_set_custom_device_property(purpose, "operate lamp"); -} - -static void -set_led_state(bool led_state) -{ - if (led_state) { - LED0_ON; - } - else { - LED0_OFF; - } -} - -static void -app_init(void) -{ - oc_init_platform("RIOT-OS", NULL, NULL); - oc_add_device("/oic/d", "oic.d.switch", "RIOT switch", "1.0", "1.0", - set_device_custom_property, NULL); -} - -static oc_event_callback_retval_t -stop_observe(void *data) -{ - PRINT("client_oic: Stopping OBSERVE\n"); - oc_stop_observe(light_1, &light_server); - observe_stopped = true; - return DONE; -} - -static void -put_light(oc_client_response_t *data) -{ - PRINT("client_oic: PUT_light:\n"); - if (data->code == OC_STATUS_CHANGED) { - PRINT("client_oic: PUT response OK\n"); - } - else { - PRINT("client_oic: PUT response code %d\n", data->code); - } -} - -static void -observe_light(oc_client_response_t *data) -{ - PRINT("client_oic: OBSERVE_light: "); - oc_rep_t *rep = data->payload; - while (rep != NULL) { - PRINT("key %s, value ", oc_string(rep->name)); - switch (rep->type) { - case BOOL: - PRINT("%d\n", rep->value_boolean); - light_state = rep->value_boolean; - break; - default: - break; - } - rep = rep->next; - } -} - -static oc_discovery_flags_t -discovery(const char *di, const char *uri, oc_string_array_t types, - oc_interface_mask_t interfaces, oc_server_handle_t *server, - void *user_data) -{ - int i; - int uri_len = strlen(uri); - - uri_len = (uri_len >= MAX_URI_LENGTH) ? MAX_URI_LENGTH - 1 : uri_len; - - for (i = 0; i < oc_string_array_get_allocated_size(types); i++) { - char *t = oc_string_array_get_item(types, i); - if (strlen(t) == 11 && strncmp(t, "oic.r.light", 11) == 0) { - memcpy(&light_server, server, sizeof(oc_server_handle_t)); - - strncpy(light_1, uri, uri_len); - light_1[uri_len] = '\0'; - - got_discovery_response = true; - - return OC_STOP_DISCOVERY; - } - } - return OC_CONTINUE_DISCOVERY; -} - -static oc_event_callback_retval_t -periodic_put(void *data) -{ - if (observe_stopped) { - PRINT("client_oic: Stop periodic PUT\n"); - return DONE; - } - - if (oc_init_put(light_1, &light_server, NULL, &put_light, HIGH_QOS, NULL)) { - oc_rep_start_root_object(); - oc_rep_set_boolean(root, state, !light_state); - oc_rep_end_root_object(); - if (oc_do_put()) { - PRINT("client_oic: Sent PUT request\n"); - } - else { - PRINT("client_oic: Could not send PUT\n"); - } - } - else { - PRINT("client_oic: Could not init PUT\n"); - } - return CONTINUE; -} - -static oc_event_callback_retval_t -do_discovery(void *data) -{ - if (got_discovery_response) { - PRINT("client_oic: Discovery done\n"); - PRINT("client_oic: Ready...\n"); - oc_do_observe(light_1, &light_server, NULL, &observe_light, LOW_QOS, NULL); - oc_set_delayed_callback(NULL, &periodic_put, 1); - oc_set_delayed_callback(NULL, &stop_observe, 100); - set_led_state(true); - return DONE; - } - oc_do_ip_discovery("oic.r.light", &discovery, NULL); - PRINT("client_oic: continue discovery\n"); - return CONTINUE; -} - -static void -issue_requests(void) -{ - oc_set_delayed_callback(NULL, &do_discovery, 1); -} - -static void -signal_event_loop_func(void) -{ - mutex_lock(&mutex); - pthread_cond_signal(&cv); - mutex_unlock(&mutex); -} - -void * -oc_main_thread(void *arg) -{ - (void)arg; - - pthread_cond_init(&cv, NULL); - - static const oc_handler_t handler = { .init = app_init, - .signal_event_loop = signal_event_loop_func, - .requests_entry = issue_requests }; - - msg_init_queue(_oc_msg_queue, OC_QUEUE_SIZE); - - if (oc_main_init(&handler) < 0) { - PRINT("client_oic: failed to initialize stack\n"); - return NULL; - } - PRINT("client_oic: Configured network interfaces:"); - _netif_config(0, NULL); - - oc_clock_time_t next_event; - while (quit == 0) { - next_event = oc_main_poll(); - mutex_lock(&mutex); - if (next_event == 0) { - pthread_cond_wait(&cv, &mutex); - } - else if (oc_clock_time() < next_event) { - ts.tv_sec = (next_event / OC_CLOCK_SECOND); - ts.tv_nsec = (next_event % OC_CLOCK_SECOND) * 1.e09 / OC_CLOCK_SECOND; - pthread_cond_timedwait(&cv, &mutex, &ts); - } - mutex_unlock(&mutex); - } - - oc_main_shutdown(); - - return NULL; -} - -int -main(void) -{ - set_led_state(false); - PRINT("client_oic: Waiting for address autoconfiguration..."); - xtimer_sleep(10); - thread_create(_oc_main_stack, sizeof(_oc_main_stack), 2, 0, oc_main_thread, - NULL, "OCF event thread"); - - fgetc(stdin); - - quit = 1; - signal_event_loop_func(); - - return 0; -} diff --git a/examples/iotivity_examples/client/config.h b/examples/iotivity_examples/client/config.h deleted file mode 100644 index a634772ee70782fef6fe01c57d1dfa9401f7e1f7..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client/config.h +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file config.c - * @brief This is a configuration file for IoTivity environment - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#ifndef CONFIG_H -#define CONFIG_H - -#define OC_DEBUG 0 - -#ifdef __cplusplus -extern "C" { -#endif - -/* Time resolution */ -#include <stdint.h> -typedef uint64_t oc_clock_time_t; -/* 1 clock tick = 1ms */ -#define OC_CLOCK_CONF_TICKS_PER_SECOND (1000) - -#define OC_BYTES_POOL_SIZE (900) -#define OC_INTS_POOL_SIZE (4) -#define OC_DOUBLES_POOL_SIZE (4) - -/* Server-side parameters */ -/* Maximum number of server resources */ -#define MAX_APP_RESOURCES (1) - -/* Common paramters */ -/* Maximum number of concurrent requests */ -#define MAX_NUM_CONCURRENT_REQUESTS (2) - -/* Estimated number of nodes in payload tree structure */ -#define EST_NUM_REP_OBJECTS (60) - -/* Maximum size of request/response PDUs */ -#define MAX_PAYLOAD_SIZE (512) - -/* Number of devices on the OCF platform */ -#define MAX_NUM_DEVICES (1) - -/* Platform payload size */ -#define MAX_PLATFORM_PAYLOAD_SIZE (256) - -/* Device payload size */ -#define MAX_DEVICE_PAYLOAD_SIZE (256) - -/* Security layer */ -/* Maximum number of authorized clients */ -#define MAX_NUM_SUBJECTS (1) - -/* Maximum number of concurrent DTLS sessions */ -#define MAX_DTLS_PEERS (1) - -/* Max inactivity timeout before tearing down DTLS connection */ -#define DTLS_INACTIVITY_TIMEOUT (10) - -#ifdef __cplusplus -} -#endif - -#endif /* CONFIG_H */ diff --git a/examples/iotivity_examples/client_switch/Makefile b/examples/iotivity_examples/client_switch/Makefile deleted file mode 100644 index 2f4371cae4a30638ce726612820640b7feb7c29e..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client_switch/Makefile +++ /dev/null @@ -1,69 +0,0 @@ -# name of your application -APPLICATION = ocf_client - -CFLAGS += -DOC_CLIENT - -# If no BOARD is found in the environment, use this default: -BOARD ?= native - -# This has to be the absolute path to the RIOT base directory: -RIOTBASE ?= $(CURDIR)/../../.. - -BOARD_INSUFFICIENT_MEMORY := airfy-beacon chronos msb-430 msb-430h nrf51dongle \ - nrf6310 pca10000 pca10005 spark-core \ - stm32f0discovery telosb weio wsn430-v1_3b wsn430-v1_4 \ - yunjia-nrf51822 z1 nucleo-f072 - -# Include packages that pull up and auto-init the link layer. -# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present -USEMODULE += gnrc_netdev_default -USEMODULE += auto_init_gnrc_netif -# Specify the mandatory networking modules for IPv6 and UDP -USEMODULE += gnrc_ipv6_router_default -USEMODULE += gnrc_udp -USEMODULE += gnrc_conn_udp -# Add a routing protocol -USEMODULE += gnrc_rpl -USEMODULE += auto_init_gnrc_rpl -# Additional networking modules that can be dropped if not needed -USEMODULE += gnrc_icmpv6_echo - -#Other modules -USEMODULE += pthread -USEMODULE += gnrc_ndp_router -USEMODULE += shell -USEMODULE += shell_commands - -USEPKG += iotivity - -SECURE ?= 0 -export SECURE - - -# Set a custom 802.15.4 channel if needed -DEFAULT_CHANNEL ?= 26 -CFLAGS += -DDEFAULT_CHANNEL=$(DEFAULT_CHANNEL) - -# Comment this out to disable code in RIOT that does safety checking -# which is not needed in a production environment but helps in the -# development process: -#CFLAGS += -DDEVELHELP - -# Use different settings when compiling for one of the following (low-memory) -# boards -LOW_MEMORY_BOARDS := nucleo-f334 - -ifneq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS))) -$(info Using low-memory configuration for iotivity_server.) -## low-memory tuning values -# lower pktbuf buffer size -CFLAGS += -DGNRC_PKTBUF_SIZE=1000 -# disable fib, rpl -DISABLE_MODULE += fib gnrc_rpl -USEMODULE += prng_minstd -endif - -# Change this to 0 show compiler invocation lines by default: -QUIET ?= 1 - -include $(RIOTBASE)/Makefile.include diff --git a/examples/iotivity_examples/client_switch/client_switch.c b/examples/iotivity_examples/client_switch/client_switch.c deleted file mode 100644 index 21c4d43ff8cee309e16ed2ff608bad9735678eba..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client_switch/client_switch.c +++ /dev/null @@ -1,253 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file client_switch.c - * @brief This is an Iotivity client. It sends a PUT when the - * User button is pressed. - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#include "oc_api.h" -#include "pthread_cond.h" -#include "thread.h" -#include "xtimer.h" -#include "periph/gpio.h" - -#define MAX_URI_LENGTH (30) - -static void observe_light(oc_client_response_t *data); -extern int _netif_config(int argc, char **argv); - -static int quit; -static mutex_t mutex; -static pthread_cond_t cv; -static struct timespec ts; -static bool got_discovery_response = false; -static char light_1[MAX_URI_LENGTH]; -static oc_server_handle_t light_server; -static bool light_state = false; -static bool led_state = false; - -static char _oc_main_stack[THREAD_STACKSIZE_MAIN]; - -static void -set_led_state(bool led_state) -{ - if (led_state) { - LED0_ON; - } - else { - LED0_OFF; - } -} - -static void -set_device_custom_property(void *data) -{ - oc_set_custom_device_property(purpose, "operate lamp"); -} - -static void -app_init(void) -{ - oc_init_platform("RIOT-OS", NULL, NULL); - oc_add_device("/oic/d", "oic.d.switch", "RIOT switch", "1.0", "1.0", - set_device_custom_property, NULL); -} - -static oc_event_callback_retval_t -stop_observe(void *data) -{ - PRINT("client_oic: Stopping OBSERVE\n"); - oc_stop_observe(light_1, &light_server); - return DONE; -} - -#ifdef BUTTON_GPIO -static void -put_light(oc_client_response_t *data) -{ - PRINT("client_oic: PUT_light:\n"); - if (data->code == OC_STATUS_CHANGED) { - PRINT("client_oic: PUT response OK\n"); - } - else { - PRINT("client_oic: PUT response code %d\n", data->code); - } -} -#endif - -static void -observe_light(oc_client_response_t *data) -{ - PRINT("client_oic: OBSERVE_light: "); - oc_rep_t *rep = data->payload; - while (rep != NULL) { - PRINT("key %s, value ", oc_string(rep->name)); - switch (rep->type) { - case BOOL: - PRINT("%d\n", rep->value_boolean); - light_state = rep->value_boolean; - break; - default: - break; - } - rep = rep->next; - } -} - -static oc_discovery_flags_t -discovery(const char *di, const char *uri, oc_string_array_t types, - oc_interface_mask_t interfaces, oc_server_handle_t *server, - void *user_data) -{ - int i; - int uri_len = strlen(uri); - - uri_len = (uri_len >= MAX_URI_LENGTH) ? MAX_URI_LENGTH - 1 : uri_len; - - for (i = 0; i < oc_string_array_get_allocated_size(types); i++) { - char *t = oc_string_array_get_item(types, i); - if (strlen(t) == 11 && strncmp(t, "oic.r.light", 11) == 0) { - memcpy(&light_server, server, sizeof(oc_server_handle_t)); - - strncpy(light_1, uri, uri_len); - light_1[uri_len] = '\0'; - - got_discovery_response = true; - - return OC_STOP_DISCOVERY; - } - } - return OC_CONTINUE_DISCOVERY; -} - -#ifdef BUTTON_GPIO -void button_callback(void) -{ - gpio_irq_disable(BUTTON_GPIO); - if (oc_init_put(light_1, &light_server, NULL, &put_light, HIGH_QOS, NULL)) { - oc_rep_start_root_object(); - oc_rep_set_boolean(root, state, !light_state); - oc_rep_end_root_object(); - if (oc_do_put()) { - PRINT("client_oic: Sent PUT request\n"); - } - else { - PRINT("client_oic: Could not send PUT\n"); - } - } - else { - PRINT("client_oic: Could not init PUT\n"); - } - xtimer_usleep(140000); - gpio_irq_enable(BUTTON_GPIO); -} -#endif - -static oc_event_callback_retval_t -operate(void *data) -{ - PRINT("client_oic: Ready...\n"); - set_led_state(true); - oc_do_observe(light_1, &light_server, NULL, &observe_light, LOW_QOS, NULL); -#ifdef BUTTON_GPIO - gpio_init_int(BUTTON_GPIO, GPIO_IN_PU, GPIO_RISING, (gpio_cb_t)button_callback, NULL); -#endif - oc_set_delayed_callback(NULL, &stop_observe, 10000); - return DONE; -} - -static oc_event_callback_retval_t -do_discovery(void *data) -{ - if (got_discovery_response) { - PRINT("client_oic: Discovery done\n"); - oc_set_delayed_callback(NULL, &operate, 1); - return DONE; - } - oc_do_ip_discovery("oic.r.light", &discovery, NULL); - PRINT("client_oic: continue discovery\n"); - return CONTINUE; -} - -static void -issue_requests(void) -{ - oc_set_delayed_callback(NULL, &do_discovery, 1); -} - -static void -signal_event_loop_func(void) -{ - mutex_lock(&mutex); - pthread_cond_signal(&cv); - mutex_unlock(&mutex); -} - -void * -oc_main_thread(void *arg) -{ - (void)arg; - - pthread_cond_init(&cv, NULL); - - static const oc_handler_t handler = { .init = app_init, - .signal_event_loop = signal_event_loop_func, - .requests_entry = issue_requests }; - if (oc_main_init(&handler) < 0) { - PRINT("client_oic: failed to initialize stack\n"); - return NULL; - } - PRINT("client_oic: Configured network interfaces:"); - _netif_config(0, NULL); - - oc_clock_time_t next_event; - while (quit == 0) { - next_event = oc_main_poll(); - mutex_lock(&mutex); - if (next_event == 0) { - pthread_cond_wait(&cv, &mutex); - } - else if (oc_clock_time() < next_event) { - ts.tv_sec = (next_event / OC_CLOCK_SECOND); - ts.tv_nsec = (next_event % OC_CLOCK_SECOND) * 1.e09 / OC_CLOCK_SECOND; - pthread_cond_timedwait(&cv, &mutex, &ts); - } - mutex_unlock(&mutex); - } - - oc_main_shutdown(); - - return NULL; -} - -int -main(void) -{ - set_led_state(led_state); - PRINT("client_oic: Waiting for address autoconfiguration..."); - xtimer_sleep(10); - thread_create(_oc_main_stack, sizeof(_oc_main_stack), 2, 0, oc_main_thread, - NULL, "OCF event thread"); - - fgetc(stdin); - - quit = 1; - signal_event_loop_func(); - - return 0; -} diff --git a/examples/iotivity_examples/client_switch/config.h b/examples/iotivity_examples/client_switch/config.h deleted file mode 100644 index a634772ee70782fef6fe01c57d1dfa9401f7e1f7..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/client_switch/config.h +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file config.c - * @brief This is a configuration file for IoTivity environment - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#ifndef CONFIG_H -#define CONFIG_H - -#define OC_DEBUG 0 - -#ifdef __cplusplus -extern "C" { -#endif - -/* Time resolution */ -#include <stdint.h> -typedef uint64_t oc_clock_time_t; -/* 1 clock tick = 1ms */ -#define OC_CLOCK_CONF_TICKS_PER_SECOND (1000) - -#define OC_BYTES_POOL_SIZE (900) -#define OC_INTS_POOL_SIZE (4) -#define OC_DOUBLES_POOL_SIZE (4) - -/* Server-side parameters */ -/* Maximum number of server resources */ -#define MAX_APP_RESOURCES (1) - -/* Common paramters */ -/* Maximum number of concurrent requests */ -#define MAX_NUM_CONCURRENT_REQUESTS (2) - -/* Estimated number of nodes in payload tree structure */ -#define EST_NUM_REP_OBJECTS (60) - -/* Maximum size of request/response PDUs */ -#define MAX_PAYLOAD_SIZE (512) - -/* Number of devices on the OCF platform */ -#define MAX_NUM_DEVICES (1) - -/* Platform payload size */ -#define MAX_PLATFORM_PAYLOAD_SIZE (256) - -/* Device payload size */ -#define MAX_DEVICE_PAYLOAD_SIZE (256) - -/* Security layer */ -/* Maximum number of authorized clients */ -#define MAX_NUM_SUBJECTS (1) - -/* Maximum number of concurrent DTLS sessions */ -#define MAX_DTLS_PEERS (1) - -/* Max inactivity timeout before tearing down DTLS connection */ -#define DTLS_INACTIVITY_TIMEOUT (10) - -#ifdef __cplusplus -} -#endif - -#endif /* CONFIG_H */ diff --git a/examples/iotivity_examples/server/Makefile b/examples/iotivity_examples/server/Makefile deleted file mode 100644 index dbbc3c30c1b7243d2677b235922166e07ba5d938..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/server/Makefile +++ /dev/null @@ -1,83 +0,0 @@ -# name of your application -APPLICATION = ocf_server - -CFLAGS += -DOC_SERVER - -# If no BOARD is found in the environment, use this default: -BOARD ?= native - -# This has to be the absolute path to the RIOT base directory: -RIOTBASE ?= $(CURDIR)/../../.. - -BOARD_INSUFFICIENT_MEMORY := airfy-beacon chronos msb-430 msb-430h nrf51dongle \ - nrf6310 pca10000 pca10005 spark-core \ - stm32f0discovery telosb weio wsn430-v1_3b wsn430-v1_4 \ - yunjia-nrf51822 z1 nucleo-f072 - -#Add IoTivity resources -RES_SRC = $(wildcard ./resources/*.c) -RES_OBJ = $(RES_SRC:.c=.o) -APPDEPS += ${RES_OBJ} - - -# Include packages that pull up and auto-init the link layer. -# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present -USEMODULE += gnrc_netdev_default -USEMODULE += auto_init_gnrc_netif -# Specify the mandatory networking modules for IPv6 and UDP -USEMODULE += gnrc_ipv6_router_default -USEMODULE += gnrc_udp -USEMODULE += gnrc_conn_udp -# Add a routing protocol -USEMODULE += gnrc_rpl -USEMODULE += auto_init_gnrc_rpl -# Additional networking modules that can be dropped if not needed -USEMODULE += gnrc_icmpv6_echo - -#Other modules -USEMODULE += pthread -USEMODULE += gnrc_ndp_router -USEMODULE += shell -USEMODULE += shell_commands - -USEPKG += iotivity - -SECURE ?= 0 -export SECURE - - -# Set a custom 802.15.4 channel if needed -DEFAULT_CHANNEL ?= 26 -CFLAGS += -DDEFAULT_CHANNEL=$(DEFAULT_CHANNEL) - -# Comment this out to disable code in RIOT that does safety checking -# which is not needed in a production environment but helps in the -# development process: -#CFLAGS += -DDEVELHELP - -# Use different settings when compiling for one of the following (low-memory) -# boards -LOW_MEMORY_BOARDS := nucleo-f334 - -ifneq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS))) -$(info Using low-memory configuration for iotivity_server.) -## low-memory tuning values -# lower pktbuf buffer size -CFLAGS += -DGNRC_PKTBUF_SIZE=1000 -# disable fib, rpl -DISABLE_MODULE += fib gnrc_rpl -USEMODULE += prng_minstd -endif - -# Change this to 0 show compiler invocation lines by default: -QUIET ?= 1 - -include $(RIOTBASE)/Makefile.include - -%.o: %.c - ${CC} -c -o $@ $< ${CFLAGS} ${INCLUDES} - -clean: clean_resources - -clean_resources: - rm -rf ${RES_OBJ} diff --git a/examples/iotivity_examples/server/config.h b/examples/iotivity_examples/server/config.h deleted file mode 100644 index a634772ee70782fef6fe01c57d1dfa9401f7e1f7..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/server/config.h +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file config.c - * @brief This is a configuration file for IoTivity environment - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#ifndef CONFIG_H -#define CONFIG_H - -#define OC_DEBUG 0 - -#ifdef __cplusplus -extern "C" { -#endif - -/* Time resolution */ -#include <stdint.h> -typedef uint64_t oc_clock_time_t; -/* 1 clock tick = 1ms */ -#define OC_CLOCK_CONF_TICKS_PER_SECOND (1000) - -#define OC_BYTES_POOL_SIZE (900) -#define OC_INTS_POOL_SIZE (4) -#define OC_DOUBLES_POOL_SIZE (4) - -/* Server-side parameters */ -/* Maximum number of server resources */ -#define MAX_APP_RESOURCES (1) - -/* Common paramters */ -/* Maximum number of concurrent requests */ -#define MAX_NUM_CONCURRENT_REQUESTS (2) - -/* Estimated number of nodes in payload tree structure */ -#define EST_NUM_REP_OBJECTS (60) - -/* Maximum size of request/response PDUs */ -#define MAX_PAYLOAD_SIZE (512) - -/* Number of devices on the OCF platform */ -#define MAX_NUM_DEVICES (1) - -/* Platform payload size */ -#define MAX_PLATFORM_PAYLOAD_SIZE (256) - -/* Device payload size */ -#define MAX_DEVICE_PAYLOAD_SIZE (256) - -/* Security layer */ -/* Maximum number of authorized clients */ -#define MAX_NUM_SUBJECTS (1) - -/* Maximum number of concurrent DTLS sessions */ -#define MAX_DTLS_PEERS (1) - -/* Max inactivity timeout before tearing down DTLS connection */ -#define DTLS_INACTIVITY_TIMEOUT (10) - -#ifdef __cplusplus -} -#endif - -#endif /* CONFIG_H */ diff --git a/examples/iotivity_examples/server/resources/res-light.c b/examples/iotivity_examples/server/resources/res-light.c deleted file mode 100644 index a2e8b6831a1c48df4f4faf14fa91166309095da4..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/server/resources/res-light.c +++ /dev/null @@ -1,108 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file res-light.c - * @brief Resource light definition. Handler are defined here. - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#include "oc_api.h" -#include "board.h" - - -static oc_resource_t *res_light = NULL; -static bool res_light_state = false; - -static void -res_light_set_led_state(bool light_state) -{ - if (light_state) { - PRINT("server_oic: LED0 is ON\n"); - LED0_ON; - } - else { - PRINT("server_oic: LED0 is OFF\n"); - LED0_OFF; - } -} - - -static void -res_light_get_handler(oc_request_t *request, oc_interface_mask_t interface, void *user_data) -{ - PRINT("server_oic: GET request\n"); - oc_rep_start_root_object(); - switch (interface) { - case OC_IF_BASELINE: - oc_process_baseline_interface(request->resource); - case OC_IF_RW: - oc_rep_set_boolean(root, state, res_light_state); - break; - default: - break; - } - oc_rep_end_root_object(); - oc_send_response(request, OC_STATUS_OK); - PRINT("server_oic: Light state %d\n", res_light_state); -} - -static void -res_light_put_handler(oc_request_t *request, oc_interface_mask_t interface, void *user_data) -{ - PRINT("server_oic: PUT request\n"); - bool state = false; - oc_rep_t *rep = request->request_payload; - - while (rep != NULL) { - PRINT("server_oic: key: %s ", oc_string(rep->name)); - switch (rep->type) { - case BOOL: - state = rep->value_boolean; - PRINT("value: %d\n", state); - break; - default: - oc_send_response(request, OC_STATUS_BAD_REQUEST); - return; - break; - } - rep = rep->next; - } - oc_send_response(request, OC_STATUS_CHANGED); - res_light_state = state; - res_light_set_led_state(res_light_state); -} - -void -res_light_register(void) -{ - res_light = oc_new_resource("/light/1", 1, 0); - oc_resource_bind_resource_type(res_light, "oic.r.light"); - oc_resource_bind_resource_interface(res_light, OC_IF_RW); - oc_resource_set_default_interface(res_light, OC_IF_RW); - -//TODO: Security is not supported by the pkg -#ifdef OC_SECURITY - oc_resource_make_secure(res_light); -#endif - - oc_resource_set_discoverable(res_light, true); - oc_resource_set_observable(res_light, true); - oc_resource_set_request_handler(res_light, OC_GET, res_light_get_handler, NULL); - oc_resource_set_request_handler(res_light, OC_PUT, res_light_put_handler, NULL); - oc_add_resource(res_light); - - res_light_set_led_state(false); //RIMANE TRUE... PERCHe' -} diff --git a/examples/iotivity_examples/server/server.c b/examples/iotivity_examples/server/server.c deleted file mode 100644 index f04e3b15855e7256d74e36eed20f7ef88aa2d868..0000000000000000000000000000000000000000 --- a/examples/iotivity_examples/server/server.c +++ /dev/null @@ -1,125 +0,0 @@ -/* - * Copyright (C) 2016 CREATE-NET - * - * 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. - */ - -/** - * @ingroup Examples - * @{ - * - * @file server.c - * @brief This is an IoTivity Server. - * - * @author Mattia Antonini <mattia.antonini1@studenti.unipr.it> - * <m.antonini@create-net.org> - * - * @} - */ - -#include "oc_api.h" -#include "xtimer.h" -#include "pthread_cond.h" -#include "thread.h" - -extern int _netif_config(int argc, char **argv); - -static int quit; -static mutex_t mutex; -static pthread_cond_t cv; -static struct timespec ts; -static char _oc_main_stack[THREAD_STACKSIZE_MAIN]; - -#define OC_QUEUE_SIZE (8) -static msg_t _oc_msg_queue[OC_QUEUE_SIZE]; - -//Resources registration functions -extern void res_light_register(void); - -static void -app_init(void) -{ - oc_init_platform("RIOT-OS", NULL, NULL); - - oc_add_device("/oic/d", "oic.d.light", "RIOT's light", "1.0", "1.0", NULL, - NULL); -} - - -static void -register_resources_func(void) -{ - res_light_register(); -} - -static void -signal_event_loop_func(void) -{ - mutex_lock(&mutex); - pthread_cond_signal(&cv); - mutex_unlock(&mutex); -} - -void * -oc_main_thread(void *arg) -{ - (void)arg; - - pthread_cond_init(&cv, NULL); - - static const oc_handler_t handler = { .init = app_init, - .signal_event_loop = signal_event_loop_func, - .register_resources = - register_resources_func }; - - msg_init_queue(_oc_msg_queue, OC_QUEUE_SIZE); - - if (oc_main_init(&handler) < 0) { - PRINT("server_oic: failed to initialize stack\n"); - return NULL; - } - - /* print network addresses */ - puts("server_oic: Configured network interfaces:"); - _netif_config(0, NULL); - - - - oc_clock_time_t next_event; - while (!quit) { - next_event = oc_main_poll(); - mutex_lock(&mutex); - if (next_event == 0) { - pthread_cond_wait(&cv, &mutex); - } - else { - ts.tv_sec = (next_event / OC_CLOCK_SECOND); - ts.tv_nsec = (next_event % OC_CLOCK_SECOND) * 1.e09 / OC_CLOCK_SECOND; - pthread_cond_timedwait(&cv, &mutex, &ts); - } - mutex_unlock(&mutex); - } - - oc_main_shutdown(); - - return NULL; -} - -int -main(void) -{ - PRINT("server_oic: Waiting for address autoconfiguration..."); - xtimer_sleep(10); - - thread_create(_oc_main_stack, sizeof(_oc_main_stack), 6, 0, oc_main_thread, - NULL, "OCF event thread"); - - fgetc(stdin); - - quit = 1; - signal_event_loop_func(); - - return 0; -} diff --git a/pkg/iotivity/Makefile b/pkg/iotivity/Makefile deleted file mode 100644 index e4e94a16d6f8dee8025a092ba62a1b4b89a3316d..0000000000000000000000000000000000000000 --- a/pkg/iotivity/Makefile +++ /dev/null @@ -1,30 +0,0 @@ -PKG_NAME=iotivity-constrained -PKG_URL=https://github.com/iotivity/iotivity-constrained -PKG_VERSION=830bb7a42d2804830a57dfe8bc469fac1317c46a -PKG_LICENSE=Apache-2.0 - -PKG_LIB=$(BINDIRBASE)/pkg/$(BOARD)/$(PKG_NAME) - -MODULE_MAKEFILE := $(PKG_DIR)/Makefile.module - -export PKG_DIR -export PKG_LIB -export PKG_NAME - -export RIOT_CFLAGS = ${CFLAGS} ${INCLUDES} - -all: git-download submodules-download copy_makefile - @"$(MAKE)" -BC $(PKG_BUILDDIR) lib-iotivity.a - @cp $(PKG_BUILDDIR)/lib-iotivity.a ${BINDIR}/iotivity.a - -copy_makefile: - @cp ./Makefile.tomove $(PKG_LIB)/Makefile - - -submodules-download: - @git -C $(PKG_LIB) submodule update --init - -include $(RIOTBASE)/pkg/pkg.mk - -clean:: copy_makefile - @"$(MAKE)" -BC $(PKG_BUILDDIR) clean diff --git a/pkg/iotivity/Makefile.include b/pkg/iotivity/Makefile.include deleted file mode 100644 index f1c0d7714f33aad757fe962ee642a8abcb9c1e5e..0000000000000000000000000000000000000000 --- a/pkg/iotivity/Makefile.include +++ /dev/null @@ -1,14 +0,0 @@ -INCLUDES += \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/port \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/port/riot \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/include \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/util \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/util/pt \ - -I$(BINDIRBASE)/.. - -ifeq ($(SECURE),1) - INCLUDES += \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/deps/tinydtls \ - -I$(BINDIRBASE)/pkg/$(BOARD)/iotivity-constrained/deps/tinydtls/sha2 -endif diff --git a/pkg/iotivity/Makefile.module b/pkg/iotivity/Makefile.module deleted file mode 100644 index 48422e909a47d7cd428d10fa73825060ccc8d8c2..0000000000000000000000000000000000000000 --- a/pkg/iotivity/Makefile.module +++ /dev/null @@ -1 +0,0 @@ -include $(RIOTBASE)/Makefile.base diff --git a/pkg/iotivity/Makefile.tomove b/pkg/iotivity/Makefile.tomove deleted file mode 100644 index 4c8b7278412893d19107ee80e51770cc77226fa6..0000000000000000000000000000000000000000 --- a/pkg/iotivity/Makefile.tomove +++ /dev/null @@ -1,41 +0,0 @@ -IOTIVITY_CFLAGS = -std=gnu99 -fno-asynchronous-unwind-tables -fno-omit-frame-pointer -Wall -Wno-format-zero-length -Wno-main -ffreestanding -Os -fno-stack-protector -ffunction-sections -fdata-sections -Wno-unused-but-set-variable -fno-reorder-functions -fno-defer-pop -Wno-pointer-sign -fno-strict-overflow -Werror=implicit-int - -CBOR = ./deps/tinycbor/src/cborencoder.c ./deps/tinycbor/src/cborencoder_close_container_checked.c ./deps/tinycbor/src/cborparser.c - -DTLS = ./deps/tinydtls/ccm.c ./deps/tinydtls/hmac.c ./deps/tinydtls/netq.c ./deps/tinydtls/peer.c ./deps/tinydtls/dtls_time.c ./deps/tinydtls/session.c ./deps/tinydtls/sha2/sha2.c ./deps/tinydtls/ecc/ecc.c ./deps/tinydtls/aes/rijndael.c ./deps/tinydtls/crypto.c ./deps/tinydtls/dtls.c - -DTLSFLAGS = -DDTLSV12 -DWITH_SHA256 -DDTLS_CHECK_CONTENTTYPE -DWITH_OCF -I./deps/tinydtls -DNDEBUG - -SRC_DEPS = ${CBOR} -SRC_CORE = $(wildcard ./messaging/coap/*.c ./api/*.c ./util/*.c ./util/pt/*.c) -VPATH=./util/pt:./messaging/coap/:./util/:./api/:./deps/tinycbor/src/: -SRC_PORT = $(wildcard ./port/riot/*.c) - -ifeq ($(SECURE),1) - SRC_SECURE += $(wildcard ./security/*.c) - SRC_DEPS += ${DTLS} - CFLAGS += ${DTLSFLAGS} -DOC_SECURITY - VPATH += ./security/:./deps/tinydtls/:./deps/tinydtls/aes/:./deps/tinydtls/sha2/:./deps/tinydtls/ecc/: -endif - - -SRC = ${SRC_DEPS} ${SRC_PORT} ${SRC_CORE} - -ifeq ($(SECURE),1) - SRC += ${SRC_SECURE} -endif - -OBJ = $(SRC:.c=.o) - - - -lib-iotivity.a: ${OBJ} - @${AR} rcs $@ ${OBJ} - -$(OBJ): %.o: %.c - @${CC} -o $@ ${RIOT_CFLAGS} ${IOTIVITY_CFLAGS} -c $< - -clean: clean_iotivity - -clean_iotivity: - rm -rf ${OBJ} diff --git a/pkg/iotivity/patches/00001-Change-Multicast-IP.patch b/pkg/iotivity/patches/00001-Change-Multicast-IP.patch deleted file mode 100644 index 3b83fb1c5fb82da28b2ec54541829b698d956d25..0000000000000000000000000000000000000000 Binary files a/pkg/iotivity/patches/00001-Change-Multicast-IP.patch and /dev/null differ diff --git a/pkg/iotivity/patches/00001-Remove-Config.h.patch b/pkg/iotivity/patches/00001-Remove-Config.h.patch deleted file mode 100644 index ca78208339cc0952416d5853aa7402a186531140..0000000000000000000000000000000000000000 Binary files a/pkg/iotivity/patches/00001-Remove-Config.h.patch and /dev/null differ