diff options
author | Pascal Rigaux <pixel@mandriva.com> | 2009-01-27 17:30:35 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 2009-01-27 17:30:35 +0000 |
commit | 4ca721b1fe6022c985ab7b10d1bea36f657c28b3 (patch) | |
tree | 1274a22b2a5ecf0214849a79c6773af3dcf87581 /src | |
parent | a218dc40a68bfe95d2307d9d2d115fc46e8f3cd8 (diff) | |
download | bootloader-theme-4ca721b1fe6022c985ab7b10d1bea36f657c28b3.tar bootloader-theme-4ca721b1fe6022c985ab7b10d1bea36f657c28b3.tar.gz bootloader-theme-4ca721b1fe6022c985ab7b10d1bea36f657c28b3.tar.bz2 bootloader-theme-4ca721b1fe6022c985ab7b10d1bea36f657c28b3.tar.xz bootloader-theme-4ca721b1fe6022c985ab7b10d1bea36f657c28b3.zip |
we do not handle multiple splash files (splashy)
only propose a limited number of framebuffer modes
(note that "video" menu is only used for syslinux, not grub)
Diffstat (limited to 'src')
-rw-r--r-- | src/common.inc | 45 | ||||
-rw-r--r-- | src/dia_video.inc | 190 |
2 files changed, 4 insertions, 231 deletions
diff --git a/src/common.inc b/src/common.inc index cf6bc2e..adb0052 100644 --- a/src/common.inc +++ b/src/common.inc @@ -342,21 +342,6 @@ menu.texts menu.entry get "%s " bc.cmd sprintf } ifelse - syslinux { - /splash_file 32 string def - - video.modes.list xmenu.video .xm_current get get - dup .vm_mode get 0 ge { - dup .vm_height get exch .vm_width get - ",%04d%04d.spl" splash_file sprintf - } { pop } ifelse - - % check whether splash file exists - splash_file 1 add filesize .undef eq { - splash_file 0 0 put % empty string - } if - } if - xmenu.kernelopts { kernelopts.options xmenu.kernelopts .xm_current get get dup "" ne { "%s " bc.cmd dup length add sprintf @@ -367,41 +352,11 @@ cmdline.hidden { cmdline.hidden "" ne { - splash_file { - /bc.tmp cmdline.hidden length splash_file length add string def - cmdline.hidden "initrd=" bootopt.find dup .undef ne { - skipnonspaces - dup - dup 0 get over 0 0 put - splash_file cmdline.hidden "%s%s" bc.tmp sprintf - 0 exch put - "%s" bc.tmp dup length add sprintf - } { - pop - bc.tmp cmdline.hidden strcpy pop - } ifelse - - bc.tmp "%s " bc.cmd dup length add sprintf - - bc.tmp free /bc.tmp .undef def - } { cmdline.hidden "%s " bc.cmd dup length add sprintf - } ifelse } if } if - /splash_file xfree - syslinux { - video.modes.list xmenu.video .xm_current get get .vm_mode get - - dup 0 ge { - 0x200 add "vga=0x%x " bc.cmd dup length add sprintf - } { - -1 eq { - "textmode=1 " bc.cmd dup length add sprintf - } if - } ifelse config.lang { config.lang "en_US" ne { diff --git a/src/dia_video.inc b/src/dia_video.inc index 8bbba40..6e7f16d 100644 --- a/src/dia_video.inc +++ b/src/dia_video.inc @@ -9,73 +9,9 @@ % Some global vars. % % video mode array fields -/.vm_mode 0 def -/.vm_width 1 def -/.vm_height 2 def - -% We have kernel splash images for at least these sizes. -/video.splashsizes [ - 0 0 % special: for text mode - 1 0 % special: for VESA mode - 800 600 - 1024 600 - 1024 768 - 1280 800 - 1280 1024 - 1400 1050 - 1600 1200 - 1680 1050 - 1920 1200 -] def - - -% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -% Create sort key for video modes. -% -% ( vm_index ) ==> ( sort_index ) -% -/vmsortindex { - video.modes.list exch get - dup - .vm_width get 16 shl - exch .vm_height get add -} def - - -% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -% Swap video mode entries. -% (Helper for video mode sorting.) -% -% ( vm_index_1 vm_index_2 ) ==> ( ) -% -/vmsortexch { - over video.modes.list exch get - over video.modes.list exch get - video.modes.list - 5 -1 roll rot put - video.modes.list 3 1 roll put -} def - - -% - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -% Check if we have a splash in that resolution. -% -% ( video_mode_list_entry ) ==> ( true|false ) -% -/video.havesplash { - false exch - - 0 2 video.splashsizes length 1 sub { - over over over - .vm_height get rot .vm_width get rot video.splashsizes exch get eq - rot 1 add video.splashsizes exch get rot eq and - { exch pop true exch exit } if - } for - - pop - -} def - +/video.default 2 def +/video.modes.list [ 0 785 788 791 ] def +/video.modes.text [ "Text" "640 x 480" "800 x 600" "1024 x 768" ] def % - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - % Build video mode list. @@ -87,125 +23,9 @@ /xmenu xmenu.video def - % build list of video modes - /video.modes.list [ - [ -1 0 0 ] % special: text mode - [ -2 1 0 ] % special: VESA mode (width = 1 to make it sort) - - % first, try 16 bit - /vm_color_bits 16 def - - { - 0 1 videomodes { - videomodeinfo dup .undef eq { - pop pop pop pop - } { - [ - over 0xbfff and 6 2 roll - 0x4000 and % fb support - exch vm_color_bits eq and % color bits - over 600 ge and % height >= 600 - 2 index 800 ge and % width >= 800 - { ] } { pop pop pop pop } ifelse - } ifelse - } for - - % no modes added? -> try 8 bit - dup .vm_mode get -2 eq vm_color_bits 8 ne and { - /vm_color_bits 8 def - } { - exit - } ifelse - } loop - - ] def - - % sort video.modes.list - - video.modes.list length 3 gt { - 0 1 video.modes.list length 2 sub { - dup 1 add 1 video.modes.list length 1 sub { - over vmsortindex over vmsortindex gt { - over over vmsortexch - } if - pop - } for - pop - } for - } if - - % remove duplicates - % (assumes text or vesa entry to be first) - - /video.modes.list - [ - video.modes.list { - dup .vm_mode get 0 gt { % ensure it's not the first entry - over .vm_width get over .vm_width get eq - 2 index .vm_height get 2 index .vm_height get eq and { - free - } if - } if - } forall - ] - video.modes.list free - def - - % create mode strings - - /video.modes.text [ - video.modes.list { - dup .vm_width get - dup 0 eq { - pop pop /txt_text_mode - } { - dup 1 eq { - pop pop "VESA" - } { - exch .vm_height get exch "%d x %d" 32 string dup 5 1 roll sprintf - } ifelse - } ifelse - } forall - ] def - - % add to menu - xmenu .xm_list video.modes.text put xmenu .xm_title .undef put - - % select largest mode the monitor supports - - boot_failsafe 4 and { 0 0 } { monitorsize } ifelse - exch 800 max exch 600 max % at least 800x600 - - % ATI quirk: avoid 1280x1024, older chips (<= 8MB, max res 1280x1024) use - % interlaced there - - video.modes.list dup length 1 sub get - dup .vm_width get 1280 eq exch .vm_height get 1024 eq and { - video.memory 0x2000 le { - video.oem "ATI " strstr 1 eq { - exch 1024 min exch 768 min % down to 1024x768 - } if - } if - } if - - xmenu .xm_current -1 put - - -1 - video.modes.list { - exch 1 add exch - - dup .vm_width get 4 index le - over .vm_height get 4 index le and - exch video.havesplash and { - xmenu .xm_current 2 index put - } if - - } forall - pop - - pop pop + xmenu .xm_current video.default put } def @@ -259,5 +79,3 @@ pmenu.panel.update } def - - |