1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
/* $OpenBSD: vgafbvar.h,v 1.4 2002/03/14 03:15:56 millert Exp $ */
/* $NetBSD: vgavar.h,v 1.2 1996/11/23 06:06:43 cgd Exp $ */
/*
* Copyright (c) 1995, 1996 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Chris G. Demetriou
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
struct vgafb_config {
/*
* Filled in by front-ends.
*/
int vc_ofh; /* openfirmware handle */
bus_space_tag_t vc_iot, vc_memt;
bus_space_handle_t vc_ioh_b, vc_ioh_c, vc_ioh_d, vc_memh, vc_mmioh;
paddr_t vc_paddr; /* physical address */
/* Colormap */
u_char vc_cmap_red[256];
u_char vc_cmap_green[256];
u_char vc_cmap_blue[256];
/*
* Private to back-end.
*/
int vc_ncol, vc_nrow; /* screen width & height */
int vc_ccol, vc_crow; /* current cursor position */
char vc_so; /* in standout mode? */
char vc_at; /* normal attributes */
char vc_so_at; /* standout attributes */
int (*vc_ioctl)(void *, u_long,
caddr_t, int, struct proc *);
paddr_t (*vc_mmap)(void *, off_t, int);
#if 0
struct raster dc_raster; /* raster description */
#endif
struct rcons dc_rcons; /* raster blitter control info */
};
int vgafb_common_probe(bus_space_tag_t, bus_space_tag_t,
u_int32_t, size_t, u_int32_t, size_t, u_int32_t, size_t );
void vgafb_common_setup(bus_space_tag_t, bus_space_tag_t,
struct vgafb_config *, u_int32_t, size_t, u_int32_t, size_t,
u_int32_t, size_t);
void vgafb_wscons_attach(struct device *, struct vgafb_config *, int);
void vgafb_wscons_console(struct vgafb_config *);
void vgafb_cnprobe(struct consdev *cp);
void vgafb_cnattach(bus_space_tag_t iot, bus_space_tag_t memt,
void *pc, int bus, int device, int function);
void vgafb_wsdisplay_attach(struct device *parent,
struct vgafb_config *vc, int console);
int vgafbioctl(void *, u_long, caddr_t, int, struct proc *);
paddr_t vgafbmmap(void *, off_t, int);
int vgafb_ioctl(void *, u_long, caddr_t, int, struct proc *);
paddr_t vgafb_mmap(void *, off_t, int);
int vgafb_alloc_screen(void *v, const struct wsscreen_descr *type,
void **cookiep, int *curxp, int *curyp, long *attrp);
void vgafb_free_screen(void *v, void *cookie);
int vgafb_show_screen(void *v, void *cookie, int waitok,
void (*cb)(void *, int, int), void *cbarg);
|