Elimina el kernel Metal O(N²) de boids en GPU que causava GPU timeout a macOS amb >50K boles, arrossegant WindowServer fins al crash. - Elimina gpu_boid_buffer.hpp/cpp (GpuBoidBuffer, BallComputeData, BoidParams) - Elimina kBoidComputeMSL i kBallComputeVertMSL de gpu_pipeline - Elimina boid_compute_pipeline_ i ball_compute_pipeline_ - Elimina use_gpu_boids_, boid_params_, ball_screen_uniforms_ de Engine - Elimina syncAndExitGpuBoids() i tot el compute dispatch de render() - Mode BOIDS ara usa sempre boid_manager_ (CPU, spatial hash O(N)) i renderitza via gpu_ball_buffer_ instanced (mateix path que PHYSICS) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
55 lines
2.7 KiB
C++
55 lines
2.7 KiB
C++
#pragma once
|
|
|
|
#include <SDL3/SDL_gpu.h>
|
|
|
|
// ============================================================================
|
|
// PostFXUniforms — pushed to the fragment stage each frame via
|
|
// SDL_PushGPUFragmentUniformData(pass, 0, &uniforms, sizeof(PostFXUniforms))
|
|
// MSL binding: constant PostFXUniforms& u [[buffer(0)]]
|
|
// ============================================================================
|
|
struct PostFXUniforms {
|
|
float vignette_strength; // 0 = none, 1.5 = default subtle
|
|
float chroma_strength; // 0 = off, 1 = full chromatic aberration
|
|
float scanline_strength; // 0 = off, 1 = full scanlines
|
|
float time; // accumulated seconds (for future animations)
|
|
};
|
|
|
|
// ============================================================================
|
|
// GpuPipeline — Creates and owns the graphics pipelines used by the engine.
|
|
//
|
|
// sprite_pipeline_ : textured quads, alpha blending.
|
|
// Vertex layout: GpuVertex (pos float2, uv float2, col float4).
|
|
// ball_pipeline_ : instanced ball rendering, alpha blending.
|
|
// Vertex layout: BallGPUData as per-instance data (input_rate=INSTANCE).
|
|
// 6 procedural vertices per instance (no index buffer).
|
|
// postfx_pipeline_ : full-screen triangle, no vertex buffer, no blend.
|
|
// Reads offscreen texture, writes to swapchain.
|
|
// Accepts PostFXUniforms via fragment uniform buffer slot 0.
|
|
// ============================================================================
|
|
class GpuPipeline {
|
|
public:
|
|
// target_format: pass SDL_GetGPUSwapchainTextureFormat() result.
|
|
// offscreen_format: format of the offscreen render target.
|
|
bool init(SDL_GPUDevice* device,
|
|
SDL_GPUTextureFormat target_format,
|
|
SDL_GPUTextureFormat offscreen_format);
|
|
void destroy(SDL_GPUDevice* device);
|
|
|
|
SDL_GPUGraphicsPipeline* spritePipeline() const { return sprite_pipeline_; }
|
|
SDL_GPUGraphicsPipeline* ballPipeline() const { return ball_pipeline_; }
|
|
SDL_GPUGraphicsPipeline* postfxPipeline() const { return postfx_pipeline_; }
|
|
|
|
private:
|
|
SDL_GPUShader* createShader(SDL_GPUDevice* device,
|
|
const char* msl_source,
|
|
const char* entrypoint,
|
|
SDL_GPUShaderStage stage,
|
|
Uint32 num_samplers,
|
|
Uint32 num_uniform_buffers,
|
|
Uint32 num_storage_buffers = 0);
|
|
|
|
SDL_GPUGraphicsPipeline* sprite_pipeline_ = nullptr;
|
|
SDL_GPUGraphicsPipeline* ball_pipeline_ = nullptr;
|
|
SDL_GPUGraphicsPipeline* postfx_pipeline_ = nullptr;
|
|
};
|