Explain is a new parameter

This commit is contained in:
Quentin 2019-10-11 16:00:56 +02:00
parent d6254351f6
commit 7e7db6d6df

View file

@ -51,6 +51,7 @@ struct light_ctx {
size_t monit_pkt_size; size_t monit_pkt_size;
uint8_t csv; uint8_t csv;
uint8_t is_measlat; uint8_t is_measlat;
uint8_t explain;
}; };
void algo_lightning_free(void* v) { void algo_lightning_free(void* v) {
@ -73,6 +74,7 @@ void algo_lightning_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, str
lightc->fast_count = lightc->total_links / 2; lightc->fast_count = lightc->total_links / 2;
lightc->sleep_duration = 500; lightc->sleep_duration = 500;
lightc->csv = 0; lightc->csv = 0;
lightc->explain = 0;
uint64_t window = 2000; uint64_t window = 2000;
if (ap->algo_specific_params != NULL) { if (ap->algo_specific_params != NULL) {
@ -86,7 +88,8 @@ void algo_lightning_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, str
sscanf(token, "window=%ld", &window); sscanf(token, "window=%ld", &window);
sscanf(token, "sent_past_links=%d", &lightc->sent_past_links); sscanf(token, "sent_past_links=%d", &lightc->sent_past_links);
sscanf(token, "csv=%d", &lightc->csv); sscanf(token, "csv=%d", &lightc->csv);
sscanf(token, "measlat=%c", &lightc->is_measlat); sscanf(token, "measlat=%d", &lightc->is_measlat);
sscanf(token, "explain=%d", &lightc->explain);
} }
} }
@ -107,6 +110,7 @@ void algo_lightning_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, str
printf("sent_past_links = %d\n", lightc->sent_past_links); printf("sent_past_links = %d\n", lightc->sent_past_links);
printf("csv = %s\n", lightc->csv ? "yes" : "no"); printf("csv = %s\n", lightc->csv ? "yes" : "no");
printf("measlat = %s\n", lightc->is_measlat ? "yes" : "no"); printf("measlat = %s\n", lightc->is_measlat ? "yes" : "no");
printf("explain = %s\n", lightc->explain ? "yes" : "no");
} }
void monitoring(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) { void monitoring(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) {
@ -123,11 +127,13 @@ void monitoring(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct
uint8_t *prev_links = &ap->fmt.content.link_monitoring_lightning.dyn_struct; uint8_t *prev_links = &ap->fmt.content.link_monitoring_lightning.dyn_struct;
int16_t *remote_stats = (int16_t*)(prev_links + sizeof(uint8_t) * lightc->sent_past_links); int16_t *remote_stats = (int16_t*)(prev_links + sizeof(uint8_t) * lightc->sent_past_links);
if (lightc->explain) {
printf("(monitoring.stats) "); printf("(monitoring.stats) ");
for (int i = 0; i < lightc->total_links; i++) { for (int i = 0; i < lightc->total_links; i++) {
printf("%d, ", remote_stats[i]); printf("%d, ", remote_stats[i]);
} }
printf("\n"); printf("\n");
}
int64_t pkt_id = ap->fmt.content.link_monitoring_lightning.id; int64_t pkt_id = ap->fmt.content.link_monitoring_lightning.id;
int64_t missing = pkt_id - (lightc->pkt_rcv_id + 1); int64_t missing = pkt_id - (lightc->pkt_rcv_id + 1);
@ -150,7 +156,7 @@ void monitoring(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct
te->detected_at = now; te->detected_at = now;
te->link_id = link_id; te->link_id = link_id;
te->pkt_id = miss_id; te->pkt_id = miss_id;
printf("(monitoring.delay) packet=%ld, link=%d, state=%s\n", miss_id, link_id, ooo_state_str[te->state]); if (lightc->explain) printf("(monitoring.delay) packet=%ld, link=%d, state=%s\n", miss_id, link_id, ooo_state_str[te->state]);
} }
// Update current packet status // Update current packet status
@ -160,7 +166,7 @@ void monitoring(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct
te2->pkt_id = pkt_id; te2->pkt_id = pkt_id;
te2->link_id = link_id; te2->link_id = link_id;
te2->finished_at = now; te2->finished_at = now;
printf("(monitoring.rcv) packet=%ld, link=%d, state=%s\n", pkt_id, link_id, ooo_state_str[te2->state]); if (lightc->explain) printf("(monitoring.rcv) packet=%ld, link=%d, state=%s\n", pkt_id, link_id, ooo_state_str[te2->state]);
} }
int deliver(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) { int deliver(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) {