The rendering process of graphics rendering pipeline is usually completed by both the CPU and the GPU, and a bottleneck can be located either in the CPU or the GPU. This paper focuses on reducing the bottleneck between the CPU and the GPU. We are proposing a method for improving the performance of parallel processing for realtime graphics rendering by separating the CPU operations into two parts: pure CPU operations and operations related to the GPU, and let them operate in parallel. This allows for maximizing the parallelism in processing the communication between the CPU and the GPU. Some experiments lead us to confirm that our method proposed in this paper can allow for faster graphics rendering. In addition to our method of using a dedicated thread for GPU related operations, we are also proposing an algorithm for balancing the graphics pipeline using the idle time due to the bottleneck. We have implemented the two methods proposed in this paper in our networked 3D game engine and verified that our methods are effective in real systems.
[1]
John Rohlf,et al.
IRIS performer: a high performance multiprocessing toolkit for real-time 3D graphics
,
1994,
SIGGRAPH.
[2]
Tomas Akenine-Möller,et al.
Real-time rendering, 2nd Edition
,
2002
.
[3]
Tomas Akenine-Möller,et al.
Real-time rendering
,
1997
.
[4]
Tomas Akenine-Möller,et al.
Real-Time Rendering, Second Edition
,
2002
.
[5]
Michael Wimmer,et al.
Rendering Time Estimation for Real-Time Rendering
,
2003,
Rendering Techniques.