Compartilhar via


Função MPI_Win_allocate

Cria um objeto Janela de MPI que aloca memória.

Sintaxe

int MPIAPI MPI_Win_allocate(
        MPI_Aint size,
        int      disp_unit,
        MPI_Info info,
        MPI_Comm comm,
  _Out_ void     *baseptr,
  _Out_ MPI_Win  *win
);

Parâmetros

  • size
    Tamanho da janela de memória em bytes.

  • disp_unit
    Tamanho da unidade local para deslocamentos, em bytes.

  • info
    Argumento de informações.

  • comm
    Communicator.

  • baseptr [out]
    Endereço inicial da janela de memória.

  • win [out]
    Objeto Window retornado pela chamada.

Retornar valor

Retorna MPI_SUCCESS em caso de êxito. Caso contrário, o valor retornado será um código de erro.

Em Fortran, o valor retornado é armazenado no parâmetro IERROR .

Fortran

    MPI_WIN_ALLOCATE(SIZE, DISP_UNIT, INFO, COMM, BASEPTR, WIN, IERROR)
        <type> BASEPTR(*)
        INTEGER(KIND=MPI_ADDRESS_KIND) SIZE
        INTEGER DISP_UNIT, INFO, COMM, WIN, IERROR

Comentários

Essa é uma chamada coletiva executada por todos os processos no grupo de comm. Em cada processo, ele aloca memória de pelo menos bytes de tamanho , retorna um ponteiro para ele e retorna um objeto de janela que pode ser usado por todos os processos em comm para executar operações RMA. A memória retornada consiste em bytes de tamanho local para cada processo, começando no endereço baseptr e está associado à janela como se o usuário chamado MPI_Win_create na memória existente. O argumento size pode ser diferente em cada processo e o tamanho = 0 é válido; no entanto, uma biblioteca pode alocar e expor mais memória para criar uma alocação rápida e globalmente simétrica.

Requisitos

Produto

Pacote Redistribuível do HPC Pack 2012 MS-MPI, Pacote Redistribuível HPC Pack 2008 R2 MS-MPI, Pacote Redistribuível do HPC Pack 2008 MS-MPI ou Utilitários de Cliente HPC Pack 2008

parâmetro

Mpi.h; Mpif.h

Biblioteca

Msmpi.lib

DLL

Msmpi.dll

Confira também

Funções de comunicação de One-Sided MPI