source: mainline/kernel/arch/ia32/src/drivers/vesa.c@ a5e5030

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since a5e5030 was 1496f87, checked in by Martin Decky <martin@…>, 17 years ago

properly detect VESA 16 bpp modes with 5:5:5 colors

  • Property mode set to 100644
File size: 2.9 KB
RevLine 
[22cf454d]1/*
[df4ed85]2 * Copyright (c) 2006 Jakub Vana
[22cf454d]3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
[3c5006a0]29/** @addtogroup ia32
[b45c443]30 * @{
31 */
[3c5006a0]32/**
33 * @file
34 * @brief VESA frame buffer driver.
[b45c443]35 */
36
[22cf454d]37#ifdef CONFIG_FB
38
39#include <genarch/fb/fb.h>
[2bc137c2]40#include <genarch/fb/visuals.h>
[80d31883]41#include <arch/drivers/vesa.h>
[22cf454d]42#include <putchar.h>
43#include <mm/page.h>
[de07bcf]44#include <mm/frame.h>
[22cf454d]45#include <mm/as.h>
46#include <arch/mm/page.h>
47#include <synch/spinlock.h>
48#include <arch/asm.h>
[5f0c664]49#include <arch/types.h>
[22cf454d]50#include <memstr.h>
[5f0c664]51#include <bitops.h>
[22cf454d]52
[7f1c620]53uint32_t vesa_ph_addr;
54uint16_t vesa_width;
55uint16_t vesa_height;
56uint16_t vesa_bpp;
57uint16_t vesa_scanline;
[22cf454d]58
[1496f87]59uint8_t vesa_red_mask;
60uint8_t vesa_red_pos;
61
62uint8_t vesa_green_mask;
63uint8_t vesa_green_pos;
64
65uint8_t vesa_blue_mask;
66uint8_t vesa_blue_pos;
67
[22cf454d]68int vesa_present(void)
69{
[4a26e39]70 if ((vesa_width != 0xffff) && (vesa_height != 0xffff))
[5f0c664]71 return true;
[4a26e39]72
[22cf454d]73 return false;
74}
75
76void vesa_init(void)
77{
[2bc137c2]78 unsigned int visual;
79
80 switch (vesa_bpp) {
81 case 8:
82 visual = VISUAL_INDIRECT_8;
83 break;
84 case 16:
[1496f87]85 if ((vesa_red_mask == 5) && (vesa_red_pos == 10)
86 && (vesa_green_mask == 5) && (vesa_green_pos == 5)
87 && (vesa_blue_mask == 5) && (vesa_blue_pos == 0))
88 visual = VISUAL_RGB_5_5_5;
89 else
90 visual = VISUAL_RGB_5_6_5;
[2bc137c2]91 break;
92 case 24:
93 visual = VISUAL_RGB_8_8_8;
94 break;
95 case 32:
96 visual = VISUAL_RGB_0_8_8_8;
97 break;
98 default:
[f651e80]99 panic("Unsupported bits per pixel.");
[2bc137c2]100 }
101
[965dc18]102 fb_properties_t vesa_props = {
103 .addr = vesa_ph_addr,
104 .offset = 0,
105 .x = vesa_width,
106 .y = vesa_height,
107 .scan = vesa_scanline,
108 .visual = visual,
109 };
110 fb_init(&vesa_props);
[22cf454d]111}
112
[76fca31]113void vesa_redraw(void)
114{
115 fb_redraw();
116}
117
[22cf454d]118#endif
[b45c443]119
[3c5006a0]120/** @}
[b45c443]121 */
Note: See TracBrowser for help on using the repository browser.