From 90be460e052b4ff7216be802d0ba63ebaebf4ffe Mon Sep 17 00:00:00 2001 From: Qiang Yu Date: Tue, 7 Jan 2025 16:47:44 +0800 Subject: [PATCH] crocus: remove crocus_get_param and crocus_get_shader_paramf MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Reviewed-by: Marek Olšák Part-of: --- src/gallium/drivers/crocus/crocus_screen.c | 309 --------------------- 1 file changed, 309 deletions(-) diff --git a/src/gallium/drivers/crocus/crocus_screen.c b/src/gallium/drivers/crocus/crocus_screen.c index 07ba70ffeb9..49c6e1eb78b 100644 --- a/src/gallium/drivers/crocus/crocus_screen.c +++ b/src/gallium/drivers/crocus/crocus_screen.c @@ -134,313 +134,6 @@ get_aperture_size(int fd) return aperture.aper_size; } -static int -crocus_get_param(struct pipe_screen *pscreen, enum pipe_cap param) -{ - struct crocus_screen *screen = (struct crocus_screen *)pscreen; - const struct intel_device_info *devinfo = &screen->devinfo; - - switch (param) { - case PIPE_CAP_NPOT_TEXTURES: - case PIPE_CAP_ANISOTROPIC_FILTER: - case PIPE_CAP_OCCLUSION_QUERY: - case PIPE_CAP_TEXTURE_SWIZZLE: - case PIPE_CAP_TEXTURE_MIRROR_CLAMP_TO_EDGE: - case PIPE_CAP_BLEND_EQUATION_SEPARATE: - case PIPE_CAP_FRAGMENT_SHADER_TEXTURE_LOD: - case PIPE_CAP_FRAGMENT_SHADER_DERIVATIVES: - case PIPE_CAP_PRIMITIVE_RESTART: - case PIPE_CAP_PRIMITIVE_RESTART_FIXED_INDEX: - case PIPE_CAP_INDEP_BLEND_ENABLE: - case PIPE_CAP_FS_COORD_ORIGIN_UPPER_LEFT: - case PIPE_CAP_FS_COORD_PIXEL_CENTER_INTEGER: - case PIPE_CAP_DEPTH_CLIP_DISABLE: - case PIPE_CAP_VS_INSTANCEID: - case PIPE_CAP_VERTEX_ELEMENT_INSTANCE_DIVISOR: - case PIPE_CAP_SEAMLESS_CUBE_MAP: - case PIPE_CAP_SEAMLESS_CUBE_MAP_PER_TEXTURE: - case PIPE_CAP_CONDITIONAL_RENDER: - case PIPE_CAP_TEXTURE_BARRIER: - case PIPE_CAP_VERTEX_COLOR_UNCLAMPED: - case PIPE_CAP_START_INSTANCE: - case PIPE_CAP_FORCE_PERSAMPLE_INTERP: - case PIPE_CAP_MIXED_FRAMEBUFFER_SIZES: - case PIPE_CAP_VS_LAYER_VIEWPORT: - case PIPE_CAP_TES_LAYER_VIEWPORT: - case PIPE_CAP_ACCELERATED: - case PIPE_CAP_UMA: - case PIPE_CAP_CLIP_HALFZ: - case PIPE_CAP_TGSI_TEXCOORD: - case PIPE_CAP_DEVICE_RESET_STATUS_QUERY: - case PIPE_CAP_COPY_BETWEEN_COMPRESSED_AND_PLAIN_FORMATS: - case PIPE_CAP_SIGNED_VERTEX_BUFFER_OFFSET: - case PIPE_CAP_TEXTURE_FLOAT_LINEAR: - case PIPE_CAP_TEXTURE_HALF_FLOAT_LINEAR: - case PIPE_CAP_POLYGON_OFFSET_CLAMP: - case PIPE_CAP_TGSI_TEX_TXF_LZ: - case PIPE_CAP_MULTISAMPLE_Z_RESOLVE: - case PIPE_CAP_SHADER_GROUP_VOTE: - case PIPE_CAP_VS_WINDOW_SPACE_POSITION: - case PIPE_CAP_TEXTURE_GATHER_SM5: - case PIPE_CAP_SHADER_ARRAY_COMPONENTS: - case PIPE_CAP_GLSL_TESS_LEVELS_AS_INPUTS: - case PIPE_CAP_FS_POSITION_IS_SYSVAL: - case PIPE_CAP_FS_FACE_IS_INTEGER_SYSVAL: - case PIPE_CAP_INVALIDATE_BUFFER: - case PIPE_CAP_SURFACE_REINTERPRET_BLOCKS: - case PIPE_CAP_FENCE_SIGNAL: - case PIPE_CAP_DEMOTE_TO_HELPER_INVOCATION: - case PIPE_CAP_GL_CLAMP: - case PIPE_CAP_LEGACY_MATH_RULES: - case PIPE_CAP_NATIVE_FENCE_FD: - return true; - case PIPE_CAP_INT64: - case PIPE_CAP_SHADER_BALLOT: - case PIPE_CAP_PACKED_UNIFORMS: - return devinfo->ver == 8; - case PIPE_CAP_QUADS_FOLLOW_PROVOKING_VERTEX_CONVENTION: - return devinfo->ver <= 5; - case PIPE_CAP_TEXTURE_QUERY_LOD: - case PIPE_CAP_QUERY_TIME_ELAPSED: - return devinfo->ver >= 5; - case PIPE_CAP_DRAW_INDIRECT: - case PIPE_CAP_MULTI_DRAW_INDIRECT: - case PIPE_CAP_MULTI_DRAW_INDIRECT_PARAMS: - case PIPE_CAP_FRAMEBUFFER_NO_ATTACHMENT: - case PIPE_CAP_FS_FINE_DERIVATIVE: - case PIPE_CAP_STREAM_OUTPUT_INTERLEAVE_BUFFERS: - case PIPE_CAP_SHADER_CLOCK: - case PIPE_CAP_TEXTURE_QUERY_SAMPLES: - case PIPE_CAP_COMPUTE: - case PIPE_CAP_SAMPLER_VIEW_TARGET: - case PIPE_CAP_SHADER_SAMPLES_IDENTICAL: - case PIPE_CAP_SHADER_PACK_HALF_FLOAT: - case PIPE_CAP_GL_SPIRV: - case PIPE_CAP_GL_SPIRV_VARIABLE_POINTERS: - case PIPE_CAP_COMPUTE_SHADER_DERIVATIVES: - case PIPE_CAP_DOUBLES: - case PIPE_CAP_MEMOBJ: - case PIPE_CAP_IMAGE_STORE_FORMATTED: - case PIPE_CAP_ALPHA_TO_COVERAGE_DITHER_CONTROL: - return devinfo->ver >= 7; - case PIPE_CAP_QUERY_BUFFER_OBJECT: - case PIPE_CAP_ROBUST_BUFFER_ACCESS_BEHAVIOR: - return devinfo->verx10 >= 75; - case PIPE_CAP_CULL_DISTANCE: - case PIPE_CAP_QUERY_PIPELINE_STATISTICS_SINGLE: - case PIPE_CAP_STREAM_OUTPUT_PAUSE_RESUME: - case PIPE_CAP_SAMPLE_SHADING: - case PIPE_CAP_CUBE_MAP_ARRAY: - case PIPE_CAP_QUERY_SO_OVERFLOW: - case PIPE_CAP_TEXTURE_MULTISAMPLE: - case PIPE_CAP_CONDITIONAL_RENDER_INVERTED: - case PIPE_CAP_QUERY_TIMESTAMP: - case PIPE_CAP_TEXTURE_BUFFER_OBJECTS: - case PIPE_CAP_INDEP_BLEND_FUNC: - case PIPE_CAP_TEXTURE_SHADOW_LOD: - case PIPE_CAP_LOAD_CONSTBUF: - case PIPE_CAP_DRAW_PARAMETERS: - case PIPE_CAP_CLEAR_SCISSORED: - return devinfo->ver >= 6; - case PIPE_CAP_FBFETCH: - return devinfo->verx10 >= 45 ? ELK_MAX_DRAW_BUFFERS : 0; - case PIPE_CAP_MAX_DUAL_SOURCE_RENDER_TARGETS: - /* in theory CL (965gm) can do this */ - return devinfo->verx10 >= 45 ? 1 : 0; - case PIPE_CAP_MAX_RENDER_TARGETS: - return ELK_MAX_DRAW_BUFFERS; - case PIPE_CAP_MAX_TEXTURE_2D_SIZE: - if (devinfo->ver >= 7) - return 16384; - else - return 8192; - case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS: - if (devinfo->ver >= 7) - return CROCUS_MAX_MIPLEVELS; /* 16384x16384 */ - else - return CROCUS_MAX_MIPLEVELS - 1; /* 8192x8192 */ - case PIPE_CAP_MAX_TEXTURE_3D_LEVELS: - return 12; /* 2048x2048 */ - case PIPE_CAP_MAX_STREAM_OUTPUT_BUFFERS: - return (devinfo->ver >= 6) ? 4 : 0; - case PIPE_CAP_MAX_TEXTURE_ARRAY_LAYERS: - return devinfo->ver >= 7 ? 2048 : 512; - case PIPE_CAP_MAX_STREAM_OUTPUT_SEPARATE_COMPONENTS: - return ELK_MAX_SOL_BINDINGS / CROCUS_MAX_SOL_BUFFERS; - case PIPE_CAP_MAX_STREAM_OUTPUT_INTERLEAVED_COMPONENTS: - return ELK_MAX_SOL_BINDINGS; - case PIPE_CAP_GLSL_FEATURE_LEVEL_COMPATIBILITY: - case PIPE_CAP_GLSL_FEATURE_LEVEL: { - if (devinfo->verx10 >= 75) - return 460; - else if (devinfo->ver >= 7) - return 420; - else if (devinfo->ver >= 6) - return 330; - return 140; - } - case PIPE_CAP_CLIP_PLANES: - if (devinfo->verx10 < 45) - return 6; - else - return 1; // defaults to MAX (8) - case PIPE_CAP_CONSTANT_BUFFER_OFFSET_ALIGNMENT: - /* 3DSTATE_CONSTANT_XS requires the start of UBOs to be 32B aligned */ - return 32; - case PIPE_CAP_MIN_MAP_BUFFER_ALIGNMENT: - return CROCUS_MAP_BUFFER_ALIGNMENT; - case PIPE_CAP_SHADER_BUFFER_OFFSET_ALIGNMENT: - return devinfo->ver >= 7 ? 4 : 0; - case PIPE_CAP_MAX_SHADER_BUFFER_SIZE_UINT: - return devinfo->ver >= 7 ? (1 << 27) : 0; - case PIPE_CAP_TEXTURE_BUFFER_OFFSET_ALIGNMENT: - return 16; // XXX: u_screen says 256 is the minimum value... - case PIPE_CAP_TEXTURE_TRANSFER_MODES: - return PIPE_TEXTURE_TRANSFER_BLIT; - case PIPE_CAP_MAX_TEXEL_BUFFER_ELEMENTS_UINT: - return CROCUS_MAX_TEXTURE_BUFFER_SIZE; - case PIPE_CAP_MAX_VIEWPORTS: - return devinfo->ver >= 6 ? 16 : 1; - case PIPE_CAP_MAX_GEOMETRY_OUTPUT_VERTICES: - return devinfo->ver >= 6 ? 256 : 0; - case PIPE_CAP_MAX_GEOMETRY_TOTAL_OUTPUT_COMPONENTS: - return devinfo->ver >= 6 ? 1024 : 0; - case PIPE_CAP_MAX_GS_INVOCATIONS: - return devinfo->ver >= 7 ? 32 : 1; - case PIPE_CAP_MAX_TEXTURE_GATHER_COMPONENTS: - if (devinfo->ver >= 7) - return 4; - else if (devinfo->ver == 6) - return 1; - else - return 0; - case PIPE_CAP_MIN_TEXTURE_GATHER_OFFSET: - if (devinfo->ver >= 7) - return -32; - else if (devinfo->ver == 6) - return -8; - else - return 0; - case PIPE_CAP_MAX_TEXTURE_GATHER_OFFSET: - if (devinfo->ver >= 7) - return 31; - else if (devinfo->ver == 6) - return 7; - else - return 0; - case PIPE_CAP_MAX_VERTEX_STREAMS: - return devinfo->ver >= 7 ? 4 : 1; - case PIPE_CAP_VENDOR_ID: - return 0x8086; - case PIPE_CAP_DEVICE_ID: - return screen->pci_id; - case PIPE_CAP_VIDEO_MEMORY: { - /* Once a batch uses more than 75% of the maximum mappable size, we - * assume that there's some fragmentation, and we start doing extra - * flushing, etc. That's the big cliff apps will care about. - */ - const unsigned gpu_mappable_megabytes = - (screen->aperture_threshold) / (1024 * 1024); - - const long system_memory_pages = sysconf(_SC_PHYS_PAGES); - const long system_page_size = sysconf(_SC_PAGE_SIZE); - - if (system_memory_pages <= 0 || system_page_size <= 0) - return -1; - - const uint64_t system_memory_bytes = - (uint64_t) system_memory_pages * (uint64_t) system_page_size; - - const unsigned system_memory_megabytes = - (unsigned) (system_memory_bytes / (1024 * 1024)); - - return MIN2(system_memory_megabytes, gpu_mappable_megabytes); - } - case PIPE_CAP_MAX_SHADER_PATCH_VARYINGS: - case PIPE_CAP_MAX_VARYINGS: - return (screen->devinfo.ver >= 6) ? 32 : 16; - case PIPE_CAP_RESOURCE_FROM_USER_MEMORY: - /* AMD_pinned_memory assumes the flexibility of using client memory - * for any buffer (incl. vertex buffers) which rules out the prospect - * of using snooped buffers, as using snooped buffers without - * cogniscience is likely to be detrimental to performance and require - * extensive checking in the driver for correctness, e.g. to prevent - * illegal snoop <-> snoop transfers. - */ - return devinfo->has_llc; - case PIPE_CAP_THROTTLE: - return screen->driconf.disable_throttling ? 0 : 1; - - case PIPE_CAP_CONTEXT_PRIORITY_MASK: - return PIPE_CONTEXT_PRIORITY_LOW | - PIPE_CONTEXT_PRIORITY_MEDIUM | - PIPE_CONTEXT_PRIORITY_HIGH; - - case PIPE_CAP_FRONTEND_NOOP: - return true; - // XXX: don't hardcode 00:00:02.0 PCI here - case PIPE_CAP_PCI_GROUP: - return 0; - case PIPE_CAP_PCI_BUS: - return 0; - case PIPE_CAP_PCI_DEVICE: - return 2; - case PIPE_CAP_PCI_FUNCTION: - return 0; - - case PIPE_CAP_HARDWARE_GL_SELECT: - return 0; - - case PIPE_CAP_TIMER_RESOLUTION: - return DIV_ROUND_UP(1000000000ull, devinfo->timestamp_frequency); - - default: - return u_pipe_screen_get_param_defaults(pscreen, param); - } - return 0; -} - -static float -crocus_get_paramf(struct pipe_screen *pscreen, enum pipe_capf param) -{ - struct crocus_screen *screen = (struct crocus_screen *)pscreen; - const struct intel_device_info *devinfo = &screen->devinfo; - - switch (param) { - case PIPE_CAPF_MIN_LINE_WIDTH: - case PIPE_CAPF_MIN_LINE_WIDTH_AA: - case PIPE_CAPF_MIN_POINT_SIZE: - case PIPE_CAPF_MIN_POINT_SIZE_AA: - return 1; - - case PIPE_CAPF_POINT_SIZE_GRANULARITY: - case PIPE_CAPF_LINE_WIDTH_GRANULARITY: - return 0.1; - - case PIPE_CAPF_MAX_LINE_WIDTH: - case PIPE_CAPF_MAX_LINE_WIDTH_AA: - if (devinfo->ver >= 6) - return 7.375f; - else - return 7.0f; - - case PIPE_CAPF_MAX_POINT_SIZE: - case PIPE_CAPF_MAX_POINT_SIZE_AA: - return 255.0f; - - case PIPE_CAPF_MAX_TEXTURE_ANISOTROPY: - return 16.0f; - case PIPE_CAPF_MAX_TEXTURE_LOD_BIAS: - return 15.0f; - case PIPE_CAPF_MIN_CONSERVATIVE_RASTER_DILATE: - case PIPE_CAPF_MAX_CONSERVATIVE_RASTER_DILATE: - case PIPE_CAPF_CONSERVATIVE_RASTER_DILATE_GRANULARITY: - return 0.0f; - default: - unreachable("unknown param"); - } -} - static int crocus_get_shader_param(struct pipe_screen *pscreen, enum pipe_shader_type p_stage, @@ -1020,10 +713,8 @@ crocus_screen_create(int fd, const struct pipe_screen_config *config) pscreen->get_vendor = crocus_get_vendor; pscreen->get_device_vendor = crocus_get_device_vendor; pscreen->get_screen_fd = crocus_screen_get_fd; - pscreen->get_param = crocus_get_param; pscreen->get_shader_param = crocus_get_shader_param; pscreen->get_compute_param = crocus_get_compute_param; - pscreen->get_paramf = crocus_get_paramf; pscreen->get_compiler_options = crocus_get_compiler_options; pscreen->get_device_uuid = crocus_get_device_uuid; pscreen->get_driver_uuid = crocus_get_driver_uuid;