1 // mgcc test_frescan_servers_send_basic.c -L. -lfrescan -o mprogram_wifi2
2 // mgcc test_frescan_servers_send_basic.c -DSENDER -L. -lfrescan -o mprogram_wifi1
4 #include <stdio.h> // perror
5 #include <stdlib.h> // exit
6 #include <unistd.h> // sleep
9 #include "frescan_servers.h"
11 #define PUT_ERROR(s) {perror (s); exit (-1);}
16 // #define ENABLE_LOGGING
24 #include <drivers/console_switcher.h>
25 #include <misc/logger.h>
27 #define LOG_DEVICE LOG_ETHERNET
33 printf(" press Enter...");
40 frescan_send_params_t params;
43 frescan_init_params_t init_params;
44 frescan_server_params_t server_params, server_params_read;
45 frescan_budget_t current_budget;
48 ret = logger_init(LOG_DEVICE);
50 printf("Changing to membuffer console\n");
51 MEMBUFFER_CONSOLE_INIT();
54 printf(">> Initializing FRESCAN\n");
56 init_params.net = NETWORK;
57 init_params.node = LOCAL_NODE;
58 init_params.tx_fp_max_prio = 10;
59 init_params.rx_num_of_channels = 5;
60 init_params.rx_channel_max_prio = NULL;
62 ret = frescan_init(&init_params);
63 if (ret != 0) PUT_ERROR ("could not init FRESCAN");
65 printf(">> Creating a Server\n");
67 server_params.budget = 6;
68 server_params.period.tv_sec = 3;
69 server_params.period.tv_nsec = 0;
70 server_params.prio = 4;
72 ret = frescan_servers_create(NETWORK,
75 if (ret != 0) PUT_ERROR ("could not create server");
77 printf(">> Getting data from Server\n");
79 ret = frescan_servers_get_data(NETWORK,
82 if (ret != 0) PUT_ERROR ("could not get data from server");
84 printf("params: C = %d\n T = (%d, %d) P = %d\n",
85 server_params_read.budget,
86 server_params_read.period.tv_sec,
87 server_params_read.period.tv_nsec,
88 server_params_read.prio);
90 printf(">> Getting current_budget from Server\n");
92 ret = frescan_servers_get_current_budget(NETWORK,
95 if (ret != 0) PUT_ERROR ("could not get current_budget");
97 printf("current_budget = %d\n", current_budget);
99 printf(">> Setting perceived\n");
101 server_params.budget = 4;
102 server_params.period.tv_sec = 2;
103 server_params.period.tv_nsec = 0;
104 server_params.prio = 8;
106 ret = frescan_servers_set_perceived(NETWORK,
109 if (ret != 0) PUT_ERROR ("could not set perceived");
111 printf(">> Getting data from Server\n");
113 ret = frescan_servers_get_data(NETWORK,
116 if (ret != 0) PUT_ERROR ("could not get data from server");
118 printf("params: C = %d\n T = (%d, %d) P = %d\n",
119 server_params_read.budget,
120 server_params_read.period.tv_sec,
121 server_params_read.period.tv_nsec,
122 server_params_read.prio);
124 ret = frescan_servers_get_current_budget(NETWORK,
127 if (ret != 0) PUT_ERROR ("could not get current_budget");
129 printf("current_budget = %d\n", current_budget);
131 printf(">> Commit params to Server\n");
133 ret = frescan_servers_commit_perceived(NETWORK, params.ss);
134 if (ret != 0) PUT_ERROR ("could not commit params");
136 ret = frescan_servers_get_current_budget(NETWORK,
139 if (ret != 0) PUT_ERROR ("could not get current_budget");
141 printf("current_budget = %d\n", current_budget);
143 printf(">> Enter in loop for sending packets\n");
145 params.net = NETWORK;
148 params.flags = FRESCAN_SS | FRESCAN_ASYNC;
152 for (i=0; i<=2; i++) {
153 written = snprintf(msg, sizeof(msg),
154 "his number is: %d", i);
156 ret = frescan_send(¶ms, (uint8_t *)msg, written);
157 if (ret != 0) PUT_ERROR ("could not send message\n");
158 printf("SENT: %d\n", i);
160 ret = frescan_servers_get_current_budget
161 (NETWORK, params.ss, ¤t_budget);
162 if (ret != 0) PUT_ERROR ("could not get current_budget");
163 printf("current_budget = %d\n", current_budget);
166 ret = frescan_servers_get_current_budget
167 (NETWORK, params.ss, ¤t_budget);
168 if (ret != 0) PUT_ERROR ("could not get current_budget");
169 printf("current_budget = %d\n", current_budget);
171 #ifdef ENABLE_LOGGING
172 while (logger_manual_call() > 0);
186 frescan_recv_params_t params;
190 frescan_init_params_t init_params;
193 init_params.net = NETWORK;
194 init_params.node = LOCAL_NODE;
195 init_params.tx_fp_max_prio = 10;
196 init_params.rx_num_of_channels = 5;
197 init_params.rx_channel_max_prio = NULL;
199 ret = frescan_init(&init_params);
200 if (ret != 0) PUT_ERROR ("could not init FRESCAN");
202 printf("FRESCAN initialized\n");
204 params.net = NETWORK;
206 params.flags = FRESCAN_SYNC;
209 printf("RECEIVING...\n");
210 ret = frescan_recv(¶ms, (uint8_t *)msg, sizeof(msg),
211 &recv_bytes, &from, &prio);
212 if (ret != 0) PUT_ERROR ("could not send message");
214 msg[recv_bytes] = '\0';
215 printf("RECEIVED: %s with prio:%u\n", msg, prio);
217 // for (i=0; i<recv_bytes; i++) {
218 // printf("msg[%d] = 0x%X;\n", i, msg[i]);