web-dev-qa-db-ja.com

C:信号コード:アドレスがマップされていません(1)mpirecv

次のコードをMPIを使用してCで記述しています。

#include <mpi.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
    int size, rank;
    MPI_Status status;
    int buf[1000];

    MPI_Init(&argc, &argv);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);

    if (rank == 0) {
        int i = 0;

        while (i != 1000) {
            buf[i] = i;
            i++;
        }

        MPI_Send(buf, 999, MPI_INT, 1, 1, MPI_COMM_WORLD);
        printf("msg has been sent\n");
    }

    if (rank == 1) {
        int sz = sizeof(buf);
        int lst = buf[sz-1];

        MPI_Recv(buf, 999, MPI_INT, 0, 1, MPI_COMM_WORLD, &status);
        printf("la taille du buf %d et dernier %d", sz, lst);
    }

    MPI_Finalize();
}

そしてそれを実行した後、それはこのメッセージを与えます:

msg has been sente
[blitzkrieg-TravelMate-P253:03395] *** Process received signal ***
[blitzkrieg-TravelMate-P253:03395] Signal: Segmentation fault (11)
[blitzkrieg-TravelMate-P253:03395] Signal code: Address not mapped (1)
[blitzkrieg-TravelMate-P253:03395] Failing at address: 0xbfee8574
[blitzkrieg-TravelMate-P253:03395] [0] [0xb772d40c]
[blitzkrieg-TravelMate-P253:03395] [1] mpii(main+0x12f) [0x8048883]
[blitzkrieg-TravelMate-P253:03395] [2] /lib/i386-linux-gnu/libc.so.6(__libc_start_main+0xf3) [0xb74c84d3]
[blitzkrieg-TravelMate-P253:03395] [3] mpii() [0x80486c1]
[blitzkrieg-TravelMate-P253:03395] *** End of error message ***

mpirunは、ノードblitzkriegでプロセスランク1、PID3395に気づきました-

TravelMate-P253はシグナル11(セグメンテーション違反)で終了しました。

どんな提案もthnxを助けます。

7
Tato Tia

スタックトレースは、質問のタイトルが示すように、エラーが_MPI_Recv_にないことを示しています。エラーは実際にはここにあります:

_int sz = sizeof(buf);
int lst = buf[sz-1]; // <---- here
_

bufintの配列であり、sizeof(buf)はそのサイズをバイト単位で返すため、szは配列内の要素数の4倍に設定されます。 _buf[sz-1]_へのアクセスは、bufの境界をはるかに超えて、プロセスのスタックの上のマップされていないメモリ領域に入ります。

配列の合計サイズをその要素の1つのサイズで割る必要があります。最初の1つ:

_int sz = sizeof(buf) / sizeof(buf[0]);
int lst = buf[sz-1];
_
10
Hristo Iliev