2012-02-27 18 views
14

ATI RV770 grafik kartı, OpenCl 1.0 ve linux üzerinde ati-stream-sdk-v2.3-lnx64 kullanıyorum.hata kodu (-11) :: OpenCL'de "cl_build_program_failure" hatası almanın olası nedenleri nelerdir?

Çekirdek programı oluşturmak için aşağıdaki iki bölümü içeren ana bilgisayar kodumu çalıştırırken hata kodu (-11) yani cl_build_program_failure alıyorum. Çekirdek programın derlendiği anlamına gelir, eğer değilse nasıl derlenir ve ayıklanır?

const char* KernelPath = "abc_kernel.cl"; //kernel program is in separate file but in same directory of host code.. 

/* çekirdek kaynağından Programı nesne oluşturun * ** * ** */

char* sProgramSource = readKernelSource(KernelPath); 
size_t sourceSize = strlen(sProgramSource) ; 
program = clCreateProgramWithSource(context, 1,(const char **) &sProgramSource,&sourceSize, &err); 
checkStatus("error while creating program",err); 

/* Yapı (derlemeşöyle ::

/* okuma programı kaynak dosyası */

Bağlantısı) Programı * ** * *** çekirdek programını okumak için/

char* options = (char*)malloc(10*sizeof(char)); 
strcpy(options, "-g"); 
err = clBuildProgram(program, num_devices, devices_id, options, NULL, NULL); 
checkStatus("Build Program Failed", err); //This line throwing the error.... 

fonksiyonudur

char* readKernelSource(const char* kernelSourcePath){ 
FILE *fp = NULL; 
size_t sourceLength; 
char *sourceString ; 
fp = fopen(kernelSourcePath , "r"); 
if(fp == 0) 
{ 
     printf("failed to open file"); 
     return NULL; 
} 
// get the length of the source code 
fseek(fp, 0, SEEK_END); 
sourceLength = ftell(fp); 
rewind(fp); 
// allocate a buffer for the source code string and read it in 
sourceString = (char *)malloc(sourceLength + 1); 
if(fread(sourceString, 1, sourceLength, fp) !=sourceLength) 
{ 
      printf("\n\t Error : Fail to read file "); 
      return 0; 
} 
sourceString[sourceLength+1]='\0'; 
fclose(fp); 
return sourceString; 

} // read of the EndKernelSource

Herkes bunu nasıl düzelteceğini söyleyebilir mi?

Bu, çalışma zamanında veya başka bir şeyde OpenCl derleme hatası olduğu anlamına mı geliyor?

// Aşağıdaki gibi clGetProgramBuildInfo() kullanarak build_log bilgisi yazdırma, Ama neden bir şey yazdırmıyor?

char * build_log; size_t log_size;

// First call to know the proper size 
     err = clGetProgramBuildInfo(program, devices_id, CL_PROGRAM_BUILD_LOG, 0, NULL, &log_size); 
     build_log = (char*)malloc((log_size+1)); 

     // Second call to get the log 
     err = clGetProgramBuildInfo(program, devices_id, CL_PROGRAM_BUILD_LOG, log_size, build_log, NULL); 
     build_log[log_size] = '\0'; 
     printf("--- Build log ---\n "); 
     fprintf(stderr, "%s\n", build_log); 
     free(build_log); 
+0

Çekirdek kaynağını bir tür üçüncü taraf aracına mı yapıştırdınız? Bir profiler belki? Hata oluşturduğumda, genellikle programın kendisinde sözdizimi olurlar. – mfa

cevap

30

Bu hata genellikle, çekirdek kodunuzdaki bir sözdizimi hatası nedeniyle oluşur. Derleyici tarafından oluşturulan günlüğe erişmek için clGetProgramBuildInfo OpenCL işlevini CL_PROGRAM_BUILD_LOG işaretiyle arayabilirsiniz. Bu günlük, komut satırında derleme yaparken kullandığınız çıktıyı içerir (hatalar, uyarılar, vb.). Eğer clBuildProgram çağırdıktan sonra

Örneğin, aşağıdakine benzer bir şey ekleyebilirsiniz:

if (err == CL_BUILD_PROGRAM_FAILURE) { 
    // Determine the size of the log 
    size_t log_size; 
    clGetProgramBuildInfo(program, devices_id[0], CL_PROGRAM_BUILD_LOG, 0, NULL, &log_size); 

    // Allocate memory for the log 
    char *log = (char *) malloc(log_size); 

    // Get the log 
    clGetProgramBuildInfo(program, devices_id[0], CL_PROGRAM_BUILD_LOG, log_size, log, NULL); 

    // Print the log 
    printf("%s\n", log); 
} 

Ayrıca gerçek örneğin AMD APP SDK içinde SDKCommon.cpp işlevi buildOpenCLProgram() görebilirsiniz.

+0

Yukarıda gösterildiği gibi build_log bilgilerini yazdırmak için aynısını yaptım. Ama ben bir şey yazdırıyor, ben bile build_log için depolama oluşturmak için malloc() kullandım. – Gopal

+0

Sanırım "bu, ** bir şey yazdırmamak" anlamına mı geliyor? Printf'in gerçekten çağrıldığını doğrulayabilir misiniz? Dizenin ilk sonlandırıldığından emin olmak için önce günlüğü başlatmanız gerekebilir. "Memset (log, 0, log_size)" yazmayı deneyin. " malloc çağrısından sonra. –

+0

"memset ((void *) build_log, 0, sizeof (build_log)); ama bu satırda segmentasyon hatası veriyor ... – Gopal

İlgili konular