двойное освобождение или коррупция (выход) - C ++ - PullRequest
0 голосов
/ 05 октября 2018

Я пытаюсь реализовать параллельное сокращение, используя Min, Max, Sum и Average в CUDA.

Это мой основной фрагмент кода на данный момент.

int main()
{
    const auto count = 8;
    const int size = count * sizeof(int);
    int h[] = {13, 27, 15, 14, 33, 2, 24, 6};

    int* d;
    int choice = 0;
    do{
        cout <<"\n ---MENU--- \n";
        cout <<"1. Find Sum of Numbers in Array\n";
        cout <<"2. Find Max of Array\n";
        cout <<"3. Find Min of Array\n";
        cout <<"4. Find Average of Array\n";
        cout <<"5. Exit\n";
        cout <<"Enter your Choice : ";
        cin >> choice;
        switch(choice){
            case 1:
                cudaMalloc(&d, size);
                cudaMemcpy(d, h, size, cudaMemcpyHostToDevice);

                sum <<<1, count / 2 >>>(d);

                int result;
                cudaMemcpy(&result, d, sizeof(int), cudaMemcpyDeviceToHost);

                cout << "Sum is " << result << endl;

                getchar();

                cudaFree(d);
                delete[] h;
                break;
            case 5:
                break;
            default:
                cout<<"Wrong Input!! Try Again!";
                break;
        }
    }while(choice != 5);
return 0;
}

Это моя CUDAЯдро для SUM:

__global__ void sum(int* input)
{
    const int tid = threadIdx.x;
    auto step_size = 1;
    int number_of_threads = blockDim.x;

    while (number_of_threads > 0)
    {
        if (tid < number_of_threads) // still alive?
        {
            const auto fst = tid * step_size * 2;
            const auto snd = fst + step_size;
            input[fst] += input[snd];
        }

        step_size <<= 1; 
        number_of_threads >>= 1;
    }
}

При запуске программы, я получаю это как ВЫХОД:

enter image description here

Как решитьЭта проблема?Пожалуйста, помогите мне.

1 Ответ

0 голосов
/ 05 октября 2018

Не игнорируйте предупреждения компилятора.Вы вызываете delete[] для нединамически размещенного массива.Это неопределенное поведение и, вероятно, причина вашего дампа ядра.

Вам не нужно вызывать delete[] для массивов в стеке.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...