Software Archive
Read-only legacy content
Announcements
FPGA community forums and blogs have moved to the Altera Community. Existing Intel Community members can sign in with their current credentials.
17060 Discussions

Segfault when offload function and data into xeon phi (SIGSEGV)

Mohammed_Al_Farhan
596 Views

Hi,

I have a code running on the CPU and I offload a function, which is being called several times inside a nested loop, into Intel Xeon Phi to be accelerated. In addition to get good performance out of the offloading, Further, I allocated the main data structures out of the offloading section by transferring them to Xeon phi and allocating them once and then at the end of the loop (after the offloading section) I deallocate them, so that I would save time by avoiding copying the data back and forth into the accelerator memory since these data are not being modified inside the offloaded function. However, I am still having bad performance and I realized that this performance comes from the implicit transmission of the data when the offloaded function begins. Therefore, I specified inside the offload paragma of the offloaded function that these data should not be copied into Intel Xeon Phi memory by (nocopy) clause, but I got segmentation fault error (offload error: process on the device 1 was terminated by signal 11 (SIGSEGV)). So the conclusion is that Xeon phi needs to copy the data each and every time I offload the function into the coprocessor although these data do not get changed during the calculations inside the offloaded function.

Could anyone please help out of this issue?

BTW, the code is written in both C and Fortran, and the first offload transfer and allocation of the data structures happens in the C code and then later the Fortran code do the calculation by the offloaded function (which is written in Fortran).

Thanks very much.

Best

0 Kudos
1 Solution
Kevin_D_Intel
Employee
596 Views

From the description and the error is seems like an instance of the pointer is what's needed to be transferred/created. Instead of NOCOPY it probably requires using IN with length(0) and alloc_if(1) free_if(0) initially to create memory for the pointer only.

If you have not already done so, review the discussions/examples related to Local Pointers Versus Pointers Used Across Offloads and specifically the Example of Persistent MIC Pointer and Selective Data Transfer on the Effective Use of the Intel Compiler's Offload Features.

View solution in original post

0 Kudos
1 Reply
Kevin_D_Intel
Employee
597 Views

From the description and the error is seems like an instance of the pointer is what's needed to be transferred/created. Instead of NOCOPY it probably requires using IN with length(0) and alloc_if(1) free_if(0) initially to create memory for the pointer only.

If you have not already done so, review the discussions/examples related to Local Pointers Versus Pointers Used Across Offloads and specifically the Example of Persistent MIC Pointer and Selective Data Transfer on the Effective Use of the Intel Compiler's Offload Features.

0 Kudos
Reply