Bug 5097 - Menu corrupted on start
Status: RESOLVED WONTFIX
Alias: None
Product: ioquake3
Classification: Unclassified
Component: Video
Version: GIT MASTER
Hardware: SGI IRIX
: P3 minor
Assignee: Zachary J. Slater
QA Contact: ioquake3 bugzilla mailing list
URL:
Depends on:
Blocks:
 
Reported: 2011-07-24 11:36 EDT by ioquake
Modified: 2013-10-09 18:45:10 EDT
3 users (show)

See Also:


Attachments
Initialize depth buffer on startup. (679 bytes, patch)
2011-07-24 11:36 EDT, ioquake
SetViewportAndScissor() after qglClear() (687 bytes, patch)
2011-07-27 16:23 EDT, ioquake
GL_SetDefaultState (668 bytes, patch)
2012-07-15 17:12 EDT, ioquake

Description ioquake 2011-07-24 11:36:10 EDT
Created attachment 2862 [details]
Initialize depth buffer on startup.

The menu and loading screen are (randomly) corrupted on IRIX until a game is started. The corruption only affects (some random parts of) the (black) background areas, where the mouse cursor sometimes leaves trails. The corrupted areas may flicker terribly, possibly showing some parts of the id logo video shown before.
This is reported e.g. here:
http://forums.nekochan.net/viewtopic.php?f=15&t=12556&view=unread#p133490

It turns out that the depth buffer is not properly initialized.The enclosed patch initializes the depth buffer of both front and back buffers to 1.0, however it would probably be better to perform this when clearing the screen to show the menu.
Comment 1 Thilo Schulz 2011-07-26 20:19:48 EDT
This is strange. Have a look at RB_BeginDrawingView() in tr_backend.c
It clears the depth buffer there, after qglClearDepth( 1.0f ); in GL_SetDefaultState() from tr_init.c

I feel uncomfortable with this patch. This code doesn't seem to belong where it is right now.
Comment 2 ioquake 2011-07-27 16:19:52 EDT
You're of course correct that RB_BeginDrawingView() is a much more suitable place to clear the depth buffer, however, the way it's set up now, It only clears the top part with the Quake III Arena logo. If one moves the SetViewportAndScissor(); after the qglClear(), the entire screen's depth buffer is cleared and no corruption occurs.
Comment 3 ioquake 2011-07-27 16:23:55 EDT
Created attachment 2864 [details]
SetViewportAndScissor() after qglClear()
Comment 4 Thilo Schulz 2011-07-29 07:43:22 EDT
excellent! fixed r2103
Comment 5 Thilo Schulz 2012-05-04 12:00:28 EDT
this patch has a huge impact on performance on nvidia graphics cards. im afraid i have to revert it.
Comment 6 ioquake 2012-05-04 14:52:04 EDT
Do you have any other ideas how/where this bug could be fixed more selectively, i.e. just for the black area in the main menu?
Comment 7 Thilo Schulz 2012-07-01 11:10:51 EDT
(In reply to comment #6)
> Do you have any other ideas how/where this bug could be fixed more selectively,
> i.e. just for the black area in the main menu?

How about the function: GL_SetDefaultState()?

I would go with your first version of the patch then, just that it's added in GL_SetDefaultState() function inside the renderer.

Would that be okay?
Comment 8 ioquake 2012-07-01 16:38:59 EDT
GL_SetDefaultState() sounds like it's worth a try. It will take me about a week before I can actually test this.
Comment 9 ioquake 2012-07-15 17:12:29 EDT
Created attachment 3251 [details]
GL_SetDefaultState

Attempt to clear all buffers in GL_SetDefaultState()
Comment 10 ioquake 2012-07-15 17:14:08 EDT
The patch I've just uploaded fixes the corruption of menus and cutscenes on the Irix system I've tested it on.
Comment 12 Zack Middleton 2013-10-07 10:25:45 EDT
Calling glClear( any bits ) in GL_SetDefaultState makes connect screen black using the proprietary NVidia driver on Windows and GNU/Linux.

Reported here: http://www.ioquake.org/forums/viewtopic.php?f=15&t=1906
Comment 13 Zack Middleton 2013-10-08 09:03:20 EDT
Reverted patch in commit e4227d1cd59f3a6877e1f18dc4c500fe499dc199.
Comment 14 ioquake 2013-10-08 14:51:52 EDT
A screenshot of e4227d1cd59f3a6877e1f18dc4c500fe499dc199 showing the remains of the intro video, a few left behind mouse pointers and some noise is at http://canavan.de/ioquake_irix_menu_corrupted.jpg
Comment 15 Zachary J. Slater 2013-10-08 16:35:39 EDT
No.
Comment 16 Tim Angus 2013-10-09 05:03:38 EDT
(In reply to comment #14)
> A screenshot of e4227d1cd59f3a6877e1f18dc4c500fe499dc199 showing the remains
> of the intro video, a few left behind mouse pointers and some noise is at
> http://canavan.de/ioquake_irix_menu_corrupted.jpg

Are you sure that the glClear calls are necessary? It smells to me like some state is not set properly when the background is cleared. My advice is to look into what (if anything) is drawing the background and figure out why it's not taking effect in your case. Like I say my guess would be that there is some GL state that's wrong at that point.

Adding code to actually do drawing to GL_SetDefaultState is probably the wrong way to fix it.
Comment 17 ioquake 2013-10-09 16:10:10 EDT
It's quite possible that glClear() calls are uneccesary. A single call before drawing the Menu may be sufficient, however I'm not ver well versed in either OpenGL or ioquake. 

If anyone with sufficient knowledge in both of those is interested in helping out, I may be able to provide ssh and VNC access to a computer that's not terribly slow.
Comment 18 Zachary J. Slater 2013-10-09 18:45:10 EDT
Please do not reopen this issue. I do not believe it makes sense for ioquake3 to  continue supporting irix. If you would like to continue discussing this feel free to email me directly zachary@ioquake.org

I recommend that you fork ioquake3 on GitHub for continued irix support and issue tracking:

https://help.github.com/articles/fork-a-repo