diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2007-01-07 13:28:05 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2007-01-07 13:28:05 +0000 |
commit | 0a883e2832fbbb400ea83340c6603ecea40a0ae5 (patch) | |
tree | 9540d95937353bb2a7d1807387891c6ae642527e /sys/dev/wscons/wsdisplay.c | |
parent | 3a21d6290a494bf9d5d42d03c056d61f02da49da (diff) |
In wsscreen_attach(), allow wsemul->attach to fail (returning NULL) if the
screen is not the console.
Diffstat (limited to 'sys/dev/wscons/wsdisplay.c')
-rw-r--r-- | sys/dev/wscons/wsdisplay.c | 33 |
1 files changed, 17 insertions, 16 deletions
diff --git a/sys/dev/wscons/wsdisplay.c b/sys/dev/wscons/wsdisplay.c index eba6c54609f..d3a17233f2d 100644 --- a/sys/dev/wscons/wsdisplay.c +++ b/sys/dev/wscons/wsdisplay.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsdisplay.c,v 1.74 2006/12/02 18:16:14 miod Exp $ */ +/* $OpenBSD: wsdisplay.c,v 1.75 2007/01/07 13:28:04 miod Exp $ */ /* $NetBSD: wsdisplay.c,v 1.82 2005/02/27 00:27:52 perry Exp $ */ /* @@ -288,26 +288,21 @@ wsscreen_attach(struct wsdisplay_softc *sc, int console, const char *emul, * Tell the emulation about the callback argument. * The other stuff is already there. */ - (*dconf->wsemul->attach)(1, 0, 0, 0, 0, scr, 0); + (void)(*dconf->wsemul->attach)(1, 0, 0, 0, 0, scr, 0); } else { /* not console */ dconf = malloc(sizeof(struct wsscreen_internal), M_DEVBUF, M_NOWAIT); - if (dconf == NULL) { - free(scr, M_DEVBUF); - return (NULL); - } + if (dconf == NULL) + goto fail; dconf->emulops = type->textops; dconf->emulcookie = cookie; - if (dconf->emulops != NULL && - (dconf->wsemul = wsemul_pick(emul)) != NULL) { - dconf->wsemulcookie = - (*dconf->wsemul->attach)(0, type, cookie, - ccol, crow, scr, defattr); - } else { - free(dconf, M_DEVBUF); - free(scr, M_DEVBUF); - return (NULL); - } + if (dconf->emulops == NULL || + (dconf->wsemul = wsemul_pick(emul)) == NULL) + goto fail; + dconf->wsemulcookie = (*dconf->wsemul->attach)(0, type, cookie, + ccol, crow, scr, defattr); + if (dconf->wsemulcookie == NULL) + goto fail; dconf->scrdata = type; } @@ -329,6 +324,12 @@ wsscreen_attach(struct wsdisplay_softc *sc, int console, const char *emul, scr->scr_rawkbd = 0; #endif return (scr); + +fail: + if (dconf != NULL) + free(dconf, M_DEVBUF); + free(scr, M_DEVBUF); + return (NULL); } void |