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

📄 querythread.c

📁 mpi并行计算的c++代码 可用vc或gcc编译通过 可以用来搭建并行计算试验环境
💻 C
字号:
/* -*- Mode: C; c-basic-offset:4 ; -*- *//*  $Id: querythread.c,v 1.13 2005/02/02 23:57:23 toonen Exp $ * *  (C) 2001 by Argonne National Laboratory. *      See COPYRIGHT in top-level directory. */#include "mpiimpl.h"/* -- Begin Profiling Symbol Block for routine MPI_Query_thread */#if defined(HAVE_PRAGMA_WEAK)#pragma weak MPI_Query_thread = PMPI_Query_thread#elif defined(HAVE_PRAGMA_HP_SEC_DEF)#pragma _HP_SECONDARY_DEF PMPI_Query_thread  MPI_Query_thread#elif defined(HAVE_PRAGMA_CRI_DUP)#pragma _CRI duplicate MPI_Query_thread as PMPI_Query_thread#endif/* -- End Profiling Symbol Block *//* Define MPICH_MPI_FROM_PMPI if weak symbols are not supported to build   the MPI routines */#ifndef MPICH_MPI_FROM_PMPI#define MPI_Query_thread PMPI_Query_thread#endif#undef FUNCNAME#define FUNCNAME MPI_Query_thread/*@   MPI_Query_thread - Return the level of thread support provided by the MPI     library   Output Parameter:.  provided - Level of thread support provided.  This is the same value   that was returned in the 'provided' argument in 'MPI_Init_thread'.   Notes:   The valid values for the level of thread support are\:+ MPI_THREAD_SINGLE - Only one thread will execute. . MPI_THREAD_FUNNELED - The process may be multi-threaded, but only the main   thread will make MPI calls (all MPI calls are funneled to the    main thread). . MPI_THREAD_SERIALIZED - The process may be multi-threaded, and multiple   threads may make MPI calls, but only one at a time: MPI calls are not   made concurrently from two distinct threads (all MPI calls are serialized). - MPI_THREAD_MULTIPLE - Multiple threads may call MPI, with no restrictions.    If 'MPI_Init' was called instead of 'MPI_Init_thread', the level of   thread support is defined by the implementation.  This routine allows   you to find out the provided level.  It is also useful for library    routines that discover that MPI has already been initialized and   wish to determine what level of thread support is available..N SignalSafe.N Fortran.N Errors.N MPI_SUCCESS@*/int MPI_Query_thread( int *provided ){    static const char FCNAME[] = "MPI_Query_thread";    int mpi_errno = MPI_SUCCESS;    MPID_MPI_STATE_DECL(MPID_STATE_MPI_QUERY_THREAD);    MPIR_ERRTEST_INITIALIZED_ORDIE();        MPID_CS_ENTER();    MPID_MPI_FUNC_ENTER(MPID_STATE_MPI_QUERY_THREAD);#   ifdef HAVE_ERROR_CHECKING    {        MPID_BEGIN_ERROR_CHECKS;        {	    MPIR_ERRTEST_ARGNULL(provided,"provided",mpi_errno);            if (mpi_errno) goto fn_fail;        }        MPID_END_ERROR_CHECKS;    }#   endif /* HAVE_ERROR_CHECKING */        /* ... body of routine ...  */    *provided = MPIR_Process.thread_provided;    /* ... end of body of routine ... */  fn_exit:    MPID_MPI_FUNC_EXIT(MPID_STATE_MPI_QUERY_THREAD);    MPID_CS_EXIT();    return mpi_errno;      fn_fail:    /* --BEGIN ERROR HANDLING-- */#   ifdef HAVE_ERROR_CHECKING    {	mpi_errno = MPIR_Err_create_code(	    mpi_errno, MPIR_ERR_RECOVERABLE, FCNAME, __LINE__, MPI_ERR_OTHER, "**mpi_query_thread",	    "**mpi_query_thread %p", provided);    }#   endif    mpi_errno = MPIR_Err_return_comm(NULL, FCNAME, mpi_errno);    goto fn_exit;    /* --END ERROR HANDLING-- */}

⌨️ 快捷键说明

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