xash3d-fwgs/ref/vk/shaders/ray_interop.h
Ivan 'provod' Avdeev 59e8a8c4c3 rt: only overshoot additive for glow mode
Add another flag to kusochki for glow geometry.
Move flags to a new kusok.flags field.

Fixes #231 (or at least makes it not stand out too much)
2023-02-28 17:50:50 -08:00

166 lines
3.6 KiB
C

// Common definitions for both shaders and native code
#ifndef RAY_INTEROP_H_INCLUDED
#define RAY_INTEROP_H_INCLUDED
#define LIST_SPECIALIZATION_CONSTANTS(X) \
X(0, uint, MAX_POINT_LIGHTS, 256) \
X(1, uint, MAX_EMISSIVE_KUSOCHKI, 256) \
X(2, uint, MAX_VISIBLE_POINT_LIGHTS, 63) \
X(3, uint, MAX_VISIBLE_SURFACE_LIGHTS, 255) \
X(4, float, LIGHT_GRID_CELL_SIZE, 128.) \
X(5, uint, MAX_LIGHT_CLUSTERS, 262144) \
X(6, uint, MAX_TEXTURES, 4096) \
X(7, uint, SBT_RECORD_SIZE, 32) \
#ifndef GLSL
#include "xash3d_types.h"
#include "vk_const.h"
#define MAX_EMISSIVE_KUSOCHKI 256
#define uint uint32_t
#define vec2 vec2_t
#define vec3 vec3_t
#define vec4 vec4_t
#define mat4 matrix4x4
typedef int ivec3[3];
#define TOKENPASTE(x, y) x ## y
#define TOKENPASTE2(x, y) TOKENPASTE(x, y)
#define PAD(x) float TOKENPASTE2(pad_, __LINE__)[x];
#define STRUCT struct
enum {
#define DECLARE_SPECIALIZATION_CONSTANT(index, type, name, default_value) \
SPEC_##name##_INDEX = index,
LIST_SPECIALIZATION_CONSTANTS(DECLARE_SPECIALIZATION_CONSTANT)
#undef DECLARE_SPECIALIZATION_CONSTANT
};
#else // if GLSL else
#extension GL_EXT_shader_8bit_storage : require
#define PAD(x)
#define STRUCT
#define DECLARE_SPECIALIZATION_CONSTANT(index, type, name, default_value) \
layout (constant_id = index) const type name = default_value;
LIST_SPECIALIZATION_CONSTANTS(DECLARE_SPECIALIZATION_CONSTANT)
#undef DECLARE_SPECIALIZATION_CONSTANT
#endif // not GLSL
#define GEOMETRY_BIT_OPAQUE 0x01
#define GEOMETRY_BIT_ALPHA_TEST 0x02
#define GEOMETRY_BIT_ADDITIVE 0x04
#define GEOMETRY_BIT_REFRACTIVE 0x08
#define SHADER_OFFSET_MISS_REGULAR 0
#define SHADER_OFFSET_MISS_SHADOW 1
#define SHADER_OFFSET_MISS_EMPTY 2
#define SHADER_OFFSET_HIT_REGULAR 0
#define SHADER_OFFSET_HIT_ALPHA_TEST 1
#define SHADER_OFFSET_HIT_ADDITIVE 2
#define SHADER_OFFSET_HIT_REGULAR_BASE 0
#define SHADER_OFFSET_HIT_SHADOW_BASE 3
#define KUSOK_MATERIAL_FLAG_SKYBOX (1<<0)
#define KUSOK_MATERIAL_FLAG_FIXME_GLOW (1<<1)
struct Kusok {
uint index_offset;
uint vertex_offset;
uint triangles;
// Material
uint tex_base_color;
// TODO the color is per-model, not per-kusok
vec4 color;
vec3 emissive;
uint tex_roughness;
vec2 uv_speed; // for conveyors; TODO this can definitely be done in software more efficiently (there only a handful of these per map)
uint tex_metalness;
uint tex_normalmap;
float roughness;
float metalness;
uint flags;
PAD(1)
mat4 prev_transform;
};
struct PointLight {
vec4 origin_r;
vec4 color_stopdot;
vec4 dir_stopdot2;
uint environment; // Is directional-only environment light
PAD(3)
};
struct PolygonLight {
vec4 plane;
vec3 center;
float area;
vec3 emissive;
uint vertices_count_offset;
};
struct LightsMetadata {
uint num_polygons;
uint num_point_lights;
PAD(2)
ivec3 grid_min_cell;
PAD(1)
ivec3 grid_size;
PAD(1)
STRUCT PointLight point_lights[MAX_POINT_LIGHTS];
STRUCT PolygonLight polygons[MAX_EMISSIVE_KUSOCHKI];
vec4 polygon_vertices[MAX_EMISSIVE_KUSOCHKI * 7]; // vec3 but aligned
};
struct LightCluster {
uint8_t num_point_lights;
uint8_t num_polygons;
uint8_t point_lights[MAX_VISIBLE_POINT_LIGHTS];
uint8_t polygons[MAX_VISIBLE_SURFACE_LIGHTS];
};
#define PUSH_FLAG_LIGHTMAP_ONLY 0x01
struct PushConstants {
float time;
uint random_seed;
int bounces;
float prev_frame_blend_factor;
float pixel_cone_spread_angle;
uint debug_light_index_begin, debug_light_index_end;
uint flags;
};
struct UniformBuffer {
mat4 inv_proj, inv_view;
mat4 prev_inv_proj, prev_inv_view;
float ray_cone_width;
uint random_seed;
PAD(2)
};
#undef PAD
#undef STRUCT
#ifndef GLSL
#undef uint
#undef vec3
#undef vec4
#undef TOKENPASTE
#undef TOKENPASTE2
#endif
#endif // RAY_INTEROP_H_INCLUDED