summaryrefslogtreecommitdiff
path: root/sys/arch/alpha/tc/sfb.c
diff options
context:
space:
mode:
authorEric Jackson <ericj@cvs.openbsd.org>2000-08-04 16:45:48 +0000
committerEric Jackson <ericj@cvs.openbsd.org>2000-08-04 16:45:48 +0000
commite640d975aff83d74ed898bc9958819ffef6d5024 (patch)
tree258685ed60b92e2309cf6b7e65e4bc0c32d0112c /sys/arch/alpha/tc/sfb.c
parentb1ab130ebe1061631d5465253f2334914def8120 (diff)
convert sfb and cfb to use new wscons; from NetBSD.
Diffstat (limited to 'sys/arch/alpha/tc/sfb.c')
-rw-r--r--sys/arch/alpha/tc/sfb.c185
1 files changed, 111 insertions, 74 deletions
diff --git a/sys/arch/alpha/tc/sfb.c b/sys/arch/alpha/tc/sfb.c
index 5bb7cabd239..727af13cac4 100644
--- a/sys/arch/alpha/tc/sfb.c
+++ b/sys/arch/alpha/tc/sfb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sfb.c,v 1.10 1998/11/21 18:13:04 millert Exp $ */
+/* $OpenBSD: sfb.c,v 1.11 2000/08/04 16:45:47 ericj Exp $ */
/* $NetBSD: sfb.c,v 1.7 1996/12/05 01:39:44 cgd Exp $ */
/*
@@ -43,13 +43,10 @@
#include <dev/tc/tcvar.h>
#include <machine/sfbreg.h>
#include <alpha/tc/sfbvar.h>
-#if 0
-#include <alpha/tc/bt459reg.h>
-#endif
#include <dev/rcons/raster.h>
#include <dev/wscons/wscons_raster.h>
-#include <dev/wscons/wsconsvar.h>
+#include <dev/wscons/wsdisplayvar.h>
#include <machine/fbio.h>
#include <machine/autoconf.h>
@@ -61,7 +58,6 @@ int sfbmatch __P((struct device *, void *, void *));
int sfbmatch __P((struct device *, struct cfdata *, void *));
#endif
void sfbattach __P((struct device *, struct device *, void *));
-int sfbprint __P((void *, const char *));
struct cfattach sfb_ca = {
sizeof(struct sfb_softc), sfbmatch, sfbattach,
@@ -73,25 +69,56 @@ struct cfdriver sfb_cd = {
void sfb_getdevconfig __P((tc_addr_t dense_addr, struct sfb_devconfig *dc));
struct sfb_devconfig sfb_console_dc;
+tc_addr_t sfb_consaddr;
+
+struct wsdisplay_emulops sfb_emulfuncs = {
+ rcons_cursor, /* could use hardware cursor; punt */
+ rcons_mapchar,
+ rcons_putchar,
+ rcons_copycols,
+ rcons_erasecols,
+ rcons_copyrows,
+ rcons_eraserows,
+ rcons_alloc_attr
+};
-struct wscons_emulfuncs sfb_emulfuncs = {
- rcons_cursor, /* could use hardware cursor; punt */
- rcons_putstr,
- rcons_copycols,
- rcons_erasecols,
- rcons_copyrows,
- rcons_eraserows,
- rcons_setattr,
+struct wsscreen_descr sfb_stdscreen = {
+ "std",
+ 0, 0, /* will be filled in -- XXX shouldn't, it's global */
+ &sfb_emulfuncs,
+ 0, 0
+};
+const struct wsscreen_descr *_sfb_scrlist[] = {
+ &sfb_stdscreen,
+ /* XXX other formats, graphics screen? */
+};
+
+struct wsscreen_list sfb_screenlist = {
+ sizeof(_sfb_scrlist) / sizeof(struct wsscreen_descr *), _sfb_scrlist
};
int sfbioctl __P((void *, u_long, caddr_t, int, struct proc *));
int sfbmmap __P((void *, off_t, int));
+static int sfb_alloc_screen __P((void *, const struct wsscreen_descr *,
+ void **, int *, int *, long *));
+static void sfb_free_screen __P((void *, void *));
+static int sfb_show_screen __P((void *, void *, int,
+ void (*) (void *, int, int), void *));
+
#if 0
void sfb_blank __P((struct sfb_devconfig *));
void sfb_unblank __P((struct sfb_devconfig *));
#endif
+struct wsdisplay_accessops sfb_accessops = {
+ sfbioctl,
+ sfbmmap,
+ sfb_alloc_screen,
+ sfb_free_screen,
+ sfb_show_screen,
+};
+
int
sfbmatch(parent, match, aux)
struct device *parent;
@@ -206,6 +233,9 @@ sfb_getdevconfig(dense_addr, dc)
rcp->rc_crowp = &rcp->rc_crow;
rcp->rc_ccolp = &rcp->rc_ccol;
rcons_init(rcp, 34, 80);
+
+ sfb_stdscreen.nrows = dc->dc_rcons.rc_maxrow;
+ sfb_stdscreen.ncols = dc->dc_rcons.rc_maxcol;
}
void
@@ -215,14 +245,14 @@ sfbattach(parent, self, aux)
{
struct sfb_softc *sc = (struct sfb_softc *)self;
struct tc_attach_args *ta = aux;
- struct wscons_attach_args waa;
- struct wscons_odev_spec *wo;
+ struct wsemuldisplaydev_attach_args waa;
int console;
- console = 0; /* XXX */
- if (console)
+ console = (ta->ta_addr == sfb_consaddr);
+ if (console) {
sc->sc_dc = &sfb_console_dc;
- else {
+ sc->nscreens = 1;
+ } else {
sc->sc_dc = (struct sfb_devconfig *)
malloc(sizeof(struct sfb_devconfig), M_DEVBUF, M_WAITOK);
sfb_getdevconfig(ta->ta_addr, sc->sc_dc);
@@ -244,33 +274,12 @@ sfbattach(parent, self, aux)
*(u_int32_t *)(x + SFB_ASIC_VIDEO_VSETUP));
#endif
- waa.waa_isconsole = console;
- wo = &waa.waa_odev_spec;
-
- wo->wo_emulfuncs = &sfb_emulfuncs;
- wo->wo_emulfuncs_cookie = &sc->sc_dc->dc_rcons;
-
- wo->wo_ioctl = sfbioctl;
- wo->wo_mmap = sfbmmap;
- wo->wo_miscfuncs_cookie = sc;
-
- wo->wo_nrows = sc->sc_dc->dc_rcons.rc_maxrow;
- wo->wo_ncols = sc->sc_dc->dc_rcons.rc_maxcol;
- wo->wo_crow = 0;
- wo->wo_ccol = 0;
-
- config_found(self, &waa, sfbprint);
-}
-
-int
-sfbprint(aux, pnp)
- void *aux;
- const char *pnp;
-{
+ waa.console = console;
+ waa.scrdata = &sfb_screenlist;
+ waa.accessops = &sfb_accessops;
+ waa.accesscookie = sc;
- if (pnp)
- printf("wscons at %s", pnp);
- return (UNCONF);
+ config_found(self, &waa, wsemuldisplaydevprint);
}
int
@@ -353,42 +362,70 @@ sfbmmap(v, offset, prot)
return alpha_btop(sc->sc_dc->dc_paddr + offset);
}
-#if 0
+int
+sfb_alloc_screen(v, type, cookiep, curxp, curyp, attrp)
+ void *v;
+ const struct wsscreen_descr *type;
+ void **cookiep;
+ int *curxp, *curyp;
+ long *attrp;
+{
+ struct sfb_softc *sc = v;
+ long defattr;
+
+ if (sc->nscreens > 0)
+ return (ENOMEM);
+
+ *cookiep = &sc->sc_dc->dc_rcons; /* one and only for now */
+ *curxp = 0;
+ *curyp = 0;
+ rcons_alloc_attr(&sc->sc_dc->dc_rcons, 0, 0, 0, &defattr);
+ *attrp = defattr;
+ sc->nscreens++;
+ return (0);
+}
+
void
-tga_console(bc, pc, bus, device, function)
- bus_chipset_tag_t bc;
- pci_chipset_tag_t pc;
- int bus, device, function;
+sfb_free_screen(v, cookie)
+ void *v;
+ void *cookie;
{
- struct tga_devconfig *dcp = &tga_console_dc;
- struct wscons_odev_spec wo;
+ struct sfb_softc *sc = v;
- tga_getdevconfig(bc, pc, pci_make_tag(pc, bus, device, function), dcp);
+ if (sc->sc_dc == &sfb_console_dc)
+ panic("sfb_free_screen: console");
- /* sanity checks */
- if (dcp->dc_vaddr == NULL)
- panic("tga_console(%d, %d): couldn't map memory space",
- device, function);
- if (dcp->dc_tgaconf == NULL)
- panic("tga_console(%d, %d): unknown board configuration",
- device, function);
+ sc->nscreens--;
+}
- /*
- * Initialize the RAMDAC but DO NOT allocate any private storage.
- * Initialization includes disabling cursor, setting a sane
- * colormap, etc. It will be reinitialized in tgaattach().
- */
- (*dcp->dc_tgaconf->tgac_ramdac->tgar_init)(dcp, 0);
+int
+sfb_show_screen(v, cookie, waitok, cb, cbarg)
+ void *v;
+ void *cookie;
+ int waitok;
+ void (*cb) __P((void *, int, int));
+ void *cbarg;
+{
- wo.wo_ef = &tga_emulfuncs;
- wo.wo_efa = &dcp->dc_rcons;
- wo.wo_nrows = dcp->dc_rcons.rc_maxrow;
- wo.wo_ncols = dcp->dc_rcons.rc_maxcol;
- wo.wo_crow = 0;
- wo.wo_ccol = 0;
- /* ioctl and mmap are unused until real attachment. */
+ return (0);
+}
+
+#if 0
+int
+sfb_cnattach(addr)
+ tc_addr_t addr;
+{
+ struct sfb_devconfig *dcp = &sfb_console_dc;
+ long defattr;
+
+ sfb_getdevconfig(addr, dcp);
+
+ rcons_alloc_attr(&dcp->dc_rcons, 0, 0, 0, &defattr);
- wscons_attach_console(&wo);
+ wsdisplay_cnattach(&sfb_stdscreen, &dcp->dc_rcons,
+ 0, 0, defattr);
+ sfb_consaddr = addr;
+ return(0);
}
#endif