/* * DC-API: Distributed Computing Platform for Master-Worker Applications * * Master side * * Authors: * Norbert Podhorszki * Gabor Vida * Gabor Gombas * * Copyright MTA SZTAKI, 2006 */ #ifndef _DC_H_ #define _DC_H_ #ifdef __cplusplus extern "C" { #endif #include /******************************************************************** * Constant definitions */ /* Possible states of a work unit */ typedef enum { DC_WU_READY, /* Created, but not yet submitted */ DC_WU_RUNNING, /* Submitted and running */ DC_WU_FINISHED, /* The WU finished normally according to the grid infrastructure. Note that the application client returning an error code is considered a 'normal' shutdown as far as the infrastructure is concerned, so you should check the exit status and/or other output. */ DC_WU_SUSPENDED,/* The work unit is suspended */ DC_WU_ABORTED, /* The WU was aborted for some reason (infrastructure failure, no canonical result, or by calling DC_cancel()) */ DC_WU_UNKNOWN /* The WU's state is not known. This may happen for example when a WU is serialized, then it finishes, and upon deserialization the underlying grid infrastructure no longer knows about it */ } DC_WUState; /* Possible event types */ typedef enum { DC_MASTER_RESULT, /* A DC_Result is available */ DC_MASTER_SUBRESULT, /* A sub-result is available */ DC_MASTER_MESSAGE /* A message has arrived */ } DC_MasterEventType; /******************************************************************** * Data types */ /* Opaque type representing a workunit */ typedef struct _DC_Workunit DC_Workunit; /* Opaque type representing a result */ typedef struct _DC_Result DC_Result; /* Descriptor of a physical file */ typedef struct _DC_PhysicalFile DC_PhysicalFile; struct _DC_PhysicalFile { char *label; char *path; DC_FileMode mode; }; /* Description of a DC-API event */ typedef struct _DC_MasterEvent DC_MasterEvent; struct _DC_MasterEvent { DC_MasterEventType type; DC_Workunit *wu; union { DC_Result *result; DC_PhysicalFile *subresult; char *message; }; }; /* Prototype of the result handling callback function. */ typedef void (*DC_ResultCallback)(DC_Workunit *wu, DC_Result *result); /* Prototype of the sub-result handling callback. */ typedef void (*DC_SubresultCallback)(DC_Workunit *wu, const char *logicalFileName, const char *path); /* Prototype of the message-handling callback. */ typedef void (*DC_MessageCallback)(DC_Workunit *wu, const char *message); /******************************************************************** * Function prototypes: Library utilities */ /* Initializes the DC-API. */ int DC_initMaster(const char *configFile); /* Sets the callback functions that will be called when a particular event. */ void DC_setMasterCb(DC_ResultCallback resultcb, DC_SubresultCallback subresultcb, DC_MessageCallback msgcb); /* Queries the number of WUs known to the API in the given state. */ int DC_getWUNumber(DC_WUState state); /* Queries per-client configuration variables */ char *DC_getClientCfgStr(const char *clientName, const char *key, int fallbackGlobal); /* Queries per-client configuration variables */ int DC_getClientCfgInt(const char *clientName, const char *key, int defaultValue, int fallbackGlobal); /* Queries per-client configuration variables */ double DC_getClientCfgDouble(const char *clientName, const char *key, double defaultValue, int fallbackGlobal); /******************************************************************** * Function prototypes: Event processing */ /* Waits for events and processes them. */ int DC_processMasterEvents(int timeout); /* Checks for events and return them. */ DC_MasterEvent *DC_waitMasterEvent(const char *wuFilter, int timeout); /* Checks for events for a particular WU. */ DC_MasterEvent *DC_waitWUEvent(DC_Workunit *wu, int timeout); /* Destroys an event. */ void DC_destroyMasterEvent(DC_MasterEvent *event); /******************************************************************** * Function prototypes: Work unit management */ /* Creates one work unit. */ DC_Workunit *DC_createWU(const char *clientName, const char *arguments[], int subresults, const char *tag); /* Sets an input file for the work unit. */ int DC_addWUInput(DC_Workunit *wu, const char *logicalFileName, const char *URL, DC_FileMode fileMode); /* Defines an output file for the work unit. */ int DC_addWUOutput(DC_Workunit *wu, const char *logicalFileName); /* Sets the priority for the work unit. */ int DC_setWUPriority(DC_Workunit *wu, int priority); /* Serializes a work unit description. */ char *DC_serializeWU(DC_Workunit *wu); /* Restores a serialized work unit. */ DC_Workunit *DC_deserializeWU(const char *buf); /* Queries the state of a work unit. */ DC_WUState DC_getWUState(DC_Workunit *wu); /* Submits a work unit. */ int DC_submitWU(DC_Workunit *wu); /* Queries the low-level ID of the work unit. */ char *DC_getWUId(const DC_Workunit *wu); /* Queries the tag of a work unit. */ char *DC_getWUTag(const DC_Workunit *wu); /* Cancels all computations for a given work unit. */ int DC_cancelWU(DC_Workunit *wu); /* Temporarily suspends the execution of a work unit. */ int DC_suspendWU(DC_Workunit *wu); /* Resumes computation of a previously suspended work unit. */ int DC_resumeWU(DC_Workunit *wu); /* Releases internal resources allocated to a work unit. */ void DC_destroyWU(DC_Workunit *wu); /* Sends a message to a running work unit. */ int DC_sendWUMessage(DC_Workunit *wu, const char *message); /******************************************************************** * Function prototypes: Result handling */ /* Queries what optional fields are present in the result. */ unsigned DC_getResultCapabilities(const DC_Result *result); /* Returns the WU that generated this result. */ DC_Workunit *DC_getResultWU(DC_Result *result); /* Returns the exit code of the client application. */ int DC_getResultExit(const DC_Result *result); /* Returns the local name of an output file. */ char *DC_getResultOutput(const DC_Result *result, const char *logicalFileName); #ifdef __cplusplus } #endif #endif /* _DC_H_ */