aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llwindow/llwindowsdl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llwindow/llwindowsdl.cpp')
-rw-r--r--linden/indra/llwindow/llwindowsdl.cpp46
1 files changed, 42 insertions, 4 deletions
diff --git a/linden/indra/llwindow/llwindowsdl.cpp b/linden/indra/llwindow/llwindowsdl.cpp
index 94111e7..b38d4d1 100644
--- a/linden/indra/llwindow/llwindowsdl.cpp
+++ b/linden/indra/llwindow/llwindowsdl.cpp
@@ -47,13 +47,13 @@ extern "C" {
47} 47}
48#endif // LL_GTK 48#endif // LL_GTK
49 49
50#if LL_LINUX 50#if LL_LINUX || LL_SOLARIS
51// not necessarily available on random SDL platforms, so #if LL_LINUX 51// not necessarily available on random SDL platforms, so #if LL_LINUX
52// for execv(), waitpid(), fork() 52// for execv(), waitpid(), fork()
53# include <unistd.h> 53# include <unistd.h>
54# include <sys/types.h> 54# include <sys/types.h>
55# include <sys/wait.h> 55# include <sys/wait.h>
56#endif // LL_LINUX 56#endif // LL_LINUX || LL_SOLARIS
57 57
58extern BOOL gDebugWindowProc; 58extern BOOL gDebugWindowProc;
59 59
@@ -349,6 +349,13 @@ static int x11_detect_VRAM_kb_fp(FILE *fp, const char *prefix_str)
349 349
350static int x11_detect_VRAM_kb() 350static int x11_detect_VRAM_kb()
351{ 351{
352#if LL_SOLARIS
353#error Can this be done without an explicit architecture test, ie a test FOR xorg? Was followed by: && defined(__sparc)
354 // NOTE: there's no Xorg server on SPARC so just return 0
355 // and allow SDL to attempt to get the amount of VRAM
356 return(0);
357#else
358
352 std::string x_log_location("/var/log/"); 359 std::string x_log_location("/var/log/");
353 std::string fname; 360 std::string fname;
354 int rtn = 0; // 'could not detect' 361 int rtn = 0; // 'could not detect'
@@ -420,6 +427,7 @@ static int x11_detect_VRAM_kb()
420 } 427 }
421 } 428 }
422 return rtn; 429 return rtn;
430#endif // LL_SOLARIS
423} 431}
424#endif // LL_X11 432#endif // LL_X11
425 433
@@ -489,7 +497,24 @@ BOOL LLWindowSDL::createContext(int x, int y, int width, int height, int bits, B
489 SDL_GL_SetAttribute(SDL_GL_RED_SIZE, 8); 497 SDL_GL_SetAttribute(SDL_GL_RED_SIZE, 8);
490 SDL_GL_SetAttribute(SDL_GL_GREEN_SIZE,8); 498 SDL_GL_SetAttribute(SDL_GL_GREEN_SIZE,8);
491 SDL_GL_SetAttribute(SDL_GL_BLUE_SIZE, 8); 499 SDL_GL_SetAttribute(SDL_GL_BLUE_SIZE, 8);
500#if !LL_SOLARIS
492 SDL_GL_SetAttribute(SDL_GL_DEPTH_SIZE, (bits <= 16) ? 16 : 24); 501 SDL_GL_SetAttribute(SDL_GL_DEPTH_SIZE, (bits <= 16) ? 16 : 24);
502#else
503 // NOTE- use smaller Z-buffer to enable more graphics cards
504 // - This should not affect better GPUs and has been proven
505 // to provide 24-bit z-buffers when available.
506 //
507 // As the API states:
508 //
509 // GLX_DEPTH_SIZE Must be followed by a nonnegative
510 // minimum size specification. If this
511 // value is zero, visuals with no depth
512 // buffer are preferred. Otherwise, the
513 // largest available depth buffer of at
514 // least the minimum size is preferred.
515
516 SDL_GL_SetAttribute(SDL_GL_DEPTH_SIZE, 16);
517#endif
493 SDL_GL_SetAttribute(SDL_GL_ALPHA_SIZE, (bits <= 16) ? 1 : 8); 518 SDL_GL_SetAttribute(SDL_GL_ALPHA_SIZE, (bits <= 16) ? 1 : 8);
494 519
495 // *FIX: try to toggle vsync here? 520 // *FIX: try to toggle vsync here?
@@ -655,13 +680,26 @@ BOOL LLWindowSDL::createContext(int x, int y, int width, int height, int bits, B
655 // fixme: actually, it's REALLY important for picking that we get at 680 // fixme: actually, it's REALLY important for picking that we get at
656 // least 8 bits each of red,green,blue. Alpha we can be a bit more 681 // least 8 bits each of red,green,blue. Alpha we can be a bit more
657 // relaxed about if we have to. 682 // relaxed about if we have to.
683#if LL_SOLARIS
684#error && defined(__sparc)
685 if(colorBits < 24) //HACK: on SPARC allow 24-bit color
686#else
658 if (colorBits < 32) 687 if (colorBits < 32)
688#endif
659 { 689 {
660 close(); 690 close();
661 setupFailure( 691 setupFailure(
692#if LL_SOLARIS
693#error && defined(__sparc)
694 "Second Life requires at least 24-bit color on SPARC to run in a window.\n"
695 "Please use fbconfig to set your default color depth to 24 bits.\n"
696 "You may also need to adjust the X11 setting in SMF. To do so use\n"
697 " 'svccfg -s svc:/application/x11/x11-server setprop options/default_depth=24'\n"
698#else
662 "Second Life requires True Color (32-bit) to run in a window.\n" 699 "Second Life requires True Color (32-bit) to run in a window.\n"
663 "Please go to Control Panels -> Display -> Settings and\n" 700 "Please go to Control Panels -> Display -> Settings and\n"
664 "set the screen to 32-bit color.\n" 701 "set the screen to 32-bit color.\n"
702#endif
665 "Alternately, if you choose to run fullscreen, Second Life\n" 703 "Alternately, if you choose to run fullscreen, Second Life\n"
666 "will automatically adjust the screen each time it runs.", 704 "will automatically adjust the screen each time it runs.",
667 "Error", 705 "Error",
@@ -2657,7 +2695,7 @@ void spawn_web_browser(const char* escaped_url)
2657{ 2695{
2658 llinfos << "spawn_web_browser: " << escaped_url << llendl; 2696 llinfos << "spawn_web_browser: " << escaped_url << llendl;
2659 2697
2660#if LL_LINUX 2698#if LL_LINUX || LL_SOLARIS
2661# if LL_X11 2699# if LL_X11
2662 if (gWindowImplementation && gWindowImplementation->mSDL_Display) 2700 if (gWindowImplementation && gWindowImplementation->mSDL_Display)
2663 { 2701 {
@@ -2697,7 +2735,7 @@ void spawn_web_browser(const char* escaped_url)
2697 llwarns << "fork failure." << llendl; 2735 llwarns << "fork failure." << llendl;
2698 } 2736 }
2699 } 2737 }
2700#endif // LL_LINUX 2738#endif // LL_LINUX || LL_SOLARIS
2701 2739
2702 llinfos << "spawn_web_browser returning." << llendl; 2740 llinfos << "spawn_web_browser returning." << llendl;
2703} 2741}