root/usr/src/boot/i386/libi386/vbe.h
/*-
 * Copyright (c) 2009 Jared D. McNeill <jmcneill@invisible.ca>
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * Default mode for VESA frame buffer.
 * This mode is selected when there is no EDID inormation and
 * mode is not provided by user.
 * To provide consistent look with UEFI GOP, we use 800x600 here,
 * and if this mode is not available, we fall back to text mode and
 * VESA disabled.
 */

#ifndef _VBE_H
#define _VBE_H

#define VBE_DEFAULT_MODE        "800x600"

struct vbeinfoblock {
        char VbeSignature[4];
        uint16_t VbeVersion;
        uint32_t OemStringPtr;
        uint32_t Capabilities;
#define VBE_CAP_DAC8    (1 << 0)        /* Can switch DAC */
#define VBE_CAP_NONVGA  (1 << 1)        /* Controller is not VGA comp. */
#define VBE_CAP_SNOW    (1 << 2)        /* Set data during Vertical Reterace */
        uint32_t VideoModePtr;
        uint16_t TotalMemory;
        uint16_t OemSoftwareRev;
        uint32_t OemVendorNamePtr, OemProductNamePtr, OemProductRevPtr;
        /* data area, in total max 512 bytes for VBE 2.0 */
        uint8_t Reserved[222];
        uint8_t OemData[256];
} __packed;

struct modeinfoblock {
        /* Mandatory information for all VBE revisions */
        uint16_t ModeAttributes;
        uint8_t WinAAttributes, WinBAttributes;
        uint16_t WinGranularity, WinSize, WinASegment, WinBSegment;
        uint32_t WinFuncPtr;
        uint16_t BytesPerScanLine;
        /* Mandatory information for VBE 1.2 and above */
        uint16_t XResolution, YResolution;
        uint8_t XCharSize, YCharSize, NumberOfPlanes, BitsPerPixel;
        uint8_t NumberOfBanks, MemoryModel, BankSize, NumberOfImagePages;
        uint8_t Reserved1;
        /*
         * Direct Color fields
         * (required for direct/6 and YUV/7 memory models)
         */
        uint8_t RedMaskSize, RedFieldPosition;
        uint8_t GreenMaskSize, GreenFieldPosition;
        uint8_t BlueMaskSize, BlueFieldPosition;
        uint8_t RsvdMaskSize, RsvdFieldPosition;
        uint8_t DirectColorModeInfo;
        /* Mandatory information for VBE 2.0 and above */
        uint32_t PhysBasePtr;
        uint32_t OffScreenMemOffset;    /* reserved in VBE 3.0 and above */
        uint16_t OffScreenMemSize;      /* reserved in VBE 3.0 and above */

        /* Mandatory information for VBE 3.0 and above */
        uint16_t LinBytesPerScanLine;
        uint8_t BnkNumberOfImagePages;
        uint8_t LinNumberOfImagePages;
        uint8_t LinRedMaskSize, LinRedFieldPosition;
        uint8_t LinGreenMaskSize, LinGreenFieldPosition;
        uint8_t LinBlueMaskSize, LinBlueFieldPosition;
        uint8_t LinRsvdMaskSize, LinRsvdFieldPosition;
        uint32_t MaxPixelClock;
        /* + 1 will fix the size to 256 bytes */
        uint8_t Reserved4[189 + 1];
} __packed;

struct crtciinfoblock {
        uint16_t HorizontalTotal;
        uint16_t HorizontalSyncStart;
        uint16_t HorizontalSyncEnd;
        uint16_t VerticalTotal;
        uint16_t VerticalSyncStart;
        uint16_t VerticalSyncEnd;
        uint8_t Flags;
        uint32_t PixelClock;
        uint16_t RefreshRate;
        uint8_t Reserved[40];
} __packed;

struct paletteentry {
        uint8_t Blue;
        uint8_t Green;
        uint8_t Red;
        uint8_t Reserved;
} __packed;

struct flatpanelinfo
{
        uint16_t HorizontalSize;        /* Horizontal Size in Pixels */
        uint16_t VerticalSize;          /* Vertical Size in Lines */
        uint16_t PanelType;             /* Flat Panel Type */
        uint8_t RedBPP;                 /* Red Bits Per Primary */
        uint8_t GreenBPP;               /* Green Bits Per Primary */
        uint8_t BlueBPP;                /* Blue Bits Per Primary */
        uint8_t ReservedBPP;            /* Reserved Bits Per Primary */
        uint32_t RsvdOffScreenMemSize;  /* Size in KB of Offscreen Memory */
        uint32_t RsvdOffScreenMemPtr; /* Pointer to reserved offscreen memory */
        uint8_t Reserved[14];           /* remainder of FPInfo */
} __packed;

#define VBE_BASE_MODE           (0x100)         /* VBE 3.0 page 18 */
#define VBE_VALID_MODE(a)       ((a) >= VBE_BASE_MODE)
#define VBE_ERROR(a)            (((a) & 0xFF) != 0x4F || ((a) & 0xFF00) != 0)
#define VBE_SUCCESS             (0x004F)
#define VBE_FAILED              (0x014F)
#define VBE_NOTSUP              (0x024F)
#define VBE_INVALID             (0x034F)

#define VGA_TEXT_MODE           (3)             /* 80x25 text mode */
#define TEXT_ROWS               (25)            /* VGATEXT rows */
#define TEXT_COLS               (80)            /* VGATEXT columns */

#define CMAP_SIZE               256     /* Number of colors in palette */

extern struct paletteentry pe8[CMAP_SIZE];
extern int palette_format;

/* high-level VBE helpers, from vbe.c */
void bios_set_text_mode(int);
int biosvbe_palette_format(int *);
void vbe_init(void);
int vbe_available(void);
int vbe_default_mode(void);
int vbe_set_mode(int);
int vbe_get_mode(void);
int vbe_set_palette(const struct paletteentry *, size_t);
void vbe_modelist(int);

#endif /* _VBE_H */