Home | History | Annotate | Line # | Download | only in dev
grfvar.h revision 1.14
      1  1.14  briggs /*	$NetBSD: grfvar.h,v 1.14 1997/04/01 05:42:01 briggs Exp $	*/
      2   1.3     cgd 
      3   1.1  briggs /*
      4   1.1  briggs  * Copyright (c) 1988 University of Utah.
      5   1.1  briggs  * Copyright (c) 1990 The Regents of the University of California.
      6   1.1  briggs  * All rights reserved.
      7   1.1  briggs  *
      8   1.1  briggs  * This code is derived from software contributed to Berkeley by
      9   1.1  briggs  * the Systems Programming Group of the University of Utah Computer
     10   1.1  briggs  * Science Department.
     11   1.1  briggs  *
     12   1.1  briggs  * Redistribution and use in source and binary forms, with or without
     13   1.1  briggs  * modification, are permitted provided that the following conditions
     14   1.1  briggs  * are met:
     15   1.1  briggs  * 1. Redistributions of source code must retain the above copyright
     16   1.1  briggs  *    notice, this list of conditions and the following disclaimer.
     17   1.1  briggs  * 2. Redistributions in binary form must reproduce the above copyright
     18   1.1  briggs  *    notice, this list of conditions and the following disclaimer in the
     19   1.1  briggs  *    documentation and/or other materials provided with the distribution.
     20   1.1  briggs  * 3. All advertising materials mentioning features or use of this software
     21   1.1  briggs  *    must display the following acknowledgement:
     22   1.1  briggs  *	This product includes software developed by the University of
     23   1.1  briggs  *	California, Berkeley and its contributors.
     24   1.1  briggs  * 4. Neither the name of the University nor the names of its contributors
     25   1.1  briggs  *    may be used to endorse or promote products derived from this software
     26   1.1  briggs  *    without specific prior written permission.
     27   1.1  briggs  *
     28   1.1  briggs  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     29   1.1  briggs  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     30   1.1  briggs  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     31   1.1  briggs  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     32   1.1  briggs  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     33   1.1  briggs  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     34   1.1  briggs  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     35   1.1  briggs  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     36   1.1  briggs  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     37   1.1  briggs  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     38   1.1  briggs  * SUCH DAMAGE.
     39   1.1  briggs  *
     40   1.1  briggs  * from: Utah $Hdr: grfvar.h 1.9 91/01/21$
     41   1.1  briggs  *
     42   1.3     cgd  *	@(#)grfvar.h	7.3 (Berkeley) 5/7/91
     43   1.1  briggs  */
     44   1.1  briggs 
     45   1.7  briggs #define CARD_NAME_LEN	64
     46  1.10  scottr 
     47  1.10  scottr /*
     48  1.10  scottr  * State info, per hardware instance.
     49  1.10  scottr  */
     50  1.10  scottr struct grfbus_softc {
     51   1.7  briggs 	struct	device	sc_dev;
     52   1.7  briggs 	nubus_slot	sc_slot;
     53   1.6  briggs 
     54  1.14  briggs 	bus_space_tag_t		sc_tag;
     55  1.14  briggs 	bus_space_handle_t	sc_regh;
     56  1.14  briggs 	bus_space_handle_t	sc_fbh;
     57  1.14  briggs 
     58   1.7  briggs 	struct	grfmode curr_mode;	/* hardware desc(for ioctl)	*/
     59  1.14  briggs 	u_int32_t	card_id;	/* DrHW value for nubus cards	*/
     60  1.14  briggs 	u_int32_t	cli_offset;	/* Offset of byte to clear intr */
     61  1.14  briggs 					/* for cards where that's suff.  */
     62   1.7  briggs 	nubus_dir	board_dir;	/* Nubus dir for curr board	*/
     63  1.10  scottr };
     64  1.10  scottr 
     65  1.10  scottr /*
     66  1.10  scottr  * State info, per grf instance.
     67  1.10  scottr  */
     68  1.10  scottr struct grf_softc {
     69  1.10  scottr 	struct	device sc_dev;		/* device glue */
     70  1.10  scottr 
     71  1.10  scottr 	int	sc_flags;		/* software flags */
     72  1.10  scottr 	struct	grfmode *sc_grfmode;	/* forwarded ... */
     73  1.10  scottr 	nubus_slot	*sc_slot;
     74   1.9  briggs 					/* mode-change on/off/mode function */
     75  1.10  scottr 	int	(*sc_mode) __P((struct grf_softc *, int, void *));
     76   1.9  briggs 					/* map virtual addr to physical addr */
     77  1.10  scottr 	caddr_t	(*sc_phys) __P((struct grf_softc *, vm_offset_t));
     78  1.10  scottr };
     79  1.10  scottr 
     80  1.10  scottr /*
     81  1.10  scottr  * Attach grf and ite semantics to Mac video hardware.
     82  1.10  scottr  */
     83  1.10  scottr struct grfbus_attach_args {
     84  1.10  scottr 	char	*ga_name;		/* name of semantics to attach */
     85  1.10  scottr 	struct	grfmode *ga_grfmode;	/* forwarded ... */
     86  1.10  scottr 	nubus_slot	*ga_slot;
     87  1.10  scottr 	int	(*ga_mode) __P((struct grf_softc *, int, void *));
     88  1.10  scottr 	caddr_t	(*ga_phys) __P((struct grf_softc *, vm_offset_t));
     89   1.1  briggs };
     90   1.1  briggs 
     91   1.9  briggs typedef	caddr_t (*grf_phys_t) __P((struct grf_softc *gp, vm_offset_t addr));
     92   1.9  briggs 
     93   1.1  briggs /* flags */
     94   1.1  briggs #define	GF_ALIVE	0x01
     95   1.1  briggs #define GF_OPEN		0x02
     96   1.1  briggs #define GF_EXCLUDE	0x04
     97   1.1  briggs #define GF_WANTED	0x08
     98   1.1  briggs #define GF_BSDOPEN	0x10
     99   1.1  briggs #define GF_HPUXOPEN	0x20
    100   1.1  briggs 
    101   1.1  briggs /* requests to mode routine */
    102   1.1  briggs #define GM_GRFON	1
    103   1.1  briggs #define GM_GRFOFF	2
    104   1.7  briggs #define GM_CURRMODE	3
    105   1.7  briggs #define GM_LISTMODES	4
    106   1.7  briggs #define GM_NEWMODE	5
    107   1.1  briggs 
    108   1.1  briggs /* minor device interpretation */
    109   1.1  briggs #define GRFUNIT(d)	((d) & 0x7)
    110   1.1  briggs 
    111   1.7  briggs /*
    112   1.7  briggs  * Nubus image data structure.  This is the equivalent of a PixMap in
    113   1.7  briggs  * MacOS programming parlance.  One of these structures exists for each
    114   1.7  briggs  * video mode that a quickdraw compatible card can fit in.
    115   1.7  briggs  */
    116   1.7  briggs struct image_data {
    117   1.7  briggs 	u_int32_t	size;
    118   1.7  briggs 	u_int32_t	offset;
    119   1.7  briggs 	u_int16_t	rowbytes;
    120   1.7  briggs 	u_int16_t	top;
    121   1.7  briggs 	u_int16_t	left;
    122   1.7  briggs 	u_int16_t	bottom;
    123   1.7  briggs 	u_int16_t	right;
    124   1.7  briggs 	u_int16_t	version;
    125   1.7  briggs 	u_int16_t	packType;
    126   1.7  briggs 	u_int32_t	packSize;
    127   1.7  briggs 	u_int32_t	hRes;
    128   1.7  briggs 	u_int32_t	vRes;
    129   1.7  briggs 	u_int16_t	pixelType;
    130   1.7  briggs 	u_int16_t	pixelSize;
    131   1.7  briggs 	u_int16_t	cmpCount;
    132   1.7  briggs 	u_int16_t	cmpSize;
    133   1.7  briggs 	u_int32_t	planeBytes;
    134   1.7  briggs };
    135   1.7  briggs 
    136   1.7  briggs #define VID_PARAMS		1
    137   1.7  briggs #define VID_TABLE_OFFSET	2
    138   1.7  briggs #define VID_PAGE_CNT		3
    139   1.7  briggs #define VID_DEV_TYPE		4
    140   1.9  briggs 
    141   1.9  briggs int	grfopen __P((dev_t dev, int flag, int mode, struct proc *p));
    142   1.9  briggs int	grfclose __P((dev_t dev, int flag, int mode, struct proc *p));
    143   1.9  briggs int	grfioctl __P((dev_t, int, caddr_t, int, struct proc *p));
    144  1.13  scottr int	grfpoll __P((dev_t dev, int events, struct proc *p));
    145   1.9  briggs int	grfmmap __P((dev_t dev, int off, int prot));
    146   1.9  briggs int	grfon __P((dev_t dev));
    147   1.9  briggs int	grfoff __P((dev_t dev));
    148   1.9  briggs int	grfaddr __P((struct grf_softc *gp, register int off));
    149   1.9  briggs int	grfmap __P((dev_t dev, caddr_t *addrp, struct proc *p));
    150   1.9  briggs int	grfunmap __P((dev_t dev, caddr_t addr, struct proc *p));
    151  1.10  scottr 
    152  1.11  scottr void	grf_establish __P((struct grfbus_softc *, nubus_slot *,
    153  1.10  scottr 	    int (*)(struct grf_softc *, int, void *),
    154  1.10  scottr 	    caddr_t (*)(struct grf_softc *, vm_offset_t)));
    155  1.12  scottr int	grfbusprint __P((void *, const char *));
    156