Casting float* to char* while looping over a 2-D array in linear memory on device

后端 未结 3 1799
慢半拍i
慢半拍i 2021-01-14 03:46

On Page 21 of the CUDA 4.0 programming guide there is an example (given below) to illustrate looping over the elements of a 2D array of floats in device memory. The dimensi

相关标签:
3条回答
  • 2021-01-14 04:26

    *(devPtr + 1) will offset the pointer by 4 bytes (sizeof(float)) before the * dereferences it. *((char)devPtr + 1) will offset the pointer by 1 byte (sizeof(char)) before the * dereferences it..

    0 讨论(0)
  • 2021-01-14 04:30

    This is due to the way pointer arithmetic works in C. When you add an integer x to a pointer p, it doesn't always add x bytes. It adds x times sizeof([type that p points to]).

    float* row = (float*)((char*)devPtr + r * pitch);
    

    By casting devPtr to a char*, the offset that is applied (r * pitch*) is in number of 1-byte increments. (because a char is one byte). Had the cast not been there, the offset applied to devPtr would be r * pitch times 4 bytes, as a float is four bytes.

    For example, if we have:

    float* devPtr = 1000;
    int r = 4;
    

    Now, let's leave out the cast:

    float* result1 = (devPtr + r);
    // result1 = devPtr + (r * sizeof(float)) = 1016;
    

    Now, if we include the cast:

    float* result2 = (float*)((char*)devPtr + r);
    // result2 = devPtr + (r * sizeof(char)) = 1004;
    
    0 讨论(0)
  • 2021-01-14 04:35

    The cast is just to make the pointer arithmetic work right;

    (float*)((char*)devPtr + r * pitch);
    

    moves r*pitch bytes forward while

    (float*)(devPtr + r * pitch);
    

    would move r*pitch floats forward (ie 4 times as many bytes)

    0 讨论(0)
提交回复
热议问题