summaryrefslogtreecommitdiff
path: root/sys/arch/sparc/dev/cgfour.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sparc/dev/cgfour.c')
-rw-r--r--sys/arch/sparc/dev/cgfour.c33
1 files changed, 12 insertions, 21 deletions
diff --git a/sys/arch/sparc/dev/cgfour.c b/sys/arch/sparc/dev/cgfour.c
index 6e6c83364d6..172706c3120 100644
--- a/sys/arch/sparc/dev/cgfour.c
+++ b/sys/arch/sparc/dev/cgfour.c
@@ -88,27 +88,29 @@ struct cgfour_softc {
};
/* autoconfiguration driver */
-void cgfourattach __P((struct device *, struct device *, void *));
-int cgfourmatch __P((struct device *, void *, void *));
+static void cgfourattach __P((struct device *, struct device *, void *));
+static int cgfourmatch __P((struct device *, void *, void *));
+int cgfouropen __P((dev_t, int, int, struct proc *));
+int cgfourclose __P((dev_t, int, int, struct proc *));
+int cgfourioctl __P((dev_t, u_long, caddr_t, int, struct proc *));
+int cgfourmmap __P((dev_t, int, int));
+static void cgfourunblank __P((struct device *));
+
struct cfdriver cgfourcd = {
NULL, "cgfour", cgfourmatch, cgfourattach,
DV_DULL, sizeof(struct cgfour_softc)
};
/* frame buffer generic driver */
-static void cgfourunblank __P((struct device *));
-static struct fbdriver cgfourfbdriver = { cgfourunblank };
+static struct fbdriver cgfourfbdriver = {
+ cgfourunblank, cgfouropen, cgfourclose, cgfourioctl, cgfourmmap
+};
extern int fbnode;
extern struct tty *fbconstty;
-extern int (*v_putc)();
-extern int nullop();
-static int cgfour_cnputc();
static void cgfourloadcmap __P((struct cgfour_softc *, int, int));
-#define CGFOUR_MAJOR 39 /* XXX */
-
/*
* Match a cgfour.
*/
@@ -138,21 +140,14 @@ cgfourattach(parent, self, args)
{
register struct cgfour_softc *sc = (struct cgfour_softc *)self;
register struct confargs *ca = args;
- register int node, ramsize, i;
+ register int node = 0, ramsize, i;
register volatile struct bt_regs *bt;
register struct cgfour_all *p;
int isconsole;
- sc->sc_fb.fb_major = CGFOUR_MAJOR; /* XXX to be removed */
-
sc->sc_fb.fb_driver = &cgfourfbdriver;
sc->sc_fb.fb_device = &sc->sc_dev;
- /*
- * The defaults below match my screen, but are not guaranteed
- * to be correct as defaults go...
- */
sc->sc_fb.fb_type.fb_type = FBTYPE_SUN4COLOR;
- node = 0;
pfour_reset();
pfour_videosize(ca->ca_ra.ra_pfour, &sc->sc_fb.fb_type.fb_width,
@@ -410,9 +405,5 @@ cgfourmmap(dev, off, prot)
poff = off + (CG4REG_COLOUR - CG4REG_OVERLAY) - START_COLOUR;
else
return (-1);
- /*
- * I turned on PMAP_NC here to disable the cache as I was
- * getting horribly broken behaviour with it on.
- */
return ((u_int)sc->sc_phys + poff + PMAP_OBIO + PMAP_NC);
}