-
Notifications
You must be signed in to change notification settings - Fork 2
Handle Debugging:Queries
ToDo: apply the language distinction for all handle types
- should the query input be the MPI opaque handle value or a pointer to a opaque handle?
- Is taddr_t big enought to hold an opaque handle?
Query a specific MPI_Comm handle and, if found and valid, return a handle that can subsequently be queried for a variety of information about this communicator. Note that the returned handle is only valid at a specific point in time. If the MPI process advances after the handle is returned, the handle should be considered stale and should therefore be freed. This function should be invoked again to obtain a new handle.
int mpidbg_comm_query(mqs_process *process,
mqs_taddr_t comm,
struct mpidbg_comm_handle_t **handle);
Free a handle returned by the mpidbg_comm_query() function.
int mpidbg_comm_handle_free(struct mpidbg_comm_handle_t *handle);
Query a handle returned by mpidbg_comm_query() and, if found and valid, return basic information about the original communicator. All arrays returned in OUT variables are allocated by this function, but are the responsibility of the caller to be freed.
struct mpidbg_keyvalue_pair_t {
/* String key name */
char *key_name;
/* String value */
char *value;
};
int mpidbg_comm_query_basic(
struct mpidbg_comm_handle_t *handle,
char **comm_name,
enum mpidbg_comm_info_bitmap_t *comm_bitflags,
int *comm_rank,
int *comm_size,
int *comm_fortran_handle,
mqs_taddr_t *comm_cxx_handle,
struct mpidbg_keyvalue_pair_t **comm_extra_info);
With:
enum mpidbg_comm_info_bitmap_t {
/* Predefined communicator if set (user-defined if not set) */
MPIDBG_COMM_INFO_PREDEFINED = 0x001,
/* Whether this communicator is a cartesian communicator or not
(mutually exclusive with _GRAPH and _INTERCOMM) */
MPIDBG_COMM_INFO_CARTESIAN = 0x002,
/* Whether this communicator is a graph communicator or not
(mutually exclusive with _CARTESIAN and _INTERCOMM) */
MPIDBG_COMM_INFO_GRAPH = 0x004,
/* If a cartesian or graph communicator, whether the processes in
this communicator were re-ordered when the topology was
assigned. */
MPIDBG_COMM_INFO_TOPO_REORDERED = 0x008,
/* Whether this is an intercommunicator or not (this communicator
is an intracommunicator if this flag is not yet). */
MPIDBG_COMM_INFO_INTERCOMM = 0x010,
/* This communicator has been marked for freeing by the user
application if set */
MPIDBG_COMM_INFO_FREED_HANDLE = 0x020,
/* This communicator has actually been freed by the MPI
implementation if set */
MPIDBG_COMM_INFO_FREED_OBJECT = 0x040,
/* The queried communicator is MPI_COMM_NULL */
MPIDBG_COMM_INFO_COMM_NULL = 0x080,
/* The queried communicator is a C handle */
MPIDBG_COMM_INFO_HANDLE_C = 0x100,
/* The queried communicator is a C++ handle */
MPIDBG_COMM_INFO_HANDLE_CXX = 0x200,
/* The queried communicator is a F77/F90 integer handle */
MPIDBG_COMM_INFO_HANDLE_FINT = 0x400,
/* The queried communicator has a distributed graph topology attached to it */
MPIDBG_COMM_INFO_DIST_GRAPH = 0x00000400,
/* Sentinel max value */
MPIDBG_COMM_INFO_MAX
};
Query a handle returned by mpidbg_comm_query() and, if found and valid, return information about the MPI processes in this communicator. All arrays returned in OUT variables are allocated by this function, but are the responsibility of the caller to be freed.
int mpidbg_comm_query_procs(struct mpidbg_comm_handle_t *handle,
int *comm_num_local_procs,
struct mpidbg_process_t **comm_local_procs,
int *comm_num_remote_procs,
struct mpidbg_process_t **comm_remote_procs);
Query a handle returned by mpidbg_comm_query() and, if found and valid, return information about the topology associated with the communicator (if any). It is not an error to call this function with communicators that do not have associated topologies; such communicators will still return MPIDBG_SUCCESS but simply return a value of 0 in the comm_out_length OUT parameter.
int mpidbg_comm_query_topo(struct mpidbg_comm_handle_t *handle,
int *comm_out_length,
int **comm_cart_dims_or_graph_indexes,
int **comm_cart_periods_or_graph_edges);
Query a handle returned by mpidbg_comm_query() and, if found and valid, return information about the attributes associated with the communicator (if any). It is not an error to call this function with communicators that do not have associated attributes; such communicators will still return MPIDBG_SUCCESS but simply return a value of 0 in the comm_attrs_length OUT parameter.
int mpidbg_comm_query_attrs(struct mpidbg_comm_handle_t *comm_handle,
int *comm_num_attrs,
struct mpidbg_attribute_pair_t *comm_attrs);
Query a handle returned by mpidbg_comm_query() and, if found and valid, return an array of pending requests on this communicator. All arrays returned in OUT variables are allocated by this function, but are the responsibility of the caller to be freed.
int mpidbg_comm_query_requests(struct mpidbg_comm_handle_t *handle,
int *comm_num_requests,
mqs_taddr_t **comm_pending_requests);
alternative:
int mpidbg_comm_query_requests(struct mpidbg_comm_handle_t *handle,
int *comm_num_requests,
struct mpidbg_request_handle_t **comm_pending_requests);
Query a handle returned by mpidbg_comm_query() and, if found and valid, return arrays of MPI_File and MPI_Win handles that were derived from this communicator.
int mpidbg_comm_query_derived(struct mpidbg_comm_handle_t *handle,
int *comm_num_derived_files,
mqs_taddr_t **comm_derived_files,
int *comm_num_derived_windows,
mqs_taddr_t **comm_derived_windows);
What to solve:
typedef ompi_request_.._t * MPI_Request;
typedef int MPI_Request;
int MPI_Irecv(void *buf, int count, MPI_Datatype datatype, int source,
int tag, MPI_Comm comm, MPI_Request *request);
MPI_Request request;
MPI_Irecv(..., &request);
...
MPI_Wait(&request);
Use case: stopped at MPI_Wait
, what is request
?
These functions are analogous to the mpidbg_comm_* functions, but for MPI_Request.
int mpidbg_request_query(mqs_process *process,
mqs_taddr_t request,
struct mpidbg_request_handle_t **handle);
Free a handle returned by the mpidbg_request_query() function.
int mpidbg_request_handle_free(struct mpidbg_request_handle_t *handle);
These functions are analogous to the mpidbg_comm_* functions, but for MPI_Status.
int mpidbg_status_query(mqs_process *process,
mqs_taddr_t status,
struct mpidbg_status_handle_t **handle);
Free a handle returned by the mpidbg_status_query() function.
int mpidbg_status_handle_free(struct mpidbg_status_handle_t *handle);
These functions are analogous to the mpidbg_comm_* functions, but for MPI_Datatype.
typedef union langHandle {mqs_taddr_t cType, int64 fortranType} langHandle;
int mpidbg_type_query(mqs_process *process,
langHandle type, // The MPI handle
int language, // MPIDBG_TYPE_LANG_C or MPIDBG_TYPE_LANG_FORTRAN
struct mpidbg_type_handle_t **handle); // The debugging handle
Function to query the list of predefined data types
int mpidbg_type_query_predefined_map(mqs_process *process,
struct mpidbg_name_map_t **mpidbg_type_name_map,
int *num_elements);
enum mpidbg_type_bitmap_t{
MPIDBG_TYPE_KIND_INT = 0x1,
MPIDBG_TYPE_KIND_UINT = 0x2,
MPIDBG_TYPE_KIND_FLOAT = 0x4,
MPIDBG_TYPE_KIND_COMPLEX = 0x8,
MPIDBG_TYPE_KIND_NONTRIVIAL = 0x10, // use the combiner to get the structure (MPI_DOUBLE_INT)
MPIDBG_TYPE_LANG_C = 0x100,
MPIDBG_TYPE_LANG_FORTRAN = 0x200
};
struct mpidbg_name_map_t {
/* Name of the handle */
char *map_name;
/* Handle that the name corresponds to. Will be 0/NULL if there
is no corresponding back-end object. */
mqs_taddr_t type_c_handle; // allways C handle value
int64 type_fortran_handle;
enum mpidbg_type_kind_t kind;
};
Basic query function:
int mpidbg_type_query_basic(
struct mpidbg_type_handle_t *handle,
char **type_name, // or: use enum for all predefined types
enum mpidbg_type_info_bitmap_t *type_bitflags,
int64 *type_size,
int64 *type_extent, // or in a separate query
int64 *type_real_extent, // or in a separate query
int64 *type_fortran_handle,
mqs_taddr_t *type_c_handle,
/*mqs_taddr_t *type_cxx_handle, was deprecated and removed*/
? struct mpidbg_keyvalue_pair_t **comm_extra_info);
Envelope functions:
int mpidbg_type_query_envelope(
struct mpidbg_type_handle_t *handle,
int64 *num_integers,
int64 *num_addresses,
int64 *num_datatypes);
int mpidbg_type_query_combiner(
struct mpidbg_type_handle_t *handle,
int64 max_integers,
int64 max_addresses,
int64 max_datatypes,
int64 array_of_integers[],
int64 array_of_addresses[],
mqs_taddr_t array_of_type_mpi_handle[], // used to lookup predefined types in the map
struct mpidbg_type_handle_t array_of_type_dbg_handle[] // used for further exploration);
Free a handle returned by the mpidbg_type_query() function.
int mpidbg_type_handle_free(struct mpidbg_type_handle_t *handle);
These functions are analogous to the mpidbg_comm_* functions, but for MPI_File.
int mpidbg_file_query(mqs_process *process,
mqs_taddr_t file,
struct mpidbg_file_handle_t **handle);
Free a handle returned by the mpidbg_file_query() function.
int mpidbg_file_handle_free(struct mpidbg_file_handle_t *handle);
These functions are analogous to the mpidbg_comm_* functions, but for MPI_Win.
int mpidbg_win_query(mqs_process *process,
mqs_taddr_t win,
struct mpidbg_win_handle_t **handle);
Free a handle returned by the mpidbg_win_query() function.
int mpidbg_win_handle_free(struct mpidbg_win_handle_t *handle);