GNUnet 0.28.0-dev.2-27-gc87478450
 
Loading...
Searching...
No Matches
gnunet_dht_profiler.c
Go to the documentation of this file.
1/*
2 This file is part of GNUnet.
3 Copyright (C) 2014, 2018 GNUnet e.V.
4
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
9
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
14
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 SPDX-License-Identifier: AGPL3.0-or-later
19 */
20
27#include "platform.h"
28#include "gnunet_util_lib.h"
29#include "gnunet_testbed_service.h"
30#include "gnunet_dht_service.h"
31#include "gnunet_constants.h"
32
33
34#define MESSAGE(...) \
35 GNUNET_log (GNUNET_ERROR_TYPE_MESSAGE, __VA_ARGS__)
36
37#define DEBUG(...) \
38 GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, __VA_ARGS__)
39
43static unsigned int put_probability = 100;
44
48static const struct GNUNET_CONFIGURATION_Handle *cfg;
49
53static char *hosts_file;
54
58struct ActiveContext;
59
63struct Context
64{
68 struct GNUNET_TESTBED_Peer *peer;
69
73 struct GNUNET_TESTBED_Operation *op;
74
79};
80
81
86{
90 struct Context *ctx;
91
96
101
106
111
117
122
126 unsigned int put_count;
127
131 uint16_t nrefs;
132};
133
134
138static struct Context *a_ctx;
139
143static struct ActiveContext *a_ac;
144
149
154
159
164
168static unsigned int num_peers;
169
173static unsigned int n_active;
174
178static unsigned int n_dht;
179
183static unsigned long long n_puts;
184
188static unsigned int num_puts_per_peer = 1;
189
193static unsigned long long n_puts_ok;
194
198static unsigned int n_gets;
199
203static unsigned int n_gets_ok;
204
208static unsigned int n_gets_fail;
209
213static unsigned int replication;
214
218static struct GNUNET_TESTBED_Operation *bandwidth_stats_op;
219
223static struct GNUNET_TESTBED_Peer **testbed_handles;
224
228static uint64_t outgoing_bandwidth;
229
233static uint64_t incoming_bandwidth;
234
239
244
248static unsigned int total_put_path_length;
249
253static unsigned int total_get_path_length;
254
258static int peers_started = 0;
259
263static enum
264{
266
267 MODE_GET = 1
269
270
274static int in_shutdown = 0;
275
276
280static void
281start_profiling (void);
282
283
289static void
290do_shutdown (void *cls)
291{
292 struct ActiveContext *ac;
293
295 if (NULL != a_ctx)
296 {
297 for (unsigned int cnt = 0; cnt < num_peers; cnt++)
298 {
299 /* Cleanup active context if this peer is an active peer */
300 ac = a_ctx[cnt].ac;
301 if (NULL != ac)
302 {
303 if (NULL != ac->delay_task)
305 if (NULL != ac->hash)
306 free (ac->hash);
307 if (NULL != ac->dht_put)
309 if (NULL != ac->dht_get)
311 }
312 /* Cleanup testbed operation handle at the last as this operation may
313 contain service connection to DHT */
314 if (NULL != a_ctx[cnt].op)
315 GNUNET_TESTBED_operation_done (a_ctx[cnt].op);
316 }
318 a_ctx = NULL;
319 }
320 // FIXME: Should we collect stats only for put/get not for other messages.
321 if (NULL != bandwidth_stats_op)
322 {
323 GNUNET_TESTBED_operation_done (bandwidth_stats_op);
324 bandwidth_stats_op = NULL;
325 }
327}
328
329
339static void
341 struct GNUNET_TESTBED_Operation *op,
342 const char *emsg)
343{
344 MESSAGE ("# Outgoing (core) bandwidth: %llu bytes\n",
345 (unsigned long long) outgoing_bandwidth);
346 MESSAGE ("# Incoming (core) bandwidth: %llu bytes\n",
347 (unsigned long long) incoming_bandwidth);
348 fprintf (stderr,
349 "Benchmark done. Collect data via gnunet-statistics, then press ENTER to exit.\n");
350 (void) getchar ();
352}
353
354
366static int
368 const struct GNUNET_TESTBED_Peer *peer,
369 const char *subsystem,
370 const char *name,
371 uint64_t value,
372 int is_persistent)
373{
374 static const char *s_sent = "# bytes encrypted";
375 static const char *s_recv = "# bytes decrypted";
376
377 if (0 == strncmp (s_sent, name, strlen (s_sent)))
379 else if (0 == strncmp (s_recv, name, strlen (s_recv)))
381 return GNUNET_OK;
382}
383
384
385static void
387{
388 MESSAGE ("# PUTS started: %llu\n",
389 n_puts);
390 MESSAGE ("# PUTS succeeded: %llu\n",
391 n_puts_ok);
392 MESSAGE ("# GETS made: %u\n",
393 n_gets);
394 MESSAGE ("# GETS succeeded: %u\n",
395 n_gets_ok);
396 MESSAGE ("# GETS failed: %u\n",
398 MESSAGE ("# average_put_path_length: %f\n",
400 MESSAGE ("# average_get_path_length: %f\n",
402
403 if (NULL == testbed_handles)
404 {
405 MESSAGE ("No peers found\n");
406 return;
407 }
408 /* Collect Stats*/
409 bandwidth_stats_op = GNUNET_TESTBED_get_statistics (n_active,
411 "core",
412 NULL,
415 NULL);
416}
417
418
424static void
425cancel_get (void *cls)
426{
427 struct ActiveContext *ac = cls;
428 struct Context *ctx = ac->ctx;
429
430 ac->delay_task = NULL;
431 GNUNET_assert (NULL != ac->dht_get);
433 ac->dht_get = NULL;
434 n_gets_fail++;
435 GNUNET_assert (NULL != ctx->op);
436 GNUNET_TESTBED_operation_done (ctx->op);
437 ctx->op = NULL;
438
439 /* If profiling is complete, summarize */
441 {
443 / (double) n_active;
445 / (double ) n_gets_ok;
446 summarize ();
447 }
448}
449
450
469static void
470get_iter (void *cls,
471 struct GNUNET_TIME_Absolute exp,
472 const struct GNUNET_HashCode *key,
473 const struct GNUNET_PeerIdentity *trunc_peer,
474 const struct GNUNET_DHT_PathElement *get_path,
475 unsigned int get_path_length,
476 const struct GNUNET_DHT_PathElement *put_path,
477 unsigned int put_path_length,
479 size_t size,
480 const void *data)
481{
482 struct ActiveContext *ac = cls;
483 struct ActiveContext *get_ac = ac->get_ac;
484 struct Context *ctx = ac->ctx;
485
486 /* we found the data we are looking for */
487 DEBUG ("We found a GET request; %u remaining\n",
488 n_gets - (n_gets_fail + n_gets_ok)); // FIXME: It always prints 1.
489 n_gets_ok++;
490 get_ac->nrefs--;
492 ac->dht_get = NULL;
493 if (ac->delay_task != NULL)
495 ac->delay_task = NULL;
496 GNUNET_assert (NULL != ctx->op);
497 GNUNET_TESTBED_operation_done (ctx->op);
498 ctx->op = NULL;
499
500 total_put_path_length = total_put_path_length + (double) put_path_length;
501 total_get_path_length = total_get_path_length + (double) get_path_length;
502 DEBUG ("total_put_path_length = %u,put_path \n",
504 /* Summarize if profiling is complete */
506 {
508 / (double) n_active;
510 / (double ) n_gets_ok;
511 summarize ();
512 }
513}
514
515
521static void
522delayed_get (void *cls)
523{
524 struct ActiveContext *ac = cls;
525 struct ActiveContext *get_ac;
526 unsigned int r;
527
528 ac->delay_task = NULL;
529 get_ac = NULL;
530 while (1)
531 {
533 get_ac = &a_ac[r];
534 if (NULL != get_ac->hash)
535 break;
536 }
537 get_ac->nrefs++;
538 ac->get_ac = get_ac;
540 DEBUG ("GET_REQUEST_START key %s \n",
541 GNUNET_h2s (&get_ac->hash[r]));
544 &get_ac->hash[r],
545 1, /* replication level */
547 NULL,
548 0, /* extended query and size */
549 &get_iter,
550 ac); /* GET iterator and closure */
551 n_gets++;
552
553 /* schedule the timeout task for GET */
555 &cancel_get,
556 ac);
557}
558
559
567static void
568delayed_put (void *cls);
569
570
577static void
578put_cont (void *cls)
579{
580 struct ActiveContext *ac = cls;
581
582 ac->dht_put = NULL;
583 n_puts_ok++;
585 ac);
586}
587
588
596static void
597delayed_put (void *cls)
598{
599 struct ActiveContext *ac = cls;
600 char block[65536];
601 size_t block_size;
602
603 ac->delay_task = NULL;
604 if (0 == ac->put_count)
605 {
606 struct Context *ctx = ac->ctx;
607 struct GNUNET_TESTBED_Operation *op;
608
609 GNUNET_assert (NULL != ctx);
610 op = ctx->op;
611 ctx->op = NULL;
612 GNUNET_TESTBED_operation_done (op);
613 return;
614 }
615
616
617 /* Generate and DHT PUT some random data */
618 block_size = 16; /* minimum */
619 /* make random payload, reserve 512 - 16 bytes for DHT headers */
620 block_size += GNUNET_CRYPTO_random_u32 (
622 - 512);
624 block_size);
625 ac->put_count--;
626 GNUNET_CRYPTO_hash (block,
627 block_size,
628 &ac->hash[ac->put_count]);
629 DEBUG ("PUT_REQUEST_START key %s\n",
630 GNUNET_h2s (&ac->hash[ac->put_count]));
631 ac->dht_put = GNUNET_DHT_put (ac->dht,
632 &ac->hash[ac->put_count],
636 block_size,
637 block,
638 GNUNET_TIME_UNIT_FOREVER_ABS, /* expiration time */
639 &put_cont,
640 ac); /* continuation and its closure */
641 n_puts++;
642}
643
644
654static void
655dht_connected (void *cls,
656 struct GNUNET_TESTBED_Operation *op,
657 void *ca_result,
658 const char *emsg)
659{
660 struct ActiveContext *ac = cls;
661 struct Context *ctx = ac->ctx;
662
663 GNUNET_assert (NULL != ctx); // FIXME: Fails
664 GNUNET_assert (NULL != ctx->op);
665 GNUNET_assert (ctx->op == op);
666 ac->dht = (struct GNUNET_DHT_Handle *) ca_result;
667 if (NULL != emsg)
668 {
670 "Connection to DHT service failed: %s\n",
671 emsg);
672 GNUNET_TESTBED_operation_done (ctx->op); /* Calls dht_disconnect() */
673 ctx->op = NULL;
674 return;
675 }
676 switch (mode)
677 {
678 case MODE_PUT:
679 {
680 struct GNUNET_TIME_Relative peer_delay_put;
681
682 peer_delay_put.rel_value_us =
685 ac->hash = calloc (ac->put_count,
686 sizeof(struct GNUNET_HashCode));
687 if (NULL == ac->hash)
688 {
690 "calloc");
692 return;
693 }
694 ac->delay_task = GNUNET_SCHEDULER_add_delayed (peer_delay_put,
696 ac);
697 break;
698 }
699
700 case MODE_GET:
701 {
702 struct GNUNET_TIME_Relative peer_delay_get;
703
704 peer_delay_get.rel_value_us =
707 ac->delay_task = GNUNET_SCHEDULER_add_delayed (peer_delay_get,
709 ac);
710 break;
711 }
712 }
713}
714
715
725static void *
726dht_connect (void *cls,
727 const struct GNUNET_CONFIGURATION_Handle *cfg)
728{
729 n_dht++;
730 return GNUNET_DHT_connect (cfg,
731 10);
732}
733
734
742static void
743dht_disconnect (void *cls,
744 void *op_result)
745{
746 struct ActiveContext *ac = cls;
747
748 GNUNET_assert (NULL != ac->dht);
749 GNUNET_assert (ac->dht == op_result);
751 ac->dht = NULL;
752 n_dht--;
753 if (0 != n_dht)
754 return;
755 if (GNUNET_YES == in_shutdown)
756 return;
757 switch (mode)
758 {
759 case MODE_PUT:
760 if (n_puts_ok != ((unsigned long long) n_active) * num_puts_per_peer)
761 return;
762 /* Start GETs if all PUTs have been made */
763 mode = MODE_GET;
765 return;
766
767 case MODE_GET:
768 if ((n_gets_ok + n_gets_fail) != n_active)
769 return;
770 break;
771 }
772}
773
774
778static void
780{
781 struct Context *ctx;
782
783 DEBUG ("GNUNET_TESTBED_service_connect\n");
785 for (unsigned int i = 0; i < n_active; i++)
786 {
787 struct ActiveContext *ac = &a_ac[i];
788 GNUNET_assert (NULL != (ctx = ac->ctx));
789 GNUNET_assert (NULL == ctx->op);
790 ctx->op = GNUNET_TESTBED_service_connect (ctx,
791 ctx->peer,
792 "dht",
793 &dht_connected, ac,
796 ac);
797 }
798}
799
800
809static void
811 struct GNUNET_TESTBED_Operation *op,
812 const char *emsg)
813{
814 struct Context *ctx = cls;
815
816 GNUNET_assert (NULL != ctx);
817 GNUNET_assert (NULL != ctx->op);
818 GNUNET_TESTBED_operation_done (ctx->op);
819 ctx->op = NULL;
821 DEBUG ("Peers Started = %d; num_peers = %d \n",
823 num_peers);
826}
827
828
840static void
841test_run (void *cls,
842 struct GNUNET_TESTBED_RunHandle *h,
843 unsigned int num_peers,
844 struct GNUNET_TESTBED_Peer **peers,
845 unsigned int links_succeeded,
846 unsigned int links_failed)
847{
848 unsigned int ac_cnt;
849
851 if (NULL == peers)
852 {
853 /* exit */
854 GNUNET_assert (0);
855 }
856 MESSAGE ("%u peers started, %u/%u links up\n",
857 num_peers,
858 links_succeeded,
859 links_succeeded + links_failed);
861 struct Context);
862 /* select the peers which actively participate in profiling */
864 if (0 == n_active)
865 {
868 a_ctx = NULL;
869 return;
870 }
871
873 struct ActiveContext);
874 ac_cnt = 0;
875 for (unsigned int cnt = 0; cnt < num_peers && ac_cnt < n_active; cnt++)
876 {
878 continue;
879
880 a_ctx[cnt].ac = &a_ac[ac_cnt];
881 a_ac[ac_cnt].ctx = &a_ctx[cnt];
882 ac_cnt++;
883 }
884 n_active = ac_cnt;
885
886 /* start DHT service on all peers */
887 for (unsigned int cnt = 0; cnt < num_peers; cnt++)
888 {
889 a_ctx[cnt].peer = peers[cnt];
890 a_ctx[cnt].op = GNUNET_TESTBED_peer_manage_service (&a_ctx[cnt],
891 peers[cnt],
892 "dht",
894 &a_ctx[cnt],
895 1);
896 }
897}
898
899
908static void
909run (void *cls,
910 char *const *args,
911 const char *cfgfile,
913{
914 uint64_t event_mask;
915
916 if (0 == num_peers)
917 {
919 _ ("Exiting as the number of peers is %u\n"),
920 num_peers);
921 return;
922 }
923 cfg = config;
924 event_mask = 0;
925 GNUNET_TESTBED_run (hosts_file,
926 cfg,
927 num_peers,
929 NULL,
930 NULL,
931 &test_run,
932 NULL);
934 NULL);
935}
936
937
943int
944main (int argc,
945 char *const *argv)
946{
947 int rc;
950 "peers",
951 "COUNT",
952 gettext_noop ("number of peers to start"),
953 &num_peers),
955 "peer-put-count",
956 "COUNT",
958 "number of PUTs to perform per peer"),
961 "hosts",
962 "FILENAME",
964 "name of the file with the login information for the testbed"),
965 &hosts_file),
967 "delay",
968 "DELAY",
970 "delay between rounds for collecting statistics (default: 30 sec)"),
971 &delay_stats),
973 "PUT-delay",
974 "DELAY",
976 "delay to start doing PUTs (default: 1 sec)"),
977 &delay_put),
979 "GET-delay",
980 "DELAY",
982 "delay to start doing GETs (default: 5 min)"),
983 &delay_get),
985 "replication",
986 "DEGREE",
987 gettext_noop ("replication degree for DHT PUTs"),
988 &replication),
990 "random-chance",
991 "PROBABILITY",
993 "chance that a peer is selected at random for PUTs"),
996 "timeout",
997 "TIMEOUT",
999 "timeout for DHT PUT and GET requests (default: 1 min)"),
1000 &timeout),
1002 };
1003
1004 /* set default delays */
1009 replication = 1; /* default replication */
1010 rc = 0;
1011 if (GNUNET_OK !=
1012 GNUNET_PROGRAM_run (argc,
1013 argv,
1014 "gnunet-dht-profiler",
1015 gettext_noop (
1016 "Measure quality and performance of the DHT service."),
1017 options,
1018 &run,
1019 NULL))
1020 rc = 1;
1021 return rc;
1022}
struct GNUNET_GETOPT_CommandLineOption options[]
Definition 002.c:5
int main()
Program to simulate results from GCP_get_desirability_of_path() for various plausible inputs.
#define gettext_noop(String)
Definition gettext.h:74
static struct GNUNET_ARM_Operation * op
Current operation.
Definition gnunet-arm.c:143
static struct GNUNET_ARM_Handle * h
Connection with ARM.
Definition gnunet-arm.c:98
static int do_shutdown
Set to GNUNET_YES if we are shutting down.
static char * data
The data to insert into the dht.
struct GNUNET_HashCode key
The key used in the DHT.
static struct GNUNET_FS_Handle * ctx
const struct GNUNET_CONFIGURATION_Handle * config
static char * name
Name (label) of the records to list.
static char * value
Value of the record to add/remove.
static uint32_t type
Type string converted to DNS type value.
static uint64_t event_mask
Global event mask for all testbed events.
struct GNUNET_CONTAINER_MultiPeerMap * peers
Map from PIDs to struct CadetPeer entries.
static char * subsystem
Set to subsystem that we're going to get stats for (or NULL for all).
GNUNET_BLOCK_Type
WARNING: This header is generated! In order to add DHT block types, you must register them in GANA,...
@ GNUNET_BLOCK_TYPE_TEST
Block for testing.
static struct GNUNET_TESTBED_Peer ** testbed_handles
Testbed peer handles.
static unsigned long long n_puts_ok
Number of DHT PUTs succeeded.
static void get_iter(void *cls, struct GNUNET_TIME_Absolute exp, const struct GNUNET_HashCode *key, const struct GNUNET_PeerIdentity *trunc_peer, const struct GNUNET_DHT_PathElement *get_path, unsigned int get_path_length, const struct GNUNET_DHT_PathElement *put_path, unsigned int put_path_length, enum GNUNET_BLOCK_Type type, size_t size, const void *data)
Iterator called on each result obtained for a DHT operation that expects a reply.
static void test_run(void *cls, struct GNUNET_TESTBED_RunHandle *h, unsigned int num_peers, struct GNUNET_TESTBED_Peer **peers, unsigned int links_succeeded, unsigned int links_failed)
Signature of a main function for a testcase.
static void dht_connected(void *cls, struct GNUNET_TESTBED_Operation *op, void *ca_result, const char *emsg)
Connection to DHT has been established.
static void * dht_connect(void *cls, const struct GNUNET_CONFIGURATION_Handle *cfg)
Connect to DHT service and return the DHT client handler.
static enum @52 mode
Should we do a PUT (mode = 0) or GET (mode = 1);.
static struct GNUNET_TIME_Relative delay_put
The delay to start puts.
static unsigned int n_gets_ok
Number of DHT GETs succeeded.
static const struct GNUNET_CONFIGURATION_Handle * cfg
Configuration.
static int bandwidth_stats_iterator(void *cls, const struct GNUNET_TESTBED_Peer *peer, const char *subsystem, const char *name, uint64_t value, int is_persistent)
Process statistic values.
static double average_get_path_length
Average number of hops taken to do get.
static int in_shutdown
Are we shutting down.
static void delayed_get(void *cls)
Task to do DHT GETs.
static struct GNUNET_TESTBED_Operation * bandwidth_stats_op
Testbed Operation (to get stats).
static void delayed_put(void *cls)
Task to do DHT PUTs.
static unsigned int n_active
Number of active peers.
static char * hosts_file
Name of the file with the hosts to run the test over.
static struct GNUNET_TIME_Relative delay_get
The delay to start puts.
static unsigned int total_put_path_length
Total put path length across all peers.
static unsigned int n_dht
Number of DHT service connections we currently have.
static void summarize()
static void bandwidth_stats_cont(void *cls, struct GNUNET_TESTBED_Operation *op, const char *emsg)
Stats callback.
#define DEBUG(...)
static void cancel_get(void *cls)
Task to cancel DHT GET.
static unsigned int n_gets_fail
Number of DHT GETs succeeded.
static unsigned int replication
Replication degree.
static void service_started(void *cls, struct GNUNET_TESTBED_Operation *op, const char *emsg)
Callback called when DHT service on the peer is started.
static void start_profiling(void)
Connect to DHT services of active peers.
static struct GNUNET_TIME_Relative timeout
The timeout for GET and PUT.
static unsigned long long n_puts
Number of DHT PUTs made.
static struct GNUNET_TIME_Relative delay_stats
The delay between rounds for collecting statistics.
static struct Context * a_ctx
An array of contexts.
static unsigned int total_get_path_length
Total get path length across all peers.
static uint64_t outgoing_bandwidth
Total number of messages sent by peer.
static double average_put_path_length
Average number of hops taken to do put.
#define MESSAGE(...)
static unsigned int put_probability
Number of peers which should perform a PUT out of 100 peers.
static void run(void *cls, char *const *args, const char *cfgfile, const struct GNUNET_CONFIGURATION_Handle *config)
Main function that will be run by the scheduler.
static unsigned int num_puts_per_peer
Number of DHT PUTs to be made per peer.
static void dht_disconnect(void *cls, void *op_result)
Adapter function called to destroy a connection to a service.
static struct ActiveContext * a_ac
Array of active peers.
static unsigned int num_peers
Number of peers.
static int peers_started
Counter to keep track of peers added to peer_context lists.
static uint64_t incoming_bandwidth
Total number of messages received by peer.
static unsigned int n_gets
Number of DHT GETs made.
static void put_cont(void *cls)
Conclude individual PUT operation, schedule the next one.
API to the DHT service.
#define GNUNET_CONSTANTS_MAX_ENCRYPTED_MESSAGE_SIZE
What is the maximum size for encrypted messages? Note that this number imposes a clear limit on the m...
uint64_t GNUNET_CRYPTO_random_u64(uint64_t max)
Generate a random unsigned 64-bit value.
void GNUNET_CRYPTO_random_block(void *buffer, size_t length)
Fill block with a random values.
uint32_t GNUNET_CRYPTO_random_u32(uint32_t i)
Produce a random value.
void GNUNET_DHT_put_cancel(struct GNUNET_DHT_PutHandle *ph)
Cancels a DHT PUT operation.
Definition dht_api.c:1149
struct GNUNET_DHT_PutHandle * GNUNET_DHT_put(struct GNUNET_DHT_Handle *handle, const struct GNUNET_HashCode *key, uint32_t desired_replication_level, enum GNUNET_DHT_RouteOption options, enum GNUNET_BLOCK_Type type, size_t size, const void *data, struct GNUNET_TIME_Absolute exp, GNUNET_SCHEDULER_TaskCallback cont, void *cont_cls)
Perform a PUT operation storing data in the DHT.
Definition dht_api.c:1086
struct GNUNET_DHT_Handle * GNUNET_DHT_connect(const struct GNUNET_CONFIGURATION_Handle *cfg, unsigned int ht_len)
Initialize the connection with the DHT service.
Definition dht_api.c:1036
void GNUNET_DHT_get_stop(struct GNUNET_DHT_GetHandle *get_handle)
Stop async DHT-get.
Definition dht_api.c:1238
struct GNUNET_DHT_GetHandle * GNUNET_DHT_get_start(struct GNUNET_DHT_Handle *handle, enum GNUNET_BLOCK_Type type, const struct GNUNET_HashCode *key, uint32_t desired_replication_level, enum GNUNET_DHT_RouteOption options, const void *xquery, size_t xquery_size, GNUNET_DHT_GetIterator iter, void *iter_cls)
Perform an asynchronous GET operation on the DHT identified.
Definition dht_api.c:1165
void GNUNET_DHT_disconnect(struct GNUNET_DHT_Handle *handle)
Shutdown connection with the DHT service.
Definition dht_api.c:1058
@ GNUNET_DHT_RO_NONE
Default.
@ GNUNET_DHT_RO_RECORD_ROUTE
We should keep track of the route that the message took in the P2P network.
struct GNUNET_GETOPT_CommandLineOption GNUNET_GETOPT_option_uint(char shortName, const char *name, const char *argumentHelp, const char *description, unsigned int *val)
Allow user to specify an unsigned int.
struct GNUNET_GETOPT_CommandLineOption GNUNET_GETOPT_option_relative_time(char shortName, const char *name, const char *argumentHelp, const char *description, struct GNUNET_TIME_Relative *val)
Allow user to specify a struct GNUNET_TIME_Relative (using human-readable "fancy" time).
#define GNUNET_GETOPT_OPTION_END
Marker for the end of the list of options.
struct GNUNET_GETOPT_CommandLineOption GNUNET_GETOPT_option_string(char shortName, const char *name, const char *argumentHelp, const char *description, char **str)
Allow user to specify a string.
void GNUNET_CRYPTO_hash(const void *block, size_t size, struct GNUNET_HashCode *ret)
Compute hash of a given block.
Definition crypto_hash.c:40
#define GNUNET_log(kind,...)
@ GNUNET_OK
@ GNUNET_YES
#define GNUNET_assert(cond)
Use this for fatal errors that cannot be handled.
#define GNUNET_break(cond)
Use this for internal assertion violations that are not fatal (can be handled) but should not occur.
const char * GNUNET_h2s(const struct GNUNET_HashCode *hc)
Convert a hash value to a string (for printing debug messages).
#define GNUNET_log_strerror(level, cmd)
Log an error message at log-level 'level' that indicates a failure of the command 'cmd' with the mess...
@ GNUNET_ERROR_TYPE_ERROR
#define GNUNET_new_array(n, type)
Allocate a size n array with structs or unions of the given type.
#define GNUNET_free(ptr)
Wrapper around free.
enum GNUNET_GenericReturnValue GNUNET_PROGRAM_run(const struct GNUNET_OS_ProjectData *pd, int argc, char *const *argv, const char *binaryName, const char *binaryHelp, const struct GNUNET_GETOPT_CommandLineOption *options, GNUNET_PROGRAM_Main task, void *task_cls)
Run a standard GNUnet command startup sequence (initialize loggers and configuration,...
Definition program.c:406
void GNUNET_SCHEDULER_shutdown(void)
Request the shutdown of a scheduler.
Definition scheduler.c:572
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_shutdown(GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run on shutdown, that is when a CTRL-C signal is received,...
Definition scheduler.c:1345
void * GNUNET_SCHEDULER_cancel(struct GNUNET_SCHEDULER_Task *task)
Cancel the task with the specified identifier.
Definition scheduler.c:986
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_now(GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run as soon as possible.
Definition scheduler.c:1310
struct GNUNET_SCHEDULER_Task * GNUNET_SCHEDULER_add_delayed(struct GNUNET_TIME_Relative delay, GNUNET_SCHEDULER_TaskCallback task, void *task_cls)
Schedule a new task to be run with a specified delay.
Definition scheduler.c:1283
#define GNUNET_TIME_UNIT_SECONDS
One second.
struct GNUNET_TIME_Relative GNUNET_TIME_relative_multiply(struct GNUNET_TIME_Relative rel, unsigned long long factor)
Multiply relative time by a given factor.
Definition time.c:486
#define GNUNET_TIME_UNIT_FOREVER_ABS
Constant used to specify "forever".
static unsigned int size
Size of the "table".
Definition peer.c:68
#define _(String)
GNU gettext support macro.
Definition platform.h:179
Context for a peer which actively does DHT PUT/GET.
struct GNUNET_HashCode * hash
The hashes of the values stored via this activity context.
struct GNUNET_DHT_Handle * dht
Handler to the DHT service.
uint16_t nrefs
The number of peers currently doing GET on our data.
unsigned int put_count
How many puts should we still issue?
struct GNUNET_SCHEDULER_Task * delay_task
Delay task.
struct ActiveContext * get_ac
The active context used for our DHT GET.
struct GNUNET_DHT_PutHandle * dht_put
The put handle.
struct Context * ctx
The linked peer context.
struct GNUNET_DHT_GetHandle * dht_get
The get handle.
Context to hold data of peer.
struct GNUNET_TESTBED_Peer * peer
The testbed peer this context belongs to.
struct ActiveContext * ac
Active context; NULL if this peer is not an active peer.
struct GNUNET_TESTBED_Operation * op
Testbed operation acting on this peer.
Handle to a GET request.
Definition dht_api.c:79
Connection to the DHT service.
Definition dht_api.c:235
A (signed) path tracking a block's flow through the DHT is represented by an array of path elements,...
Handle to a PUT request.
Definition dht_api.c:43
Definition of a command line option.
A 512-bit hashcode.
The identity of the host (wraps the signing key of the peer).
Entry in list of pending tasks.
Definition scheduler.c:141
Time for absolute times used by GNUnet, in microseconds.
Time for relative time used by GNUnet, in microseconds.
uint64_t rel_value_us
The actual value.