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 = 3;
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(">> Enter in loop for sending packets\n");
101 params.net = NETWORK;
104 params.flags = FRESCAN_SS | FRESCAN_ASYNC;
108 for (i=0; i<=2; i++) {
109 written = snprintf(msg, sizeof(msg),
110 "his number is: %d", i);
112 ret = frescan_send(¶ms, (uint8_t *)msg, written);
113 if (ret != 0) PUT_ERROR ("could not send message\n");
114 printf("SENT: %d\n", i);
116 ret = frescan_servers_get_current_budget
117 (NETWORK, params.ss, ¤t_budget);
118 if (ret != 0) PUT_ERROR ("could not get current_budget");
119 printf("current_budget = %d\n", current_budget);
122 ret = frescan_servers_get_current_budget
123 (NETWORK, params.ss, ¤t_budget);
124 if (ret != 0) PUT_ERROR ("could not get current_budget");
125 printf("current_budget = %d\n", current_budget);
127 #ifdef ENABLE_LOGGING
128 while (logger_manual_call() > 0);
142 frescan_recv_params_t params;
146 frescan_init_params_t init_params;
149 init_params.net = NETWORK;
150 init_params.node = LOCAL_NODE;
151 init_params.tx_fp_max_prio = 10;
152 init_params.rx_num_of_channels = 5;
153 init_params.rx_channel_max_prio = NULL;
155 ret = frescan_init(&init_params);
156 if (ret != 0) PUT_ERROR ("could not init FRESCAN");
158 printf("FRESCAN initialized\n");
160 params.net = NETWORK;
162 params.flags = FRESCAN_SYNC;
165 printf("RECEIVING...\n");
166 ret = frescan_recv(¶ms, (uint8_t *)msg, sizeof(msg),
167 &recv_bytes, &from, &prio);
168 if (ret != 0) PUT_ERROR ("could not send message");
170 msg[recv_bytes] = '\0';
171 printf("RECEIVED: %s with prio:%u\n", msg, prio);
173 // for (i=0; i<recv_bytes; i++) {
174 // printf("msg[%d] = 0x%X;\n", i, msg[i]);