Module Name: src Committed By: rin Date: Fri Mar 5 06:17:02 UTC 2021
Modified Files: src/sys/arch/evbppc/explora/dev: pckbc_elb.c Log Message: Avoid doubly bus_space_map(9) when pckbc(4) is already attached as console. To generate a diff of this commit: cvs rdiff -u -r1.11 -r1.12 src/sys/arch/evbppc/explora/dev/pckbc_elb.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/arch/evbppc/explora/dev/pckbc_elb.c diff -u src/sys/arch/evbppc/explora/dev/pckbc_elb.c:1.11 src/sys/arch/evbppc/explora/dev/pckbc_elb.c:1.12 --- src/sys/arch/evbppc/explora/dev/pckbc_elb.c:1.11 Fri Mar 5 06:14:47 2021 +++ src/sys/arch/evbppc/explora/dev/pckbc_elb.c Fri Mar 5 06:17:02 2021 @@ -1,4 +1,4 @@ -/* $NetBSD: pckbc_elb.c,v 1.11 2021/03/05 06:14:47 rin Exp $ */ +/* $NetBSD: pckbc_elb.c,v 1.12 2021/03/05 06:17:02 rin Exp $ */ /*- * Copyright (c) 2003 The NetBSD Foundation, Inc. @@ -30,7 +30,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: pckbc_elb.c,v 1.11 2021/03/05 06:14:47 rin Exp $"); +__KERNEL_RCSID(0, "$NetBSD: pckbc_elb.c,v 1.12 2021/03/05 06:17:02 rin Exp $"); #include <sys/param.h> #include <sys/conf.h> @@ -84,19 +84,23 @@ pckbc_elb_attach(device_t parent, device msc->sc_irq = eaa->elb_irq; sc->intr_establish = pckbc_elb_intr_establish; - if (pckbc_is_console(eaa->elb_bt, eaa->elb_base)) { + if (pckbc_is_console(eaa->elb_bt, + _BUS_SPACE_UNSTRIDE(eaa->elb_bt, eaa->elb_base))) { t = &pckbc_consdata; pckbc_console_attached = 1; } else { t = kmem_zalloc(sizeof(struct pckbc_internal), KM_SLEEP); + + t->t_iot = eaa->elb_bt; + bus_space_map(eaa->elb_bt, + _BUS_SPACE_UNSTRIDE(eaa->elb_bt, eaa->elb_base), 1, 0, + &t->t_ioh_d); + bus_space_map(eaa->elb_bt, + _BUS_SPACE_UNSTRIDE(eaa->elb_bt, eaa->elb_base2), 1, 0, + &t->t_ioh_c); + t->t_addr = eaa->elb_base; } - t->t_iot = eaa->elb_bt; - bus_space_map(eaa->elb_bt, - _BUS_SPACE_UNSTRIDE(eaa->elb_bt, eaa->elb_base), 1, 0, &t->t_ioh_d); - bus_space_map(eaa->elb_bt, - _BUS_SPACE_UNSTRIDE(eaa->elb_bt, eaa->elb_base2), 1, 0, &t->t_ioh_c); - t->t_addr = eaa->elb_base; t->t_sc = sc; sc->id = t;