Notifications
Clear all

prusaslicer using wrong graphics driver  

  RSS
jared
(@jared-4)
Member
prusaslicer using wrong graphics driver

i am using prusaslicer 2.9.2 in a virtual machine. this has been working file for a few years, until i recently upgraded the display protocol and graphics driver. now, for some reason, prusaslicer is using cpu display, and the performance is abysmal. just trying to rotate the model goes down to about 2 seconds per frame. and i don't mean to frames per second, just to be clear. i attached a system info below. as you can see, for some reason it's using display vendor of vmware instead of nvidia. the vm has a discreet nvidia gpu passed to it, which is working fine for literally every other app on the system. how can one fix this. copying the opengl32.ddl file into the main installation folder doesn't help either. using the portable version doesn't either. the problem persists when using the gcode viewer. 

 

PrusaSlicer
Version:   2.9.2
Build:     PrusaSlicer-2.9.2

Operating System:    Windows
System Architecture: 64 bit
Windows Version:     Windows 11 (build 22631), 64-bit edition
Total RAM size [MB]: 34,353MB
OpenGL installation
GL version:   3.3.0 (3.3 (Core Profile) Mesa 12.0.0-rc2)
Profile:      Core
Vendor:       VMware, Inc.
Renderer:     Gallium 0.4 on llvmpipe (LLVM 3.6, 256 bits)
GLSL version: 3.30.0
Textures compression:       Disabled
Mutisampling: Disabled
<details>
<summary>Installed extensions:</summary>
GL_AMD_conservative_depth
GL_AMD_draw_buffers_blend
GL_AMD_seamless_cubemap_per_texture
GL_AMD_shader_stencil_export
GL_AMD_shader_trinary_minmax
GL_AMD_vertex_shader_layer
GL_AMD_vertex_shader_viewport_index
GL_ARB_ES2_compatibility
GL_ARB_ES3_compatibility
GL_ARB_arrays_of_arrays
GL_ARB_base_instance
GL_ARB_blend_func_extended
GL_ARB_buffer_storage
GL_ARB_clear_buffer_object
GL_ARB_clip_control
GL_ARB_compressed_texture_pixel_storage
GL_ARB_conditional_render_inverted
GL_ARB_conservative_depth
GL_ARB_copy_buffer
GL_ARB_cull_distance
GL_ARB_debug_output
GL_ARB_depth_buffer_float
GL_ARB_depth_clamp
GL_ARB_direct_state_access
GL_ARB_draw_buffers
GL_ARB_draw_buffers_blend
GL_ARB_draw_elements_base_vertex
GL_ARB_draw_indirect
GL_ARB_draw_instanced
GL_ARB_explicit_attrib_location
GL_ARB_explicit_uniform_location
GL_ARB_fragment_coord_conventions
GL_ARB_fragment_layer_viewport
GL_ARB_fragment_shader
GL_ARB_framebuffer_object
GL_ARB_framebuffer_sRGB
GL_ARB_get_program_binary
GL_ARB_get_texture_sub_image
GL_ARB_gpu_shader_fp64
GL_ARB_half_float_pixel
GL_ARB_half_float_vertex
GL_ARB_instanced_arrays
GL_ARB_internalformat_query
GL_ARB_internalformat_query2
GL_ARB_invalidate_subdata
GL_ARB_map_buffer_alignment
GL_ARB_map_buffer_range
GL_ARB_multi_bind
GL_ARB_multi_draw_indirect
GL_ARB_occlusion_query2
GL_ARB_pixel_buffer_object
GL_ARB_point_sprite
GL_ARB_program_interface_query
GL_ARB_provoking_vertex
GL_ARB_robustness
GL_ARB_sampler_objects
GL_ARB_seamless_cube_map
GL_ARB_seamless_cubemap_per_texture
GL_ARB_separate_shader_objects
GL_ARB_shader_bit_encoding
GL_ARB_shader_objects
GL_ARB_shader_stencil_export
GL_ARB_shader_subroutine
GL_ARB_shader_texture_lod
GL_ARB_shading_language_420pack
GL_ARB_shading_language_packing
GL_ARB_stencil_texturing
GL_ARB_sync
GL_ARB_texture_buffer_object
GL_ARB_texture_buffer_object_rgb32
GL_ARB_texture_buffer_range
GL_ARB_texture_compression_rgtc
GL_ARB_texture_cube_map_array
GL_ARB_texture_float
GL_ARB_texture_gather
GL_ARB_texture_mirror_clamp_to_edge
GL_ARB_texture_multisample
GL_ARB_texture_non_power_of_two
GL_ARB_texture_query_levels
GL_ARB_texture_rectangle
GL_ARB_texture_rg
GL_ARB_texture_rgb10_a2ui
GL_ARB_texture_stencil8
GL_ARB_texture_storage
GL_ARB_texture_storage_multisample
GL_ARB_texture_swizzle
GL_ARB_texture_view
GL_ARB_timer_query
GL_ARB_transform_feedback2
GL_ARB_transform_feedback3
GL_ARB_transform_feedback_instanced
GL_ARB_uniform_buffer_object
GL_ARB_vertex_array_bgra
GL_ARB_vertex_array_object
GL_ARB_vertex_attrib_64bit
GL_ARB_vertex_attrib_binding
GL_ARB_vertex_shader
GL_ARB_vertex_type_10f_11f_11f_rev
GL_ARB_vertex_type_2_10_10_10_rev
GL_ARB_viewport_array
GL_ATI_blend_equation_separate
GL_ATI_texture_float
GL_ATI_texture_mirror_once
GL_EXT_abgr
GL_EXT_blend_equation_separate
GL_EXT_draw_buffers2
GL_EXT_draw_instanced
GL_EXT_framebuffer_blit
GL_EXT_framebuffer_multisample
GL_EXT_framebuffer_multisample_blit_scaled
GL_EXT_framebuffer_sRGB
GL_EXT_packed_depth_stencil
GL_EXT_packed_float
GL_EXT_pixel_buffer_object
GL_EXT_polygon_offset_clamp
GL_EXT_provoking_vertex
GL_EXT_shader_integer_mix
GL_EXT_texture_array
GL_EXT_texture_compression_rgtc
GL_EXT_texture_integer
GL_EXT_texture_mirror_clamp
GL_EXT_texture_sRGB
GL_EXT_texture_sRGB_decode
GL_EXT_texture_shared_exponent
GL_EXT_texture_snorm
GL_EXT_texture_swizzle
GL_EXT_timer_query
GL_EXT_transform_feedback
GL_EXT_vertex_array_bgra
GL_IBM_multimode_draw_arrays
GL_KHR_context_flush_control
GL_KHR_debug
GL_MESA_pack_invert
GL_MESA_texture_signed_rgba
GL_MESA_ycbcr_texture
GL_NV_conditional_render
GL_NV_depth_clamp
GL_NV_packed_depth_stencil
GL_OES_EGL_image
GL_OES_read_format
</details>
Posted : 22/08/2025 1:16 am
Laura F Farrell
(@laura-f-farrell)
Estimable Member
RE: prusaslicer using wrong graphics driver

