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

📄 ad_pfs_fcntl.c

📁 mpi并行计算的c++代码 可用vc或gcc编译通过 可以用来搭建并行计算试验环境
💻 C
字号:
/* -*- Mode: C; c-basic-offset:4 ; -*- *//*  * *   Copyright (C) 1997 University of Chicago.  *   See COPYRIGHT notice in top-level directory. */#include "ad_pfs.h"#include "adio_extern.h"void ADIOI_PFS_Fcntl(ADIO_File fd, int flag, ADIO_Fcntl_t *fcntl_struct,		     int *error_code){    int i, err;    int iomod, np_total, np_comm;    static char myname[] = "ADIOI_PFS_FCNTL";    switch(flag) {    case ADIO_FCNTL_GET_FSIZE:	if (!(fd->atomicity)) {          /* in M_ASYNC mode, all processes are not aware of changes              in file size (although the manual says otherwise). Therefore,              temporarily change to M_UNIX and then change              back to M_ASYNC.*/ 	    MPI_Comm_size(MPI_COMM_WORLD, &np_total);	    MPI_Comm_size(fd->comm, &np_comm);	    if (np_total == np_comm) {		err = _setiomode(fd->fd_sys, M_UNIX);		err = _setiomode(fd->fd_sys, M_ASYNC);	    }            /* else it is M_UNIX anyway, so no problem */	}	fcntl_struct->fsize = lseek(fd->fd_sys, 0, SEEK_END);	if (fd->fp_sys_posn != -1) 	    lseek(fd->fd_sys, fd->fp_sys_posn, SEEK_SET);	*error_code = MPI_SUCCESS;	break;    case ADIO_FCNTL_SET_DISKSPACE:	err = _lsize(fd->fd_sys, fcntl_struct->diskspace, SEEK_SET);	if (err == -1) {	    *error_code = MPIO_Err_create_code(MPI_SUCCESS,					       MPIR_ERR_RECOVERABLE, myname,					       __LINE__, MPI_ERR_IO, "**io",					       "**io %s", strerror(errno));	}	else *error_code = MPI_SUCCESS;	break;    case ADIO_FCNTL_SET_ATOMICITY:	MPI_Comm_size(MPI_COMM_WORLD, &np_total);	MPI_Comm_size(fd->comm, &np_comm);	if (np_total == np_comm) {	    iomod = (fcntl_struct->atomicity == 0) ? M_ASYNC : M_UNIX;	    err = _setiomode(fd->fd_sys, iomod);	}        /* else can't do anything because setiomode is global. but           the file will have been opened with M_UNIX anyway, because           gopen is also global. */	fd->atomicity = (fcntl_struct->atomicity == 0) ? 0 : 1;	if (err == -1) {	    /* --BEGIN ERROR HANDLING-- */	    *error_code = MPIO_Err_create_code(MPI_SUCCESS,					       MPIR_ERR_RECOVERABLE, myname,					       __LINE__, MPI_ERR_IO, "**io",					       "**io %s", strerror(errno));	    /* --END ERROR HANDLING-- */	}	else *error_code = MPI_SUCCESS;	break;    default:	/* --BEGIN ERROR HANDLING-- */	*error_code = MPIO_Err_create_code(MPI_SUCCESS, MPI_ERR_RECOVERABLE,					   myname, __LINE__, MPI_ERR_ARG,					   "**flag", "**flag %d", flag);	return;	/* --END ERROR HANDLING-- */    }}

⌨️ 快捷键说明

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