1 //----------------------------------------------------------------------
2 // Copyright (C) 2006 - 2009 by the FRESCOR consortium:
4 // Universidad de Cantabria, SPAIN
5 // University of York, UK
6 // Scuola Superiore Sant'Anna, ITALY
7 // Kaiserslautern University, GERMANY
8 // Univ. Politecnica Valencia, SPAIN
9 // Czech Technical University in Prague, CZECH REPUBLIC
11 // Thales Communication S.A. FRANCE
12 // Visual Tools S.A. SPAIN
13 // Rapita Systems Ltd UK
16 // See http://www.frescor.org
18 // The FRESCOR project (FP6/2005/IST/5-034026) is funded
19 // in part by the European Union Sixth Framework Programme
20 // The European Union is not liable of any use that may be
24 // based on previous work (FSF) done in the FIRST project
26 // Copyright (C) 2005 Mälardalen University, SWEDEN
27 // Scuola Superiore S.Anna, ITALY
28 // Universidad de Cantabria, SPAIN
29 // University of York, UK
31 // This file is part of FNA (Frescor Network Adaptation)
33 // FNA is free software; you can redistribute it and/or modify it
34 // under terms of the GNU General Public License as published by the
35 // Free Software Foundation; either version 2, or (at your option) any
36 // later version. FNA is distributed in the hope that it will be
37 // useful, but WITHOUT ANY WARRANTY; without even the implied warranty
38 // of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
39 // General Public License for more details. You should have received a
40 // copy of the GNU General Public License along with FNA; see file
41 // COPYING. If not, write to the Free Software Foundation, 675 Mass Ave,
42 // Cambridge, MA 02139, USA.
44 // As a special exception, including FNA header files in a file,
45 // instantiating FNA generics or templates, or linking other files
46 // with FNA objects to produce an executable application, does not
47 // by itself cause the resulting executable application to be covered
48 // by the GNU General Public License. This exception does not
49 // however invalidate any other reasons why the executable file might be
50 // covered by the GNU Public License.
51 // -----------------------------------------------------------------------
53 // mgcc test_frescan_servers_send_basic.c -L. -lfrescan -o mprogram_wifi2
54 // mgcc test_frescan_servers_send_basic.c -DSENDER -L. -lfrescan -o mprogram_wifi1
56 #include <stdio.h> // perror
57 #include <stdlib.h> // exit
58 #include <unistd.h> // sleep
61 #include "frescan_servers.h"
63 #define PUT_ERROR(s) {perror (s); exit (-1);}
68 // #define ENABLE_LOGGING
76 #include <drivers/console_switcher.h>
77 #include <misc/logger.h>
79 #define LOG_DEVICE LOG_ETHERNET
85 printf(" press Enter...");
92 frescan_send_params_t params;
95 frescan_init_params_t init_params;
96 frescan_server_params_t server_params, server_params_read;
97 frescan_budget_t current_budget;
100 ret = logger_init(LOG_DEVICE);
102 printf("Changing to membuffer console\n");
103 MEMBUFFER_CONSOLE_INIT();
106 printf(">> Initializing FRESCAN\n");
108 init_params.net = NETWORK;
109 init_params.node = LOCAL_NODE;
110 init_params.tx_fp_max_prio = 10;
111 init_params.rx_num_of_channels = 5;
112 init_params.rx_channel_max_prio = NULL;
114 ret = frescan_init(&init_params);
115 if (ret != 0) PUT_ERROR ("could not init FRESCAN");
117 printf(">> Creating a Server\n");
119 server_params.budget = 6;
120 server_params.period.tv_sec = 3;
121 server_params.period.tv_nsec = 0;
122 server_params.prio = 4;
124 ret = frescan_servers_create(NETWORK,
127 if (ret != 0) PUT_ERROR ("could not create server");
129 printf(">> Getting data from Server\n");
131 ret = frescan_servers_get_data(NETWORK,
134 if (ret != 0) PUT_ERROR ("could not get data from server");
136 printf("params: C = %d\n T = (%d, %d) P = %d\n",
137 server_params_read.budget,
138 server_params_read.period.tv_sec,
139 server_params_read.period.tv_nsec,
140 server_params_read.prio);
142 printf(">> Getting current_budget from Server\n");
144 ret = frescan_servers_get_current_budget(NETWORK,
147 if (ret != 0) PUT_ERROR ("could not get current_budget");
149 printf("current_budget = %d\n", current_budget);
151 printf(">> Setting perceived\n");
153 server_params.budget = 4;
154 server_params.period.tv_sec = 2;
155 server_params.period.tv_nsec = 0;
156 server_params.prio = 8;
158 ret = frescan_servers_set_perceived(NETWORK,
161 if (ret != 0) PUT_ERROR ("could not set perceived");
163 printf(">> Getting data from Server\n");
165 ret = frescan_servers_get_data(NETWORK,
168 if (ret != 0) PUT_ERROR ("could not get data from server");
170 printf("params: C = %d\n T = (%d, %d) P = %d\n",
171 server_params_read.budget,
172 server_params_read.period.tv_sec,
173 server_params_read.period.tv_nsec,
174 server_params_read.prio);
176 ret = frescan_servers_get_current_budget(NETWORK,
179 if (ret != 0) PUT_ERROR ("could not get current_budget");
181 printf("current_budget = %d\n", current_budget);
183 printf(">> Commit params to Server\n");
185 ret = frescan_servers_commit_perceived(NETWORK, params.ss);
186 if (ret != 0) PUT_ERROR ("could not commit params");
188 ret = frescan_servers_get_current_budget(NETWORK,
191 if (ret != 0) PUT_ERROR ("could not get current_budget");
193 printf("current_budget = %d\n", current_budget);
195 printf(">> Enter in loop for sending packets\n");
197 params.net = NETWORK;
200 params.flags = FRESCAN_SS | FRESCAN_ASYNC;
204 for (i=0; i<=2; i++) {
205 written = snprintf(msg, sizeof(msg),
206 "his number is: %d", i);
208 ret = frescan_send(¶ms, (uint8_t *)msg, written);
209 if (ret != 0) PUT_ERROR ("could not send message\n");
210 printf("SENT: %d\n", i);
212 ret = frescan_servers_get_current_budget
213 (NETWORK, params.ss, ¤t_budget);
214 if (ret != 0) PUT_ERROR ("could not get current_budget");
215 printf("current_budget = %d\n", current_budget);
218 ret = frescan_servers_get_current_budget
219 (NETWORK, params.ss, ¤t_budget);
220 if (ret != 0) PUT_ERROR ("could not get current_budget");
221 printf("current_budget = %d\n", current_budget);
223 #ifdef ENABLE_LOGGING
224 while (logger_manual_call() > 0);
238 frescan_recv_params_t params;
242 frescan_init_params_t init_params;
245 init_params.net = NETWORK;
246 init_params.node = LOCAL_NODE;
247 init_params.tx_fp_max_prio = 10;
248 init_params.rx_num_of_channels = 5;
249 init_params.rx_channel_max_prio = NULL;
251 ret = frescan_init(&init_params);
252 if (ret != 0) PUT_ERROR ("could not init FRESCAN");
254 printf("FRESCAN initialized\n");
256 params.net = NETWORK;
258 params.flags = FRESCAN_SYNC;
261 printf("RECEIVING...\n");
262 ret = frescan_recv(¶ms, (uint8_t *)msg, sizeof(msg),
263 &recv_bytes, &from, &prio);
264 if (ret != 0) PUT_ERROR ("could not send message");
266 msg[recv_bytes] = '\0';
267 printf("RECEIVED: %s with prio:%u\n", msg, prio);
269 // for (i=0; i<recv_bytes; i++) {
270 // printf("msg[%d] = 0x%X;\n", i, msg[i]);