blob: ba1f9f40ea365233a1228164f2a12c397d4e0dd3 [file] [log] [blame] [edit]
/*
* Copyright © 2016 Red Hat.
* Copyright © 2016 Bas Nieuwenhuizen
*
* based in part on anv driver which is:
* Copyright © 2015 Intel Corporation
*
* SPDX-License-Identifier: MIT
*/
#ifndef RADV_INSTANCE_H
#define RADV_INSTANCE_H
#include "util/simple_mtx.h"
#include "util/xmlconfig.h"
#include "radv_radeon_winsys.h"
#include "vk_instance.h"
#ifdef ANDROID_STRICT
#define RADV_API_VERSION VK_MAKE_VERSION(1, 1, VK_HEADER_VERSION)
#else
#define RADV_API_VERSION VK_MAKE_VERSION(1, 4, VK_HEADER_VERSION)
#define RADV_API_VERSION_1_3 VK_MAKE_VERSION(1, 3, VK_HEADER_VERSION)
#endif
enum radv_trace_mode {
/** Radeon GPU Profiler */
RADV_TRACE_MODE_RGP = 1 << VK_TRACE_MODE_COUNT,
/** Radeon Raytracing Analyzer */
RADV_TRACE_MODE_RRA = 1 << (VK_TRACE_MODE_COUNT + 1),
/** Gather context rolls of submitted command buffers */
RADV_TRACE_MODE_CTX_ROLLS = 1 << (VK_TRACE_MODE_COUNT + 2),
};
struct radv_drirc {
struct driOptionCache options;
struct driOptionCache available_options;
struct {
bool disable_aniso_single_level;
bool disable_dcc;
bool disable_dcc_mips;
bool disable_dcc_stores;
bool disable_depth_storage;
bool disable_shrink_image_store;
bool disable_sinking_load_input_fs;
bool disable_tc_compat_htile_in_general;
bool disable_trunc_coord;
bool enable_mrt_output_nan_fixup;
bool flush_before_query_copy;
bool flush_before_timestamp_write;
bool invariant_geom;
bool lower_terminate_to_discard;
bool no_dynamic_bounds;
bool split_fma;
bool ssbo_non_uniform;
bool tex_non_uniform;
bool zero_vram;
bool wait_for_vm_map_updates;
bool no_implicit_varying_subgroup_size;
bool rt_wave64;
bool hide_rebar_on_dgpu;
char *app_layer;
int override_uniform_offset_alignment;
} debug;
struct {
bool disable_ngg_gs;
bool enable_unified_heap_on_apu;
bool report_llvm9_version_string;
bool prefer_2d_swizzle_for_3d_storage;
char *gfx12_hiz_wa;
} performance;
struct {
bool cooperative_matrix2_nv;
bool emulate_rt;
bool expose_float16_gfx8;
bool vk_require_astc;
bool vk_require_etc2;
} features;
struct {
bool clear_lds;
int override_vram_size;
uint8_t override_compute_shader_version;
uint8_t override_graphics_shader_version;
uint8_t override_ray_tracing_shader_version;
} misc;
};
struct radv_instance {
struct vk_instance vk;
VkAllocationCallbacks alloc;
simple_mtx_t shader_dump_mtx;
uint64_t debug_flags;
uint64_t perftest_flags;
uint64_t trap_excp_flags;
enum radeon_ctx_pstate profile_pstate;
struct radv_drirc drirc;
FILE *pso_history_logfile;
};
VK_DEFINE_HANDLE_CASTS(radv_instance, vk.base, VkInstance, VK_OBJECT_TYPE_INSTANCE)
const char *radv_get_debug_option_name(int id);
const char *radv_get_perftest_option_name(int id);
bool radv_is_rt_wave64_enabled(const struct radv_instance *instance);
#endif /* RADV_INSTANCE_H */