19 #ifndef __DRIVER_MIC_COMMON_H__
20 #define __DRIVER_MIC_COMMON_H__
24 #include <common/config.h>
28 #include <source/COIProcess_source.h>
30 #define STARPU_TO_MIC_ID(id) ((id) + 1)
34 #define STARPU_MIC_PORTS_BEGIN SCIF_PORT_RSVD+1000
36 #define STARPU_MIC_SOURCE_PORT_NUMBER STARPU_MIC_PORTS_BEGIN
37 #define STARPU_MIC_SINK_PORT_NUMBER(id) ((id) + STARPU_MIC_PORTS_BEGIN)
39 #define STARPU_MIC_SOURCE_DT_PORT_NUMBER (STARPU_MAXMICDEVS + STARPU_MIC_PORTS_BEGIN)
40 #define STARPU_MIC_SINK_DT_PORT_NUMBER(id) ((id) + STARPU_MAXMICDEVS + STARPU_MIC_PORTS_BEGIN + 1)
42 #define STARPU_MIC_SINK_SINK_DT_PORT_NUMBER(me, peer_id) \
43 ((me) * STARPU_MAXMICDEVS + (peer_id) + 2 * STARPU_MAXMICDEVS + STARPU_MIC_PORTS_BEGIN + 1)
45 #define STARPU_MIC_PAGE_SIZE 0x1000
46 #define STARPU_MIC_GET_PAGE_SIZE_MULTIPLE(size) \
47 (((size) % STARPU_MIC_PAGE_SIZE == 0) ? (size) : (((size) / STARPU_MIC_PAGE_SIZE + 1) * STARPU_MIC_PAGE_SIZE))
49 #define STARPU_MIC_COMMON_REPORT_SCIF_ERROR(status) \
50 _starpu_mic_common_report_scif_error(__starpu_func__, __FILE__, __LINE__, status)
58 void _starpu_mic_common_report_scif_error(
const char *func,
const char *file,
int line,
const int status);
60 int _starpu_mic_common_recv_is_ready(
const struct _starpu_mp_node *mp_node);
62 void _starpu_mic_common_send(
const struct _starpu_mp_node *node,
void *msg,
int len);
64 void _starpu_mic_common_recv(
const struct _starpu_mp_node *node,
void *msg,
int len);
66 void _starpu_mic_common_dt_send(
const struct _starpu_mp_node *node,
void *msg,
int len,
void * event);
68 void _starpu_mic_common_dt_recv(
const struct _starpu_mp_node *node,
void *msg,
int len,
void * event);
70 void _starpu_mic_common_connect(scif_epd_t *endpoint, uint16_t remote_node, COIPROCESS process,
71 uint16_t local_port_number, uint16_t remote_port_number);
72 void _starpu_mic_common_accept(scif_epd_t *endpoint, uint16_t port_number);
Definition: driver_mic_common.h:53