18#ifndef __STARPU__FXT_H__
19#define __STARPU__FXT_H__
24#include <starpu_config.h>
25#include <common/config.h>
40#include "../mpi/src/starpu_mpi_fxt.h"
42#include "../../../include/starpu_fxt.h"
44#define MAX_MPI_NODES 64
46extern char _starpu_last_codelet_symbol[STARPU_NMAXWORKERS][(FXT_MAX_PARAMS-5)*
sizeof(
unsigned long)];
48void _starpu_fxt_dag_init(
char *dag_filename);
49void _starpu_fxt_dag_terminate(
void);
50void _starpu_fxt_dag_add_tag(
const char *prefix, uint64_t tag,
unsigned long job_id,
const char *label);
51void _starpu_fxt_dag_add_tag_deps(
const char *prefix, uint64_t child, uint64_t father,
const char *label);
52void _starpu_fxt_dag_set_tag_done(
const char *prefix, uint64_t tag,
const char *color);
53void _starpu_fxt_dag_add_task_deps(
const char *prefix,
unsigned long dep_prev,
unsigned long dep_succ,
const char *label);
54void _starpu_fxt_dag_set_task_name(
const char *prefix,
unsigned long job_id,
const char *label,
const char *color);
55void _starpu_fxt_dag_add_send(
int src,
unsigned long dep_prev,
unsigned long tag,
unsigned long id);
56void _starpu_fxt_dag_add_receive(
int dst,
unsigned long dep_prev,
unsigned long tag,
unsigned long id);
57void _starpu_fxt_dag_add_sync_point(
void);
63int _starpu_fxt_mpi_find_sync_point(
char *filename_in, uint64_t *offset,
int *key,
int *rank);
64void _starpu_fxt_mpi_add_send_transfer(
int src,
int dst,
long mpi_tag,
size_t size,
float date,
long jobid);
65void _starpu_fxt_mpi_add_recv_transfer(
int src,
int dst,
long mpi_tag,
float date,
long jobid);
66void _starpu_fxt_display_mpi_transfers(
struct starpu_fxt_options *options,
int *ranks, FILE *out_paje_file);
68void _starpu_fxt_write_paje_header(FILE *file,
struct starpu_fxt_options *options);
70extern int _starpu_poti_extendedSetState;
71extern int _starpu_poti_semiExtendedSetState;
72extern int _starpu_poti_MemoryEvent;
73extern int _starpu_poti_MpiLinkStart;
78void _starpu_fxt_component_print_header(FILE *output);
79void _starpu_fxt_component_new(uint64_t component,
char *name);
80void _starpu_fxt_component_connect(uint64_t parent, uint64_t child);
81void _starpu_fxt_component_update_ntasks(
unsigned nsubmitted,
unsigned curq_size);
82void _starpu_fxt_component_push(FILE *output,
struct starpu_fxt_options *options,
double timestamp,
int workerid, uint64_t from, uint64_t to, uint64_t task,
unsigned prio);
83void _starpu_fxt_component_pull(FILE *output,
struct starpu_fxt_options *options,
double timestamp,
int workerid, uint64_t from, uint64_t to, uint64_t task,
unsigned prio);
84void _starpu_fxt_component_dump(FILE *output);
85void _starpu_fxt_component_finish(FILE *output);