]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/dev/fb/vesa.h
cxgbe(4): Stop but don't free netmap queues when netmap is switched off.
[FreeBSD/FreeBSD.git] / sys / dev / fb / vesa.h
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3  *
4  * Copyright (c) 1998 Michael Smith and Kazutaka YOKOTA
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer as
12  *    the first lines of this file unmodified.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``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 AUTHORS 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  * $FreeBSD$
29  */
30
31 #ifndef _DEV_FB_VESA_H_
32 #define _DEV_FB_VESA_H_
33
34 struct vesa_info
35 {
36     /* mandatory fields */
37     u_int8_t            v_sig[4];       /* VESA */
38     u_int16_t           v_version;      /* ver in BCD */
39     u_int32_t           v_oemstr;       /* OEM string */
40     u_int32_t           v_flags;        /* flags */
41 #define V_DAC8          (1<<0)
42 #define V_NONVGA        (1<<1)
43 #define V_SNOW          (1<<2)
44     u_int32_t           v_modetable;    /* modes */
45     u_int16_t           v_memsize;      /* in 64K */
46     /* 2.0 */
47     u_int16_t           v_revision;     /* software rev */
48     u_int32_t           v_venderstr;    /* vender */
49     u_int32_t           v_prodstr;      /* product name */
50     u_int32_t           v_revstr;       /* product rev */
51     u_int8_t            v_strach[222];
52     u_int8_t            v_oemdata[256];
53 } __packed;
54
55 struct vesa_mode 
56 {
57     /* mandatory fields */
58     u_int16_t           v_modeattr;
59 #define V_MODESUPP      (1<<0)  /* VESA mode attributes */
60 #define V_MODEOPTINFO   (1<<1)
61 #define V_MODEBIOSOUT   (1<<2)
62 #define V_MODECOLOR     (1<<3)
63 #define V_MODEGRAPHICS  (1<<4)
64 #define V_MODENONVGA    (1<<5)
65 #define V_MODENONBANK   (1<<6)
66 #define V_MODELFB       (1<<7)
67 #define V_MODEVESA      (1<<16) /* Private attributes */
68     u_int8_t            v_waattr;
69     u_int8_t            v_wbattr;
70 #define V_WATTREXIST    (1<<0)
71 #define V_WATTRREAD     (1<<1)
72 #define V_WATTRWRITE    (1<<2)
73     u_int16_t           v_wgran;
74     u_int16_t           v_wsize;
75     u_int16_t           v_waseg;
76     u_int16_t           v_wbseg;
77     u_int32_t           v_posfunc;
78     u_int16_t           v_bpscanline;
79     /* fields optional for 1.0/1.1 implementations */
80     u_int16_t           v_width;
81     u_int16_t           v_height;
82     u_int8_t            v_cwidth;
83     u_int8_t            v_cheight;
84     u_int8_t            v_planes;
85     u_int8_t            v_bpp;
86     u_int8_t            v_banks;
87     u_int8_t            v_memmodel;
88 #define V_MMTEXT        0
89 #define V_MMCGA         1
90 #define V_MMHGC         2
91 #define V_MMEGA         3
92 #define V_MMPACKED      4
93 #define V_MMSEQU256     5
94 #define V_MMDIRCOLOR    6
95 #define V_MMYUV         7
96     u_int8_t            v_banksize;
97     u_int8_t            v_ipages;
98     u_int8_t            v_reserved0;
99     /* fields for 1.2+ implementations */
100     u_int8_t            v_redmasksize;
101     u_int8_t            v_redfieldpos;
102     u_int8_t            v_greenmasksize;
103     u_int8_t            v_greenfieldpos;
104     u_int8_t            v_bluemasksize;
105     u_int8_t            v_bluefieldpos;
106     u_int8_t            v_resmasksize;
107     u_int8_t            v_resfieldpos;
108     u_int8_t            v_dircolormode;
109     /* 2.0 implementations */
110     u_int32_t           v_lfb;
111     u_int32_t           v_offscreen;
112     u_int16_t           v_offscreensize;
113     /* 3.0 implementations */
114     u_int16_t           v_linbpscanline;
115     u_int8_t            v_bankipages;
116     u_int8_t            v_linipages;
117     u_int8_t            v_linredmasksize;
118     u_int8_t            v_linredfieldpos;
119     u_int8_t            v_lingreenmasksize;
120     u_int8_t            v_lingreenfieldpos;
121     u_int8_t            v_linbluemasksize;
122     u_int8_t            v_linbluefieldpos;
123     u_int8_t            v_linresmasksize;
124     u_int8_t            v_linresfieldpos;
125     u_int32_t           v_maxpixelclock;
126     u_int8_t            v_reserved1[190];
127 } __packed;
128
129 #ifdef _KERNEL
130
131 #define VESA_MODE(x)    ((x) >= M_VESA_BASE && (x) <= M_VESA_MODE_MAX)
132
133 int vesa_load_ioctl(void);
134 int vesa_unload_ioctl(void);
135
136 #endif
137
138 #endif /* !_DEV_FB_VESA_H_ */