I used to be a VMware specialist, two times VCP certified and 6 years spent working on virtual environments mostly VMware - admittedly its more than a decade now though, but the way virtualisation works is that it passes a virtual software driver to the OS not the raw hardware driver, so its correct that your graphics driver shows up as VMware and not NVidia, as VMware is handling the hardware in the hypervisor. It is technically possible to pass "direct hardware access" to VMware for some hardware, but its generally not recommended (usually because in a vSphere environment theoretically that hardware is probably physically connected to a single ESX host, so if the virtual machine fails over to another ESX server, that physical box doesn't have the hardware - usually in a server environment we'd be talking about something like a USB dongle that was being used to run a hardware based license key, that sort of thing). I presume the hypervisor for Workstation is not dissimilar than the bare metal model used for enterprise.

You might get some help here though, you should be able to optimise 3d settings for particular types of hardware vendors.

https://techdocs.broadcom.com/us/en/vmware-cis/desktop-hypervisors/workstation-pro/17-0/using-vmware-workstation-pro/configuring-and-managing-virtual-machines/configure-display-settings-for-a-virtual-machine/prepare-the-host-system-to-use-accelerated-3d-graphics.html#GUID-EA588485-718A-4FD8-81F5-B6E1F04C5788-en

Posted : 18/09/2025 4:44 pm
1 people liked
jared
(@jared-4)
Member
Topic starter answered:
RE: prusaslicer using wrong graphics driver

in this case, the hardware IS passed directly to the vm, and in so doing forfeiting migration possibility. oddly, it worked on the previous version of horizon, so somehow prusa is not grabbing the correct driver this time around....

Posted : 18/09/2025 4:48 pm
Tim
 Tim
(@tim-21)
Member
RE: prusaslicer using wrong graphics driver

Perhaps the later nvidia drivers aren't supporting opengl like they once did? So passing the hardware doesn't really matter to whatever Prusa sees or expects. There have even been cases of nvidia borking the opengl versions in driver releases.  No clue if any of this affects your use case, so just throwing it out there as places to look.

Posted : 18/09/2025 6:10 pm
Laura F Farrell
(@laura-f-farrell)
Estimable Member
RE: prusaslicer using wrong graphics driver

VMware have pretty much dropped the Workstation product as a commercial proposition and now give it away for free (It used to be 125 euro or something like that, not sure as they used to give you a free license with the VCP exam pass) so its hardly a priority product for development and I doubt the support is going to be much.

Posted : 23/09/2025 3:53 pm
Share: