pipeline up

This commit is contained in:
Brett Weiland 2024-05-09 19:14:29 -05:00
parent 51a8923eb3
commit 7e9e215061
5 changed files with 45 additions and 24 deletions

BIN
build/indigo_worlds Executable file

Binary file not shown.

BIN
build/kernel.o Normal file

Binary file not shown.

Binary file not shown.

View File

@ -5,14 +5,14 @@
__global__ void test_image(uint8_t *image) {
int2 unnormalized_coordinates = make_int2(blockDim.x, blockDim.y) * make_int2(blockIdx.x, blockIdx.y) + make_int2(threadIdx.x, threadIdx.y);
int2 img_res = make_int2(blockDim.x, blockDim.y) * make_int2(gridDim.x, gridDim.y);
size_t img_index = (unnormalized_coordinates.y * img_res.y) + unnormalized_coordinates.x;
//uint8_t pixel_val = (img_index / (img_res.x * img_res.y)) * 255;
uint8_t pixel_val = 0xff;
//if(img_index == 1) printf("%i\n", img_index);
print(img_index)
image[img_index] = 0xff;
image[img_index+1] = pixel_val;
image[img_index+2] = pixel_val;
int2 img_res = make_int2(blockDim.x, blockDim.y) * make_int2(gridDim.x, gridDim.y); //can move if needed
size_t img_index = ((unnormalized_coordinates.y * img_res.y) + unnormalized_coordinates.x) * 4;
//vec3 col = 0.5 + 0.5*cos(iTime+uv.xyx+vec3(0,2,4));
image[img_index] = 0x00;
image[img_index+1] = 0x00;
image[img_index+2] = 0xff;
image[img_index+3] = 0xff;
}

51
main.cu
View File

@ -8,32 +8,53 @@
__global__ void test_image(uint8_t *image);
int main() {
const int size_x = 100;
const int size_y = 100;
//bluuuuugh i'll figure out occupancy later, this res are easy
//calculated manually for gtx1060 with 20 SM, 1024 threads/SM
const int res_x = 32 * 20;
const int res_y = 32 * 20;
const dim3 blockCount(20, 20);
const dim3 threadCount(32, 32);
uint8_t *image_d;
Image image = GenImageColor(size_x, size_y, BLUE);
Color texture_data[res_x * res_y];
//see if GPU is connected (my egpu is finicky)
{
int temp_device;
cudaError_t err;
if((err = cudaGetDevice(&temp_device)) != cudaSuccess) {
printf("failed to get device!\nError: %s\n", cudaGetErrorString(err));
return(1);
}
}
SetTraceLogLevel(LOG_ERROR);
InitWindow(res_x, res_y, "cuda teseteroni");
//TODO could probably cut out
Image image = GenImageColor(res_x, res_y, BLUE);
Texture tex = LoadTextureFromImage(image);
InitWindow(size_x, size_y, "cuda teseteroni");
cudaMalloc((void **)&image_d, 100 * 100 * 4);
test_image<<<1, dim3(3,3)>>>(image_d);
cudaDeviceSynchronize();
//for(;;);
//if(!IsWindowFullscreen()) ToggleFullscreen();
while(!WindowShouldClose()) {
cudaMemcpy(image.data, (void **)image_d, 100 * 100 * 4, cudaMemcpyDeviceToHost);
//memset(image.data, (int32_t)0x0000ff, 100 * 100 * 4);
//cuda stuff
cudaMalloc((void **)&image_d, res_x * res_y * sizeof(Color));
test_image<<<blockCount, threadCount>>>(image_d);
cudaDeviceSynchronize();
cudaMemcpy(texture_data, (void **)image_d, res_x * res_y * sizeof(Color), cudaMemcpyDeviceToHost);
BeginDrawing();
DrawTexture(LoadTextureFromImage(image), 0, 0, WHITE);
UpdateTexture(tex, texture_data);
DrawTexture(tex, 0, 0, WHITE);
DrawFPS(0, 0);
EndDrawing();
}
return 0;
}