[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH] move DAC register setting to linux.c
From: |
Robert Millan |
Subject: |
Re: [PATCH] move DAC register setting to linux.c |
Date: |
Sat, 12 Sep 2009 15:07:30 +0200 |
User-agent: |
Mutt/1.5.18 (2008-05-17) |
Committed.
On Thu, Sep 10, 2009 at 11:03:16PM +0200, Robert Millan wrote:
>
> It didn't really seem right that we were *setting* values in the DAC palette
> register in a function that was only meant to retrieve video mode information.
>
> So I would rather move this to the Linux loader. In the event that other
> loaders would need this facility, it can be moved into a shared function.
>
> This has the advantage that we don't mess with the DAC palette in cases where
> this is not necessary (read: the vast majority of them).
>
> --
> Robert Millan
>
> The DRM opt-in fallacy: "Your data belongs to us. We will decide when (and
> how) you may access your data; but nobody's threatening your freedom: we
> still allow you to remove your data and not access it at all."
> 2009-09-10 Robert Millan <address@hidden>
>
> * video/i386/pc/vbe.c (grub_vbe_get_video_mode_info): Move packed
> mode special handling (grub_vbe_bios_set_dac_palette_width() call)
> from here ...
> * loader/i386/linux.c [GRUB_MACHINE_PCBIOS]
> (grub_linux_setup_video): ... to here (with some adjustments).
>
> Index: video/i386/pc/vbe.c
> ===================================================================
> --- video/i386/pc/vbe.c (revision 2583)
> +++ video/i386/pc/vbe.c (working copy)
> @@ -286,24 +286,6 @@ grub_vbe_get_video_mode_info (grub_uint3
>
> /* Make copy of mode info block. */
> grub_memcpy (mode_info, mi_tmp, sizeof (*mode_info));
> -
> - /* Packed mode. Query DAC Palette width for color sizes. */
> - if (mode_info->bits_per_pixel <= 8)
> - {
> - int width = 8;
> - status = 0;
> -
> - if (controller_info.capabilities & GRUB_VBE_CAPABILITY_DACWIDTH)
> - status = grub_vbe_bios_set_dac_palette_width (& width);
> -
> - if (status != GRUB_VBE_STATUS_OK)
> - /* 6 is default after mode reset. */
> - width = 6;
> -
> - mode_info->red_mask_size = mode_info->green_mask_size
> - = mode_info->blue_mask_size = width;
> - mode_info->rsvd_mask_size = 0;
> - }
> }
> else
> /* Just clear mode info block if it isn't a VESA mode. */
> Index: loader/i386/linux.c
> ===================================================================
> --- loader/i386/linux.c (revision 2583)
> +++ loader/i386/linux.c (working copy)
> @@ -33,6 +33,7 @@
> #include <grub/video.h>
> #include <grub/video_fb.h>
> #include <grub/command.h>
> +#include <grub/i386/pc/vbe.h>
>
> #define GRUB_LINUX_CL_OFFSET 0x1000
> #define GRUB_LINUX_CL_END_OFFSET 0x2000
> @@ -416,6 +417,33 @@ grub_linux_setup_video (struct linux_ker
> params->reserved_mask_size = mode_info.reserved_mask_size;
> params->reserved_field_pos = mode_info.reserved_field_pos;
>
> +
> +#ifdef GRUB_MACHINE_PCBIOS
> + /* VESA packed modes may come with zeroed mask sizes, which need
> + to be set here according to DAC Palette width. If we don't,
> + this results in Linux displaying a black screen. */
> + if (mode_info.bpp <= 8)
> + {
> + struct grub_vbe_info_block controller_info;
> + int status;
> + int width = 8;
> +
> + status = grub_vbe_bios_get_controller_info (&controller_info);
> +
> + if (status == GRUB_VBE_STATUS_OK &&
> + (controller_info.capabilities & GRUB_VBE_CAPABILITY_DACWIDTH))
> + status = grub_vbe_bios_set_dac_palette_width (&width);
> +
> + if (status != GRUB_VBE_STATUS_OK)
> + /* 6 is default after mode reset. */
> + width = 6;
> +
> + params->red_mask_size = params->green_mask_size
> + = params->blue_mask_size = width;
> + params->reserved_mask_size = 0;
> + }
> +#endif
> +
> return 0;
> }
>
> _______________________________________________
> Grub-devel mailing list
> address@hidden
> http://lists.gnu.org/mailman/listinfo/grub-devel
--
Robert Millan
The DRM opt-in fallacy: "Your data belongs to us. We will decide when (and
how) you may access your data; but nobody's threatening your freedom: we
still allow you to remove your data and not access it at all."