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)
58void _starpu_mic_common_report_scif_error(
const char *func,
const char *file,
int line,
const int status);
60int _starpu_mic_common_recv_is_ready(
const struct _starpu_mp_node *mp_node);
62void _starpu_mic_common_send(
const struct _starpu_mp_node *node,
void *msg,
int len);
64void _starpu_mic_common_recv(
const struct _starpu_mp_node *node,
void *msg,
int len);
66void _starpu_mic_common_dt_send(
const struct _starpu_mp_node *node,
void *msg,
int len,
void * event);
68void _starpu_mic_common_dt_recv(
const struct _starpu_mp_node *node,
void *msg,
int len,
void * event);
70void _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);
72void _starpu_mic_common_accept(scif_epd_t *endpoint, uint16_t port_number);
Definition driver_mic_common.h:53