xref: /openbsd-src/sys/arch/sparc64/dev/gfb.c (revision 63294167c4eaf171adac4fb2d8cc6d072a13af61)
1*63294167Skettenis /*	$OpenBSD: gfb.c,v 1.4 2022/07/15 17:57:26 kettenis Exp $	*/
24aa2721cSkettenis 
34aa2721cSkettenis /*
44aa2721cSkettenis  * Copyright (c) 2009 Mark Kettenis.
54aa2721cSkettenis  *
64aa2721cSkettenis  * Permission to use, copy, modify, and distribute this software for any
74aa2721cSkettenis  * purpose with or without fee is hereby granted, provided that the above
84aa2721cSkettenis  * copyright notice and this permission notice appear in all copies.
94aa2721cSkettenis  *
104aa2721cSkettenis  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
114aa2721cSkettenis  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
124aa2721cSkettenis  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
134aa2721cSkettenis  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
144aa2721cSkettenis  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
154aa2721cSkettenis  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
164aa2721cSkettenis  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
174aa2721cSkettenis  */
184aa2721cSkettenis 
194aa2721cSkettenis #include <sys/param.h>
204aa2721cSkettenis #include <sys/device.h>
214aa2721cSkettenis #include <sys/systm.h>
224aa2721cSkettenis 
234aa2721cSkettenis #include <machine/bus.h>
244aa2721cSkettenis #include <machine/autoconf.h>
254aa2721cSkettenis 
264aa2721cSkettenis #include <dev/wscons/wsconsio.h>
274aa2721cSkettenis #include <dev/wscons/wsdisplayvar.h>
284aa2721cSkettenis #include <dev/rasops/rasops.h>
294aa2721cSkettenis #include <machine/fbvar.h>
304aa2721cSkettenis 
314aa2721cSkettenis struct gfb_softc {
324aa2721cSkettenis 	struct sunfb sc_sunfb;
334aa2721cSkettenis 	bus_space_tag_t sc_bt;
344aa2721cSkettenis 	bus_space_handle_t sc_pixel_h;
354aa2721cSkettenis 	int sc_console;
364aa2721cSkettenis 	int sc_node;
374aa2721cSkettenis 	u_int sc_mode;
384aa2721cSkettenis };
394aa2721cSkettenis 
404aa2721cSkettenis int	gfb_match(struct device *, void *, void *);
414aa2721cSkettenis void	gfb_attach(struct device *, struct device *, void *);
424aa2721cSkettenis 
434aa2721cSkettenis int	gfb_ioctl(void *, u_long, caddr_t, int, struct proc *);
444aa2721cSkettenis 
454aa2721cSkettenis struct wsdisplay_accessops gfb_accessops = {
4687eec248Smiod 	.ioctl = gfb_ioctl
474aa2721cSkettenis };
484aa2721cSkettenis 
494aa2721cSkettenis struct cfdriver gfb_cd = {
504aa2721cSkettenis 	NULL, "gfb", DV_DULL
514aa2721cSkettenis };
524aa2721cSkettenis 
53eb7eaf8dSmpi const struct cfattach gfb_ca = {
544aa2721cSkettenis 	sizeof(struct gfb_softc), gfb_match, gfb_attach
554aa2721cSkettenis };
564aa2721cSkettenis 
574aa2721cSkettenis int
gfb_match(struct device * parent,void * match,void * aux)584aa2721cSkettenis gfb_match(struct device *parent, void *match, void *aux)
594aa2721cSkettenis {
604aa2721cSkettenis 	struct mainbus_attach_args *ma = aux;
614aa2721cSkettenis 
624aa2721cSkettenis 	if (strcmp(ma->ma_name, "SUNW,gfb") == 0)
634aa2721cSkettenis 		return (1);
644aa2721cSkettenis 	return (0);
654aa2721cSkettenis }
664aa2721cSkettenis 
674aa2721cSkettenis void
gfb_attach(struct device * parent,struct device * self,void * aux)684aa2721cSkettenis gfb_attach(struct device *parent, struct device *self, void *aux)
694aa2721cSkettenis {
704aa2721cSkettenis 	struct gfb_softc *sc = (struct gfb_softc *)self;
714aa2721cSkettenis 	struct mainbus_attach_args *ma = aux;
724aa2721cSkettenis 	extern int fbnode;
734aa2721cSkettenis 
744aa2721cSkettenis 	sc->sc_bt = ma->ma_bustag;
754aa2721cSkettenis 
764aa2721cSkettenis 	printf("\n");
774aa2721cSkettenis 
784aa2721cSkettenis 	if (bus_space_map(ma->ma_bustag, ma->ma_reg[6].ur_paddr,
794aa2721cSkettenis 	    ma->ma_reg[6].ur_len, BUS_SPACE_MAP_LINEAR, &sc->sc_pixel_h))
804aa2721cSkettenis 		return;
814aa2721cSkettenis 
824aa2721cSkettenis 	sc->sc_console = (fbnode == ma->ma_node);
834aa2721cSkettenis 	sc->sc_node = ma->ma_node;
844aa2721cSkettenis 
854aa2721cSkettenis 	fb_setsize(&sc->sc_sunfb, 32, 1152, 900, sc->sc_node, 0);
864aa2721cSkettenis 	/* linesize has a fixed value, compensate */
874aa2721cSkettenis 	sc->sc_sunfb.sf_linebytes = 16384;
884aa2721cSkettenis 	sc->sc_sunfb.sf_fbsize = sc->sc_sunfb.sf_height * 16384;
894aa2721cSkettenis 
904aa2721cSkettenis 	sc->sc_sunfb.sf_ro.ri_bits = (void *)bus_space_vaddr(sc->sc_bt,
914aa2721cSkettenis 	    sc->sc_pixel_h);
924aa2721cSkettenis 	sc->sc_sunfb.sf_ro.ri_hw = sc;
934aa2721cSkettenis 	fbwscons_init(&sc->sc_sunfb, 0, sc->sc_console);
944aa2721cSkettenis 
954aa2721cSkettenis 	if (sc->sc_console)
964aa2721cSkettenis 		fbwscons_console_init(&sc->sc_sunfb, -1);
974aa2721cSkettenis 
984aa2721cSkettenis 	fbwscons_attach(&sc->sc_sunfb, &gfb_accessops, sc->sc_console);
994aa2721cSkettenis 	return;
1004aa2721cSkettenis }
1014aa2721cSkettenis 
1024aa2721cSkettenis int
gfb_ioctl(void * v,u_long cmd,caddr_t data,int flags,struct proc * p)1034aa2721cSkettenis gfb_ioctl(void *v, u_long cmd, caddr_t data, int flags, struct proc *p)
1044aa2721cSkettenis {
1054aa2721cSkettenis 	struct gfb_softc *sc = v;
1064aa2721cSkettenis 	struct wsdisplay_fbinfo *wdf;
1074aa2721cSkettenis 
1084aa2721cSkettenis 	switch (cmd) {
1094aa2721cSkettenis 	case WSDISPLAYIO_GTYPE:
1104aa2721cSkettenis 		*(u_int *)data = WSDISPLAY_TYPE_UNKNOWN;
1114aa2721cSkettenis 		break;
1124aa2721cSkettenis 	case WSDISPLAYIO_SMODE:
1134aa2721cSkettenis 		sc->sc_mode = *(u_int *)data;
1144aa2721cSkettenis 		break;
1154aa2721cSkettenis 	case WSDISPLAYIO_GINFO:
1164aa2721cSkettenis 		wdf = (void *)data;
1174aa2721cSkettenis 		wdf->height = sc->sc_sunfb.sf_height;
1184aa2721cSkettenis 		wdf->width  = sc->sc_sunfb.sf_width;
1194aa2721cSkettenis 		wdf->depth  = sc->sc_sunfb.sf_depth;
120*63294167Skettenis 		wdf->stride = sc->sc_sunfb.sf_linebytes;
121*63294167Skettenis 		wdf->offset = 0;
1224aa2721cSkettenis 		wdf->cmsize = 256;
1234aa2721cSkettenis 		break;
1244aa2721cSkettenis 	case WSDISPLAYIO_LINEBYTES:
1254aa2721cSkettenis 		*(u_int *)data = sc->sc_sunfb.sf_linebytes;
1264aa2721cSkettenis 		break;
1274aa2721cSkettenis 
1284aa2721cSkettenis #if 0
1294aa2721cSkettenis 	case WSDISPLAYIO_GETCMAP:
1304aa2721cSkettenis 		return gfb_getcmap(sc, (struct wsdisplay_cmap *)data);
1314aa2721cSkettenis 	case WSDISPLAYIO_PUTCMAP:
1324aa2721cSkettenis 		return gfb_putcmap(sc, (struct wsdisplay_cmap *)data);
1334aa2721cSkettenis #endif
1344aa2721cSkettenis 
1354aa2721cSkettenis 	case WSDISPLAYIO_SVIDEO:
1364aa2721cSkettenis 	case WSDISPLAYIO_GVIDEO:
1374aa2721cSkettenis 		break;
1384aa2721cSkettenis 
1394aa2721cSkettenis 	case WSDISPLAYIO_GCURPOS:
1404aa2721cSkettenis 	case WSDISPLAYIO_SCURPOS:
1414aa2721cSkettenis 	case WSDISPLAYIO_GCURMAX:
1424aa2721cSkettenis 	case WSDISPLAYIO_GCURSOR:
1434aa2721cSkettenis 	case WSDISPLAYIO_SCURSOR:
1444aa2721cSkettenis 	default:
1454aa2721cSkettenis 		return -1; /* not supported yet */
1464aa2721cSkettenis         }
1474aa2721cSkettenis 
1484aa2721cSkettenis 	return (0);
1494aa2721cSkettenis }
150