Page 1 of 1

Moving the Graphics Card Base Addres instead of buffering

Posted: Thu Mar 17, 2016 8:13 pm
by ~
How common and how possible would the following be in a standard way?
I have been thinking that drawing in a screen could be done extremely fast if the base address of the graphics card (the BAR) could be moved to arbitrary regions of memory at runtime instead of relying on double/multiple buffering.

In this way, we could implement a high level stack of buffer pointers, and also a heap of such buffers.

Then, we could start pushing just the address of certain screen-sized buffer and pass it as a parameter for a drawing function.

When we finish drawing, we could, instead of copying the secondary buffer to the screen's frame buffer, just pop it directly into the PCI Base Address Register (BAR) and thus updating the current screen immediately?

If the hardware supported it, we could also move, free up and even page the frame buffer region and probably use it for other purposes (for example when the screen is turned off or when there's a long time away from the computer).

Re: Moving the Graphics Card Base Addres instead of bufferin

Posted: Thu Mar 17, 2016 8:55 pm
by neon
Most modern video devices support page flipping which can be used to alternate between multiple buffers without the need to copy data. I am not aware of any standard protocol (not even firmware interfaces) that provides these facilities though. In other words, you may need to write custom drivers for these devices. Copying the back buffer is slower but more portable.

Re: Moving the Graphics Card Base Addres instead of bufferin

Posted: Thu Mar 17, 2016 11:08 pm
by FallenAvatar
Seeing as hardware sees physical memory (and not paged/linear/whats the other one called?) this is already "easy" to do.

- Monk

Re: Moving the Graphics Card Base Addres instead of bufferin

Posted: Thu Mar 17, 2016 11:13 pm
by ~
tjmonk15 wrote:Seeing as hardware sees physical memory (and not paged/linear/whats the other one called?) this is already "easy" to do.

- Monk
Segmented?

Re: Moving the Graphics Card Base Addres instead of bufferin

Posted: Fri Mar 18, 2016 12:13 am
by alexfru
neon wrote:Most modern video devices support page flipping which can be used to alternate between multiple buffers without the need to copy data. I am not aware of any standard protocol (not even firmware interfaces) that provides these facilities though. In other words, you may need to write custom drivers for these devices. Copying the back buffer is slower but more portable.
VESA VBE. If you have enough video memory, you can make a virtual screen larger than the physical screen and organize scrolling or flipping by setting the address of the beginning of the visible portion and drawing in the invisible.

Re: Moving the Graphics Card Base Addres instead of bufferin

Posted: Fri Mar 18, 2016 12:25 am
by Octocontrabass
~ wrote:instead of copying the secondary buffer to the screen's frame buffer, just pop it directly into the PCI Base Address Register (BAR) and thus updating the current screen immediately?
The video card's frame buffer is located in the video card's RAM, not in main RAM. Changing the BAR only changes where the video card's RAM is located in the CPU address space; it does not cause the video card to use main RAM as the frame buffer.

(Integrated graphics controllers that use main RAM as the video card's RAM may support these kinds of shenanigans, but it won't be as simple as messing with the PCI configuration.)