Advertisement

force opengl to use software rendering

Started by December 19, 2024 03:25 AM
15 comments, last by Geri 1 week, 3 days ago

@dpadam450 Well, i'm actually comparing between different implementations of software rasterizer, mainly focus on their performance and compatibility.

I know it's pretty weired to do that in 2024(soon to be 2025) , but you know there're quite a few people who ask for a relatively high performance while unwilling to buy a GPU :(

Of course i can't use shaders when it comes with the software rasterize, but it's not a big problem right now.

Anyway, i'm just curious about why opengl doesn't provide some functions that allow me to enumerate the devices on the computer. DirectX has DXGI to do that , and vulkan also has APIs to query devices. Maybe the guys who design OpenGL think it's not the graphics API's responsbility to do that……..

Lemonade101 said:
Of course i can't use shaders when it comes with the software rasterize, but it's not a big problem right now.

Sure you can! There have been plenty of software rasterizers that work with shaders, and work with various OGL features.

What you can't do is use the very old Opengl32.dll drivers supporting OGL 1.1 while still expecting them to automatically make OGL 4.6 calls. If you only include libraries for OGL 1.1, you're limited to March 1997 functionality.

IIRC even under 1.1 there was still the ability to query all the function pointers by name through glGetProcAddress(glFunctionName) or on Windows specifically with the Win32 API function GetProcAddress(). So even if you did link against a 1.1 library but somehow the underlying drivers supported all the library functions and you had code the followed the calling conventions and knew the constants, you could still request the pointers to the full modern feature set that the drivers support. It's basically the same way extensions have always worked, asking for a pointer to a function if it exists and then using it. The ‘man-in-the-middle’ OpenGL context doesn't need to directly implement the function, all it needs to do is provide whatever interfaces are asked about to connect the two sides. If you happen to use a newer library like OGL 1.5 or OGL 2.1 or 3.3 or 4.2, or the current 4.6, the core functions are automatically bound for you but I believe they are all still accessible through their address via function name lookup.

The Mesa implementation has an intermediate layer that processes shaders just fine, running them through an intermediate layer on various systems, although the docs say they've only got about 80% support if you are in software-only rasterizing, with only some of the more exotic, rarely used functions not implemented. They've got enough to pass their validation suite that pulls from many hundred games and tools.

Lemonade101 said:
i'm just curious about why opengl doesn't provide some functions that allow me to enumerate the devices on the computer.

Because of its design. OpenGL works through graphics contexts that are portable and cross-platform. Platform-specific commands and functionality are outside the GL.

Part of that is why for decades OGL was as portable as it was, working on Windows, Linux, Mac, game consoles like PlayStation (although they mangled some of it through PSGL), through feature phones and smart phones and tablets. OGL doesn't care about the operating system or software systems, if the graphics are done by hardware or software. As the spec describes, they provide a abstract "state machine that controls a set of drawing operations.", and it is up to the the programmers and the GL implementors to implement whatever they need on their respective sides of that state machine.

It is designed to be portable, and accomplishes it quite well. Graphics systems through the eras of computing shifted back in the 1990s. Before then it was quite common to have terminals that were different from the machines running the software. It still is in the Unix world, but less common in the Windows world. The generic state machine model didn't need to be on any particular machine or have any particular implementation

The graphical display you see in front of you isn't necessarily where the program is running. As a simple example, you may have a program running on a supercomputer in the lab, but you want to display the graphics on your local machine. This is handled by several graphical systems, including the X Window System used by Linux, by having the graphical server get abstracted away. Your graphical display would be your desktop machine, and the graphical calls made by the program might be happening on the hardware right in front of you, or might be happening remotely. It is left up to the person who owns the system to decide.

For an OpenGL program, it' s about the window system that owns the context. If you've got an older SLI configuration with two graphics cards, if the window context is on one card then that's where OpenGL will do the work. If you're on a remote display like running an X terminal across a network, then the computer running the program can be in the lab while your graphical display and OpenGL context is on your local machine.

You can get information about the context like the context's OpenGL version, the vender string, the renderer name, and shader version.

Your program can create multiple OpenGL contexts, and since each could theoretically be associated with different rendering hardware they can have different OpenGL objects like shaders and buffer objects.

OpenGL doesn't technically exist until after you've created the context. That's part of the OpenGL Spec. You create that in a platform-specific way, which could be a Windows call, an X11 call, and Android system call, a PlayStation graphics subsystem call, whatever. As a result, it isn't OpenGL that is enumerating devices on the system, that's not part of the cross-platform library. Instead, you use whatever libraries are provided on your system (like wglCreateContext() on Windows) with parameters appropriate for whatever system you're on to create your graphics context. Only after that call succeeds does OpenGL actually ‘exist’ as far as the spec is concerned. On Windows if you need to tie it to a specific device that's a platform-specific command, bind it to \\.\DISPLAY1 with a HDC, and pass the HDC to wglCreateContext(), which will then create the OpenGL context targeting DISPLAY1.

Advertisement

Lemonade101 said:
but you know there're quite a few people who ask for a relatively high performance while unwilling to buy a GPU :(

The what? Who'd actually do that? Who buys a PC, but not a GPU? A 50$ GPU is going to give better performance for graphics rendering than a 700$ CPU with a software renderer. Somebody who buys a PC for 400$ won't see any good performance in any scenario, ever, so I really don't know who you think those people are, but I'm 100% certain they either don't exist, or are just the “karen” type wo'd complain about anything, in all situations no matter what you do.

More-ever, you need some type of GPU to get graphics output to the monitor, so that' makes this scenario pretty much impossible. And yes, any integrated Intel -2000HD is also giving better performance than s software rasterizer. So that' making me belive even more that what you are doing is unnecessary. Use software rasterizer to determine if some weird bug is due to driver issues, otherwise use a normal GPU based hardware renderer. If somebody tells you they want to run your app without a GPU, tell them to go easy on the shrooms and message you when they stopped tripping.

“but you know there're quite a few people who ask for a relatively high performance while unwilling to buy a GPU :(”
“Who buys a PC, but not a GPU?”

You can't even buy a computer/laptop without a GPU embedded. Every cellphone has a GPU. Makes no sense. I'm working on a piece of software on my own to release here soon. Some people ask if I could port it to Linux or Mac and I simply say, no, I don't have the time to do so. What you are doing is a waste and should be rejected as a feature.

NBA2K, Madden, Maneater, Killing Floor, Sims

Agreed that the concept generally is very flawed, it's quite difficult these days to not have any hardware support, but someone intentionally trying to create the situation could force it through contrived circumstances. They're not playing a game under those circumstances, but they could contrive a method for a software renderer.

The biggest significant reason in my mind is offline rendering, in a chosen environment where the offline rendering machines don't have accessible graphics processing. Maybe they're a bunch of virtual machines on the cloud and they're trying to render all the frames of a video for later playback. On AWS it's simple enough to get computer instances with a “G” or “P” prefix that have graphics cards, but here we would have to allow that for whatever reason they choose to not get the actual hardware and instead emulate that hardware because costs are different. They could be sharing the environment with someone else, or maybe have done cost comparisons, but for whatever reason use plain compute instances using Mesa with a software rasterizer to render the frames with zero graphics hardware acceleration.

It's not a game feature, but software rendering still has an increasingly-rare place.

Lemonade101 said:

I'm trying to write an opengl program that need to use pure software rendering for some test reasons.

But i just can't find a common way to force opengl using CPU only even if it's running on the platform that equipped with a GPU.

manually set compatibility profile or set the version of opengl into an older version (like 1.4) seems not work.

So is there any “official” or “recommended” way to achieve that (better if it's cross-platform)? Or any platform specified solutions?

You can use TitaniumGL ( http://users.atw.hu/titaniumgl/gamerdown.html ) it has a software-rendering only version in the package. Its opengl 1.4. The hardware accelerated version is also OpenGL 1.4.

Advertisement