⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iowaitsome.c

📁 fortran并行计算包
💻 C
字号:
/* -*- Mode: C; c-basic-offset:4 ; -*- *//*  * *   Copyright (C) 2003 University of Chicago.  *   See COPYRIGHT notice in top-level directory. */#include "mpioimpl.h"#ifdef HAVE_WEAK_SYMBOLS#if defined(HAVE_PRAGMA_WEAK)#pragma weak MPIO_Waitsome = PMPIO_Waitsome#elif defined(HAVE_PRAGMA_HP_SEC_DEF)#pragma _HP_SECONDARY_DEF PMPIO_Waitsome MPIO_Waitsome#elif defined(HAVE_PRAGMA_CRI_DUP)#pragma _CRI duplicate MPIO_Waitsome as PMPIO_Waitsome/* end of weak pragmas */#endif/* Include mapping from MPI->PMPI */#define MPIO_BUILD_PROFILING#include "mpioprof.h"#endif/*  This is a temporary function until we switch to using MPI-2's generalized  requests.*/int MPIO_Waitsome(int count, MPIO_Request requests[], int *outcount,		  int indices[], MPI_Status *statuses){    int i, flag, err;     MPIU_THREAD_SINGLE_CS_ENTER("io");    if (count == 1) {    	MPIR_Nest_incr();	err = MPIO_Wait( requests, statuses );    	MPIR_Nest_decr();	if (!err) {	    *outcount = 1;	    indices[0] = 0;	}	goto fn_exit;    }    /* Check for no active requests */    for (i=0; i<count; i++) {	if (requests[i] != MPIO_REQUEST_NULL) {	    break;	}    }    if (i == count) {	*outcount = MPI_UNDEFINED;	err = MPI_SUCCESS;	goto fn_exit;    }    err = MPI_SUCCESS;    *outcount = 0;    do {	for (i=0; i<count; i++) {	    if (requests[i] != MPIO_REQUEST_NULL) {		err = MPIO_Test( &requests[i], &flag, statuses );		if (flag) {		    if (!err) {			indices[0] = i;			indices++;			statuses++;			*outcount = *outcount + 1;		    }		}	    }	}    } while (*outcount == 0);fn_exit:    MPIU_THREAD_SINGLE_CS_EXIT("io");    return err;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -