Opened 15 years ago
Closed 13 years ago
#4779 closed bug (fixed)
Resolution not properly reset after returning from fullscreen mode
Reported by: | scottmc | Owned by: | pulkomandy |
---|---|---|---|
Priority: | normal | Milestone: | R1 |
Component: | Servers/app_server | Version: | R1/Development |
Keywords: | Cc: | mdisreali@… | |
Blocked By: | Blocking: | ||
Platform: | All |
Description
When running some tests using libsdl I've seen some cases where I start in 1600x1200 mode and then run the test which goes to full screen and when it ends dumps me into 1024x768 mode. After returning from fullscreen mode the system will sometimes then crash into gdb and lock up.
Attachments (4)
Change History (23)
comment:1 by , 15 years ago
Component: | - General → System |
---|
comment:2 by , 15 years ago
Component: | System → Servers/app_server |
---|---|
Owner: | changed from | to
comment:3 by , 15 years ago
Updated libsdl can now be found here: http://ports-space.haiku-files.org/media-libs/
comment:4 by , 15 years ago
Cc: | added |
---|---|
Version: | R1/alpha1 → R1/Development |
Experiencing this when I try to run Quake3 on hrev37440-4h. Using the most recent sdl libs as of 2010-06-11. Screen goes from 1024x768 to 640x480. I have to use Cmd+Fn to get to another workspace and then re-run Screen to reset my resolutions.
comment:5 by , 15 years ago
try running it from the command line and then attach the output you get in the terminal from start to finish
by , 15 years ago
Attachment: | quake3-gcc2_r37440-4h_blackscreen_then_exit.txt added |
---|
by , 15 years ago
Attachment: | quake3-gcc4_r37440-4h_blankscreen_then_exit.txt added |
---|
comment:7 by , 14 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
This seems to be related to sdl and/or the gamekit? Perhaps pulkomandy and GSoC student Nathan can look into it? This may or may not have been fixed with our sdl port changes made in late 2010.
comment:8 by , 13 years ago
It's likely a bug in SDL, which saves the current video mode at start and tries to restore it at exit. The restoring may not always work. Also, it looks like it doesn't always fail.
comment:9 by , 13 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
This appears to be fixed now. If anyone still sees this happening, please provide details on how to reproduce the issue.
comment:10 by , 13 years ago
Well I saw it happen by running the fire demo above just yesterday. Not sure this qualifies as fixed ?
comment:11 by , 13 years ago
Which haiku version were you using? Which version of sdl were you using?
I tested using the fire demo as well, it goes to 640x480 while it's running and when it ends it went back to the previously set resolution, which in my case was 1600x1200. I tested on hrev42458 gcc2hybrid, with the libsdl-1.2-hg build. Before when I'd run this test it would switch to 1024x768, instead of the resolution I was running prior to running the demo.
comment:12 by , 13 years ago
This is hrev42532, not sure about the SDL version; how do I check ?
sdl-config --version 1.2.14
comment:13 by , 13 years ago
Resolution: | fixed |
---|---|
Status: | closed → reopened |
I just checked with the libsdl-1.3-gsoc WIP build and built the fire demo and it is showing the resizing issue still, so re-opening for now.
Note, this is what I used for building the fire demo, unzip the source and then run:
gcc -o fire fire.c -g -O2 -I/boot/common/include/SDL -DHAVE_OPENGL -L/boot/common/lib -lSDL -lGL -lroot -lbe -lmedia -lgame -ldevice -ltextencoding
comment:14 by , 13 years ago
FWIW I tested "fire" on hrev40260 (from January), and it restores the resolution after being quit. However, it doesn't manage to restore it 100%, ie. the app_server will now switch the resolution (to the same, but obviously with different timings/flags/whatever) when switching workspaces which is quite a bit annoying.
comment:15 by , 13 years ago
axeld: this may be a known bug in intel_extreme, where it will not compare modes when setting. So, switching workspace trigger a mode change that should be intercpted as a no-op in the driver, but isn't. There's a todo somewhere in the code about it.
comment:16 by , 13 years ago
The test system indeed has an intel_extreme chipset, but I don't find it entirely convincing, as the app_server doesn't usually do that on a workspace switch. At the very least, that shouldn't be the only problem there is.
comment:17 by , 13 years ago
I don't think it's just intel_extreme as I was seeing this happen in VMware where the display adapter shows up at VGA compatible controller vendor 15ad: VMware, device 0405 SVGA II Adapter
comment:18 by , 13 years ago
I tried the latest build of SDL1.2 at haiku ports, and this one doesn't have the bug.
I'm wondering what Nathan based his port on, I'm not sure if he used plain SDL1.2 sources or the ones with patches we had not upstreamed yet. This means some bugs may be back in the 1.3 port now...
comment:19 by , 13 years ago
Resolution: | → fixed |
---|---|
Status: | reopened → closed |
Not an Haiku bug anyway. Move to SDL bugtracker if needed.
You can get the latest build of libsdl for Haiku here: http://www.haiku-ports.de/packages/media-libs/libsdl/