/********************************************************************************************************************************/ /* Created: 15-MAR-2001 23:37:39 by OpenVMS SDL EV1-33 */ /* Source: 15-MAR-2001 23:34:57 _$11$DUA933:[BUILD.SDL]PPL$ROUTINES.SDI;1 */ /********************************************************************************************************************************/ /*** MODULE ppl$routines ***/ #ifndef __PPL$ROUTINES_LOADED #define __PPL$ROUTINES_LOADED 1 #pragma nostandard #ifdef __cplusplus extern "C" { #define __unknown_params ... #else #define __unknown_params #endif #if !defined(__VAXC) && !defined(VAXC) #define __struct struct #define __union union #else #define __struct variant_struct #define __union variant_union #endif /**************************************************************************** */ /* * */ /* COPYRIGHT (c) 1988 BY * */ /* DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASSACHUSETTS. * */ /* ALL RIGHTS RESERVED. * */ /* * */ /* THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED * */ /* ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE AND WITH THE * */ /* INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS SOFTWARE OR ANY OTHER * */ /* COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY * */ /* OTHER PERSON. NO TITLE TO AND OWNERSHIP OF THE SOFTWARE IS HEREBY * */ /* TRANSFERRED. * */ /* * */ /* THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE * */ /* AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT * */ /* CORPORATION. * */ /* * */ /* DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF ITS * */ /* SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL. * */ /* * */ /* * */ /**************************************************************************** */ /* PPL$ADJUST_SEMAPHORE_MAXIMUM */ /* */ /* Adjust a Semaphore Maximum */ /* */ /* The Adjust a Semaphore Maximum routine increments or decrements the maximum */ /* associated with a semaphore. */ /* */ unsigned int ppl$adjust_semaphore_maximum(__unknown_params); /* PPL$ADJUST_QUORUM */ /* */ /* Adjust Barrier Quorum */ /* */ /* The Adjust Barrier Quorum routine increments or decrements the quorum */ /* associated with a barrier. */ /* */ unsigned int ppl$adjust_quorum(__unknown_params); /* PPL$AWAIT_EVENT */ /* */ /* Await Event Occurrence */ /* */ /* The Await Event Occurrence routine blocks the caller until an event */ /* occurs. */ /* */ unsigned int ppl$await_event(__unknown_params); /* PPL$CREATE_APPLICATION */ /* */ /* Form or Join a PPL$ Application */ /* */ /* The Form or Join a PPL$ Application routine informs the PPL$ facility */ /* that the calling process is forming or joining a parallel application. */ /* */ unsigned int ppl$create_application(__unknown_params); /* PPL$CREATE_BARRIER */ /* */ /* Create a Barrier */ /* */ /* The Create a Barrier routine creates and initializes a */ /* barrier, and returns the barrier identifier. */ /* You use the barrier identifier to perform all operations on that */ /* barrier. */ /* */ unsigned int ppl$create_barrier(__unknown_params); /* PPL$CREATE_EVENT */ /* */ /* Create an Event */ /* */ /* The Create an Event routine creates an arbitrary user-defined event */ /* and returns the event identifier. You use the event identifier to */ /* perform all operations on that event. */ /* */ unsigned int ppl$create_event(__unknown_params); /* PPL$CREATE_SPIN_LOCK */ /* */ /* Create Spin Lock */ /* */ /* The Create Spin Lock routine creates and initializes a simple (spin) */ /* lock, and returns the lock identifier. You use that lock identifier to */ /* get and free the lock. */ /* */ unsigned int ppl$create_spin_lock(__unknown_params); /* PPL$CREATE_SHARED_MEMORY */ /* */ /* Create Shared Memory */ /* */ /* The Create Shared Memory routine creates (if necessary) and maps a */ /* section of memory that can be shared by multiple processes. */ /* */ unsigned int ppl$create_shared_memory(__unknown_params); /* PPL$CREATE_WORK_QUEUE */ /* */ /* Create a Work Queue */ /* */ /* The Create a Work Queue routine creates and initializes a work queue, and */ /* returns the work queue identifier. */ /* */ unsigned int ppl$create_work_queue(__unknown_params); /* PPL$CREATE_SEMAPHORE */ /* */ /* Create a Semaphore */ /* */ /* The Create a Semaphore routine creates and initializes a */ /* semaphore with a waiting queue, and returns the semaphore identifier. */ /* You use the semaphore identifier to perform all operations on that */ /* semaphore. */ /* */ unsigned int ppl$create_semaphore(__unknown_params); /* PPL$CREATE_VM_ZONE */ /* */ /* Create a New Virtual Memory Zone */ /* */ /* The Create a New Virtual Memory Zone routine creates a new storage */ /* zone, according to specified arguments, which is available to all */ /* participants in the application. */ /* */ unsigned int ppl$create_vm_zone(__unknown_params); /* PPL$DELETE_APPLICATION */ /* */ /* Delete a PPL$ Application */ /* */ /* The Delete a PPL$ Application routine marks all shared memory for */ /* deletion and prevents additional processes from joining the application. */ /* */ unsigned int ppl$delete_application(void); /* PPL$DECREMENT_SEMAPHORE */ /* */ /* Decrement a Semaphore */ /* */ /* The Decrement a Semaphore routine waits for a semaphore to have a */ /* value greater than 0, then decrements the value */ /* by 1 to indicate the allocation of a resource. */ /* */ unsigned int ppl$decrement_semaphore(__unknown_params); /* PPL$DISABLE_EVENT */ /* */ /* Disable Asynchronous Notification of an Event */ /* */ /* The Disable Asynchronous Notification of an Event routine disables delivery to a */ /* process of notification of an event by either AST or signal. */ /* */ unsigned int ppl$disable_event(__unknown_params); /* PPL$DELETE_WORK_ITEM */ /* */ /* Delete a Work Queue Item */ /* */ /* The Delete a Work Queue Item routine deletes a work item from a work */ /* queue. */ /* */ unsigned int ppl$delete_work_item(__unknown_params); /* PPL$DELETE_SHARED_MEMORY */ /* */ /* Delete Shared Memory */ /* */ /* The Delete Shared Memory routine deletes or unmaps from a global */ /* section that you created using the PPL$CREATE_SHARED_MEMORY routine. */ /* Optionally, this routine writes the contents of the global section to */ /* disk before deleting the section. */ /* */ unsigned int ppl$delete_shared_memory(__unknown_params); /* PPL$DELETE_WORK_QUEUE */ /* */ /* Delete a Work Queue */ /* */ /* The Delete a Work Queue routine deletes the specified work queue, and releases */ /* any storage associated with it. */ /* */ unsigned int ppl$delete_work_queue(__unknown_params); /* PPL$ENABLE_EVENT_AST */ /* */ /* Enable AST Notification of an Event */ /* */ /* The Enable AST Notification of an Event routine specifies the address of */ /* an AST routine (and optionally an argument to that routine) to be delivered */ /* when an event occurs. */ /* */ unsigned int ppl$enable_event_ast(__unknown_params); /* PPL$ENABLE_EVENT_SIGNAL */ /* */ /* Enable Signal Notification of an Event */ /* */ /* The Enable Signal Notification of an Event routine specifies a */ /* condition value to be signaled when the event occurs. */ /* */ unsigned int ppl$enable_event_signal(__unknown_params); /* PPL$FLUSH_SHARED_MEMORY */ /* */ /* Flush Shared Memory */ /* */ /* The Flush Shared Memory routine writes (flushes) to disk the contents */ /* of a global section that you created using the PPL$CREATE_SHARED_MEMORY */ /* routine. Only pages that have been modified are flushed to disk. */ /* */ unsigned int ppl$flush_shared_memory(__unknown_params); /* PPL$FIND_OBJECT_ID */ /* */ /* Find Object Identification */ /* */ /* Given the name of a spin lock, semaphore, barrier, event, work queue, */ /* or shared memory zone, the Find Object Identification routine returns */ /* the identifier of the object associated with the name you specify. */ /* */ unsigned int ppl$find_object_id(__unknown_params); /* PPL$FIND_SYNCH_ELEMENT_ID */ /* */ /* Find */ /* */ /* Given the name of a spin lock, semaphore, barrier, or event, the */ /* Find Synchronization Element Identification routine returns the */ /* identifier of the associated synchronization element. */ /* */ unsigned int ppl$find_synch_element_id(__unknown_params); /* PPL$GET_INDEX */ /* */ /* Get Index of a Participant */ /* */ /* The Get Index of a Participant routine returns an index that is unique */ /* within the application. A value of zero signifies the participant that */ /* formed the application. The other participants in the application */ /* always return an index greater than zero. */ /* */ unsigned int ppl$get_index(__unknown_params); /* PPL$INSERT_WORK_ITEM */ /* */ /* Insert a Work Queue Item */ /* */ /* The Insert a Work Queue Item routine inserts a work item into the specified work */ /* queue. */ /* */ unsigned int ppl$insert_work_item(__unknown_params); /* PPL$INCREMENT_SEMAPHORE */ /* */ /* Increment a Semaphore */ /* */ /* The Increment a Semaphore routine increments the value of the semaphore */ /* by 1, analogous to the signal protocol. If any other participants */ /* are blocked on a call to PPL$DECREMENT_SEMAPHORE for this semaphore, */ /* one is removed from the queue and awakened. */ /* The semaphore must have been created by PPL$CREATE_SEMAPHORE. */ /* */ unsigned int ppl$increment_semaphore(__unknown_params); /* PPL$INDEX_TO_PID */ /* */ /* Convert Participant Index to VMS PID */ /* */ /* The Convert Participant Index to VMS PID routine returns the VMS PID */ /* of the process associated with the specified index. */ /* */ unsigned int ppl$index_to_pid(__unknown_params); /* PPL$INITIALIZE */ /* */ /* Initialize the PPL$ Facility */ /* */ /* The Initialize the PPL$ Facility routine informs the PPL$ facility that the */ /* caller is forming or joining the parallel application. Calling this */ /* routine is optional, because PPL$ initializes itself at the */ /* first call to a PPL$ routine. */ /* */ unsigned int ppl$initialize(__unknown_params); /* PPL$PID_TO_INDEX */ /* */ /* Convert VMS PID to Participant Index */ /* */ /* The Convert VMS PID to Participant Index routine returns the PPL$-defined */ /* participant index of the process associated with the */ /* specified VMS PID. */ /* */ unsigned int ppl$pid_to_index(__unknown_params); /* PPL$READ_BARRIER */ /* */ /* Read a Barrier */ /* */ /* The Read a Barrier routine returns the specified barrier's current quorum and */ /* the number of participants currently waiting (blocked) at the barrier. The */ /* barrier must have been created by PPL$CREATE_BARRIER. */ /* */ unsigned int ppl$read_barrier(__unknown_params); /* PPL$READ_EVENT */ /* */ /* Read an Event State */ /* */ /* The Read an Event State routine returns the current state of the specified */ /* event. */ /* The state can be not_occurred or not_occurred. */ /* */ unsigned int ppl$read_event(__unknown_params); /* PPL$READ_SEMAPHORE */ /* */ /* Read Semaphore Values */ /* */ /* The Read Semaphore Values routine returns the current or */ /* maximum values, or both, of the specified counting semaphore. */ /* The semaphore must have been created by */ /* PPL$CREATE_SEMAPHORE. */ /* */ unsigned int ppl$read_semaphore(__unknown_params); /* PPL$RELEASE_SPIN_LOCK */ /* */ /* Release Spin Lock */ /* */ /* The Release Spin Lock routine relinquishes the spin lock by clearing the */ /* bit representing the lock. The lock must have been created by */ /* PPL$CREATE_SPIN_LOCK. */ /* */ unsigned int ppl$release_spin_lock(__unknown_params); /* PPL$RESET_EVENT */ /* */ /* Reset an Event */ /* */ /* The Reset an Event routine resets an event's state to */ /* not_occurred. */ /* */ unsigned int ppl$reset_event(__unknown_params); /* PPL$REMOVE_WORK_ITEM */ /* */ /* Remove a Work Queue Item */ /* */ /* The Remove a Work Queue Item routine removes the next item in order from a work */ /* queue. */ /* */ unsigned int ppl$remove_work_item(__unknown_params); /* PPL$READ_SPIN_LOCK */ /* */ /* Read a Spin Lock State */ /* */ /* The Read a Spin Lock State routine returns the current state of a spin */ /* lock. The state can be not_seized or not_seized. */ /* */ unsigned int ppl$read_spin_lock(__unknown_params); /* PPL$READ_WORK_QUEUE */ /* */ /* Read a Work Queue */ /* */ /* The Read a Work Queue routine returns information about a work queue. */ /* */ unsigned int ppl$read_work_queue(__unknown_params); /* PPL$SET_SEMAPHORE_MAXIMUM */ /* */ /* Set a Semaphore Maximum */ /* */ /* The Set a Semaphore Maximum routine dynamically sets the maximum value of a */ /* semaphore. */ /* */ unsigned int ppl$set_semaphore_maximum(__unknown_params); /* PPL$SPAWN */ /* */ /* Initiate Parallel Execution */ /* */ /* The Initiate Parallel Execution routine executes code in parallel */ /* with the caller by creating one or more subordinate threads of execution */ /* (VMS subprocesses). */ /* */ unsigned int ppl$spawn(__unknown_params); /* PPL$SET_QUORUM */ /* */ /* Set Barrier Quorum */ /* */ /* The Set Barrier Quorum routine dynamically sets a value for the */ /* specified barrier's quorum. */ /* */ unsigned int ppl$set_quorum(__unknown_params); /* PPL$STOP */ /* */ /* Stop a Participant */ /* */ /* The Stop a Participant routine terminates the execution of the specified */ /* participant in this application. */ /* */ unsigned int ppl$stop(__unknown_params); /* PPL$SEIZE_SPIN_LOCK */ /* */ /* Seize Spin Lock */ /* */ /* The Seize Spin Lock routine retrieves a simple (spin) lock by waiting in a */ /* spin loop until the lock is free. The lock must have been created by */ /* PPL$CREATE_SPIN_LOCK. */ /* */ unsigned int ppl$seize_spin_lock(__unknown_params); /* PPL$TERMINATE */ /* */ /* Abort PPL$ Participation */ /* */ /* The Abort PPL$ Participation routine ends the caller's */ /* participation in the application prematurely---that is, at some time */ /* before the caller actually completes its execution. */ /* */ unsigned int ppl$terminate(__unknown_params); /* PPL$TRIGGER_EVENT */ /* */ /* Trigger an Event */ /* */ /* The Trigger an Event routine causes the event's state to become */ /* occurred. You control whether all pending actions for */ /* the event are processed (made to occur), or just one is processed. */ /* A pending action can be an AST, a signal (condition), or a wakeup. */ /* */ unsigned int ppl$trigger_event(__unknown_params); /* PPL$UNIQUE_NAME */ /* */ /* Produce a Unique Name */ /* */ /* The Produce a Unique Name routine returns an application-unique name. */ /* A system-unique string specific to the calling application is appended */ /* to the string specified by the user. */ /* The resulting name is identical for all participants in */ /* the application, but different from those for all other applications on that */ /* system. */ /* */ unsigned int ppl$unique_name(__unknown_params); /* PPL$WAIT_AT_BARRIER */ /* */ /* Synchronize at a Barrier */ /* */ /* The Synchronize at a Barrier routine causes the caller to */ /* wait at the specified barrier. */ /* The barrier is in effect from the time the first participant calls */ /* PPL$WAIT_AT_BARRIER until each member of the */ /* quorum has issued the call. At that time, the wait concludes and */ /* all are released for further execution. */ /* */ unsigned int ppl$wait_at_barrier(__unknown_params); #ifdef __cplusplus } #endif #pragma standard #endif /* __PPL$ROUTINES_LOADED */