2006-02-23 14:00:51 +00:00
|
|
|
/*
|
|
|
|
* DC-API: Distributed Computing Platform for Master-Worker Applications
|
|
|
|
*
|
|
|
|
* Client side
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Norbert Podhorszki <pnorbert@sztaki.hu>
|
|
|
|
* Gabor Vida <vida@sztaki.hu>
|
|
|
|
* Gabor Gombas <gombasg@sztaki.hu>
|
|
|
|
*
|
|
|
|
* Copyright MTA SZTAKI, 2006
|
|
|
|
*/
|
2006-05-19 13:39:25 +00:00
|
|
|
#ifndef _DC_CLIENT_H_
|
|
|
|
#define _DC_CLIENT_H_
|
2005-11-18 08:25:01 +00:00
|
|
|
|
2005-12-06 15:36:31 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2005-11-18 08:25:01 +00:00
|
|
|
|
2006-02-08 15:20:11 +00:00
|
|
|
#include <dc_common.h>
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-02-23 14:00:51 +00:00
|
|
|
/********************************************************************
|
|
|
|
* Constant definitions
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* File types for the DC_ResolveFileName function */
|
2006-02-08 15:34:34 +00:00
|
|
|
typedef enum {
|
|
|
|
DC_FILE_IN,
|
|
|
|
DC_FILE_OUT,
|
|
|
|
DC_FILE_TMP
|
2006-04-08 11:50:14 +00:00
|
|
|
} DC_FileType;
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-02-23 14:00:51 +00:00
|
|
|
/* Special handle for the checkpoint file */
|
|
|
|
#define DC_CHECKPOINT_FILE "__DC_CHECKPOINT_"
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-02-23 14:00:51 +00:00
|
|
|
/* Control events */
|
|
|
|
typedef enum {
|
2006-05-19 13:39:25 +00:00
|
|
|
DC_CLIENT_CHECKPOINT, /* Checkpointing is requested */
|
|
|
|
DC_CLIENT_FINISH, /* Computation should be aborted */
|
|
|
|
DC_CLIENT_MESSAGE /* A message has arrived */
|
|
|
|
} DC_ClientEventType;
|
2006-04-08 11:50:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Data types
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Description of a DC-API event */
|
2006-05-19 13:39:25 +00:00
|
|
|
typedef struct _DC_ClientEvent DC_ClientEvent;
|
|
|
|
struct _DC_ClientEvent
|
2006-04-08 11:50:14 +00:00
|
|
|
{
|
2006-05-19 13:39:25 +00:00
|
|
|
DC_ClientEventType type;
|
2006-04-08 11:50:14 +00:00
|
|
|
union
|
|
|
|
{
|
|
|
|
char *message;
|
|
|
|
};
|
|
|
|
};
|
2006-02-23 14:00:51 +00:00
|
|
|
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Function prototypes
|
|
|
|
*/
|
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Initializes the client API. */
|
2006-05-19 13:39:25 +00:00
|
|
|
int DC_initClient(void);
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Resolves the local name of input/output files. */
|
2006-04-08 11:50:14 +00:00
|
|
|
char *DC_resolveFileName(DC_FileType type, const char *logicalFileName);
|
2005-11-18 08:25:01 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Sends a sub-result back to the master. */
|
2006-02-23 14:00:51 +00:00
|
|
|
int DC_sendResult(const char *logicalFileName, const char *path,
|
|
|
|
DC_FileMode fileMode);
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Sends a message to the master. */
|
2006-02-23 14:00:51 +00:00
|
|
|
int DC_sendMessage(const char *message);
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Checks for application control events. */
|
2006-05-19 13:39:25 +00:00
|
|
|
DC_ClientEvent *DC_checkClientEvent(void);
|
2005-11-18 08:25:01 +00:00
|
|
|
|
2006-05-19 13:39:25 +00:00
|
|
|
/* Destroys the event-specific data returned by DC_checkClientEvent(). */
|
|
|
|
void DC_destroyClientEvent(DC_ClientEvent *event);
|
2006-04-04 13:11:19 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Indicates that an application-level checkpoint has completed. */
|
2006-02-23 14:00:51 +00:00
|
|
|
void DC_checkpointMade(const char *fileName);
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Informs the user interface about the fraction of work already done. */
|
2006-02-23 14:00:51 +00:00
|
|
|
void DC_fractionDone(double fraction);
|
2006-01-24 15:52:37 +00:00
|
|
|
|
2006-04-08 11:25:18 +00:00
|
|
|
/* Finishes computation. */
|
2006-05-19 13:39:25 +00:00
|
|
|
void DC_finishClient(int exitcode) __attribute__((__noreturn__));
|
2005-11-18 08:25:01 +00:00
|
|
|
|
2005-12-06 15:36:31 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2006-05-19 13:39:25 +00:00
|
|
|
#endif /* _DC_CLIENT_H_ */
|