Slight tweak to how the sm(4) driver attaches to superio. Also, just
use the regular bus tag for sm(4) instead of superio's "special" ISA bus tag.
This commit is contained in:
parent
ec32f137a2
commit
5cc4fe3194
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: if_sm_superio.c,v 1.1 2002/08/26 11:04:45 scw Exp $ */
|
/* $NetBSD: if_sm_superio.c,v 1.2 2002/08/30 10:57:06 scw Exp $ */
|
||||||
|
|
||||||
/*-
|
/*-
|
||||||
* Copyright (c) 1997 The NetBSD Foundation, Inc.
|
* Copyright (c) 1997 The NetBSD Foundation, Inc.
|
||||||
@ -47,7 +47,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: if_sm_superio.c,v 1.1 2002/08/26 11:04:45 scw Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: if_sm_superio.c,v 1.2 2002/08/30 10:57:06 scw Exp $");
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/systm.h>
|
#include <sys/systm.h>
|
||||||
@ -109,7 +109,7 @@ sm_superio_match(struct device *parent, struct cfdata *cf, void *aux)
|
|||||||
if (cf->cf_loc[SUPERIOCF_IRQ] == SUPERIOCF_IRQ_DEFAULT)
|
if (cf->cf_loc[SUPERIOCF_IRQ] == SUPERIOCF_IRQ_DEFAULT)
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
saa->saa_offset = cf->cf_loc[SUPERIOCF_OFFSET];
|
saa->saa_offset += cf->cf_loc[SUPERIOCF_OFFSET];
|
||||||
saa->saa_irq = cf->cf_loc[SUPERIOCF_IRQ];
|
saa->saa_irq = cf->cf_loc[SUPERIOCF_IRQ];
|
||||||
|
|
||||||
/* Map the device. */
|
/* Map the device. */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: superio.c,v 1.3 2002/08/29 18:11:07 scw Exp $ */
|
/* $NetBSD: superio.c,v 1.4 2002/08/30 10:57:05 scw Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2002 Wasabi Systems, Inc.
|
* Copyright 2002 Wasabi Systems, Inc.
|
||||||
@ -188,8 +188,6 @@ static struct superio_devs superio_devs[] = {
|
|||||||
|
|
||||||
#define SUPERIO_NDEVS (sizeof(superio_devs) / sizeof(struct superio_devs))
|
#define SUPERIO_NDEVS (sizeof(superio_devs) / sizeof(struct superio_devs))
|
||||||
|
|
||||||
#define BH_IS_LAN_DEV(bh) (((bus_addr_t)bh) >= SYSFPGA_OFFSET_LAN)
|
|
||||||
|
|
||||||
/*ARGSUSED*/
|
/*ARGSUSED*/
|
||||||
static int
|
static int
|
||||||
superiomatch(struct device *parent, struct cfdata *cf, void *args)
|
superiomatch(struct device *parent, struct cfdata *cf, void *args)
|
||||||
@ -303,9 +301,10 @@ superioattach(struct device *parent, struct device *self, void *args)
|
|||||||
* Attach the onboard network interface
|
* Attach the onboard network interface
|
||||||
*/
|
*/
|
||||||
saa.saa_name = "sm";
|
saa.saa_name = "sm";
|
||||||
saa.saa_offset = SUPERIOCF_OFFSET_DEFAULT;
|
saa.saa_offset = sa->sa_offset;
|
||||||
|
saa._saa_base = sa->sa_offset;
|
||||||
saa.saa_irq = SUPERIOCF_IRQ_DEFAULT;
|
saa.saa_irq = SUPERIOCF_IRQ_DEFAULT;
|
||||||
saa.saa_bust = &superio_bus_space_tag;
|
saa.saa_bust = sc->sc_bust;
|
||||||
config_found_sm(self, &saa, superioprint, superiosubmatch);
|
config_found_sm(self, &saa, superioprint, superiosubmatch);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -320,8 +319,7 @@ superioprint(void *arg, const char *cp)
|
|||||||
|
|
||||||
#if NSM_SUPERIO > 0
|
#if NSM_SUPERIO > 0
|
||||||
if (strcmp(saa->saa_name, "isa") != 0) {
|
if (strcmp(saa->saa_name, "isa") != 0) {
|
||||||
if (saa->saa_offset != SUPERIOCF_OFFSET_DEFAULT)
|
printf(" offset 0x%x", saa->saa_offset - saa->_saa_base);
|
||||||
printf(" offset 0x%x", saa->saa_offset);
|
|
||||||
if (saa->saa_irq != SUPERIOCF_IRQ_DEFAULT)
|
if (saa->saa_irq != SUPERIOCF_IRQ_DEFAULT)
|
||||||
printf(" irq %d", saa->saa_irq);
|
printf(" irq %d", saa->saa_irq);
|
||||||
}
|
}
|
||||||
@ -388,19 +386,14 @@ superio_bs_map(void *arg, bus_addr_t addr, bus_size_t size,
|
|||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
int rv;
|
int rv;
|
||||||
|
|
||||||
if (addr < SYSFPGA_OFFSET_LAN) {
|
addr *= 4;
|
||||||
addr *= 4;
|
size *= 4;
|
||||||
size *= 4;
|
|
||||||
|
|
||||||
if (sc->sc_isaext) {
|
if (sc->sc_isaext) {
|
||||||
rv = extent_alloc_region(sc->sc_isaext,
|
rv = extent_alloc_region(sc->sc_isaext, addr, size, EX_NOWAIT);
|
||||||
addr, size, EX_NOWAIT);
|
if (rv != 0)
|
||||||
if (rv != 0)
|
return (rv);
|
||||||
return (rv);
|
}
|
||||||
}
|
|
||||||
} else
|
|
||||||
if (addr > (SYSFPGA_OFFSET_LAN + SMC_IOSIZE))
|
|
||||||
return (EINVAL);
|
|
||||||
|
|
||||||
*hp = (bus_space_handle_t) addr;
|
*hp = (bus_space_handle_t) addr;
|
||||||
|
|
||||||
@ -414,8 +407,7 @@ superio_bs_unmap(void *arg, bus_space_handle_t bh, bus_size_t size)
|
|||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
bus_addr_t addr = (bus_addr_t)bh;
|
bus_addr_t addr = (bus_addr_t)bh;
|
||||||
|
|
||||||
if (sc->sc_isaext && addr < SYSFPGA_OFFSET_LAN)
|
extent_free(sc->sc_isaext, addr, size * 4, EX_NOWAIT);
|
||||||
extent_free(sc->sc_isaext, addr, size * 4, EX_NOWAIT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*ARGSUSED*/
|
/*ARGSUSED*/
|
||||||
@ -438,23 +430,10 @@ static u_int8_t
|
|||||||
superio_bs_read_1(void *arg, bus_space_handle_t bh, bus_size_t off)
|
superio_bs_read_1(void *arg, bus_space_handle_t bh, bus_size_t off)
|
||||||
{
|
{
|
||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
u_int8_t rv;
|
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
rv = (u_int8_t)bus_space_read_4(sc->sc_bust, sc->sc_bush, off);
|
return ((u_int8_t)bus_space_read_4(sc->sc_bust, sc->sc_bush, off));
|
||||||
} else {
|
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
|
||||||
off = (bus_size_t)bh + (off ^ 0x3);
|
|
||||||
#else
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
rv = bus_space_read_1(sc->sc_bust, sc->sc_bush, off);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (rv);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static u_int16_t
|
static u_int16_t
|
||||||
@ -464,21 +443,12 @@ superio_bs_read_2(void *arg, bus_space_handle_t bh, bus_size_t off)
|
|||||||
u_int32_t reg;
|
u_int32_t reg;
|
||||||
u_int16_t rv;
|
u_int16_t rv;
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off);
|
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off);
|
||||||
rv = reg & 0xff;
|
rv = reg & 0xff;
|
||||||
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off + 4);
|
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off + 4);
|
||||||
rv |= (reg & 0xff) << 8;
|
rv |= (reg & 0xff) << 8;
|
||||||
} else {
|
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
|
||||||
off = (bus_size_t)bh + (off ^ 0x2);
|
|
||||||
#else
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
#endif
|
|
||||||
rv = bus_space_read_2(sc->sc_bust, sc->sc_bush, off);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (rv);
|
return (rv);
|
||||||
}
|
}
|
||||||
@ -489,20 +459,9 @@ superio_bs_write_1(void *arg, bus_space_handle_t bh, bus_size_t off,
|
|||||||
{
|
{
|
||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
bus_space_write_4(sc->sc_bust, sc->sc_bush, off,
|
bus_space_write_4(sc->sc_bust, sc->sc_bush, off, (u_int32_t)val & 0xff);
|
||||||
(u_int32_t)val & 0xff);
|
|
||||||
} else {
|
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
|
||||||
off = (bus_size_t)bh + (off ^ 0x3);
|
|
||||||
#else
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bus_space_write_1(sc->sc_bust, sc->sc_bush, off, val);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -511,21 +470,12 @@ superio_bs_write_2(void *arg, bus_space_handle_t bh, bus_size_t off,
|
|||||||
{
|
{
|
||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
bus_space_write_4(sc->sc_bust, sc->sc_bush, off,
|
bus_space_write_4(sc->sc_bust, sc->sc_bush, off,
|
||||||
(u_int32_t)val & 0xff);
|
(u_int32_t)val & 0xff);
|
||||||
bus_space_write_4(sc->sc_bust, sc->sc_bush, off + 4,
|
bus_space_write_4(sc->sc_bust, sc->sc_bush, off + 4,
|
||||||
(u_int32_t)(val >> 8) & 0xff);
|
(u_int32_t)(val >> 8) & 0xff);
|
||||||
} else {
|
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
|
||||||
off = (bus_size_t)bh + (off ^ 0x2);
|
|
||||||
#else
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
#endif
|
|
||||||
bus_space_write_2(sc->sc_bust, sc->sc_bush, off, val);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static u_int16_t
|
static u_int16_t
|
||||||
@ -535,18 +485,12 @@ superio_bs_read_stream_2(void *arg, bus_space_handle_t bh, bus_size_t off)
|
|||||||
u_int32_t reg;
|
u_int32_t reg;
|
||||||
u_int16_t rv;
|
u_int16_t rv;
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off);
|
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off);
|
||||||
rv = reg & 0xff;
|
rv = reg & 0xff;
|
||||||
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off + 4);
|
reg = bus_space_read_4(sc->sc_bust, sc->sc_bush, off + 4);
|
||||||
rv = (rv << 8) | (reg & 0xff);
|
rv = (rv << 8) | (reg & 0xff);
|
||||||
} else {
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
|
|
||||||
rv = bus_space_read_stream_2(sc->sc_bust, sc->sc_bush, off);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (rv);
|
return (rv);
|
||||||
}
|
}
|
||||||
@ -557,18 +501,12 @@ superio_bs_write_stream_2(void *arg, bus_space_handle_t bh, bus_size_t off,
|
|||||||
{
|
{
|
||||||
struct superio_softc *sc = arg;
|
struct superio_softc *sc = arg;
|
||||||
|
|
||||||
if (!BH_IS_LAN_DEV(bh)) {
|
off = (bus_size_t)bh + (off * 4);
|
||||||
off = (bus_size_t)bh + (off * 4);
|
|
||||||
|
|
||||||
bus_space_write_4(sc->sc_bust, sc->sc_bush, off,
|
bus_space_write_4(sc->sc_bust, sc->sc_bush, off,
|
||||||
(u_int32_t)(val >> 8) & 0xff);
|
(u_int32_t)(val >> 8) & 0xff);
|
||||||
bus_space_write_4(sc->sc_bust, sc->sc_bush, off + 4,
|
bus_space_write_4(sc->sc_bust, sc->sc_bush, off + 4,
|
||||||
(u_int32_t)val & 0xff);
|
(u_int32_t)val & 0xff);
|
||||||
} else {
|
|
||||||
off += (bus_size_t)bh;
|
|
||||||
|
|
||||||
bus_space_write_stream_2(sc->sc_bust, sc->sc_bush, off, val);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: superiovar.h,v 1.2 2002/08/26 11:04:45 scw Exp $ */
|
/* $NetBSD: superiovar.h,v 1.3 2002/08/30 10:57:06 scw Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2002 Wasabi Systems, Inc.
|
* Copyright 2002 Wasabi Systems, Inc.
|
||||||
@ -59,6 +59,8 @@ struct superio_attach_args {
|
|||||||
bus_space_tag_t saa_bust;
|
bus_space_tag_t saa_bust;
|
||||||
bus_addr_t saa_offset;
|
bus_addr_t saa_offset;
|
||||||
int saa_irq;
|
int saa_irq;
|
||||||
|
|
||||||
|
bus_addr_t _saa_base;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* _EVBSH5_SUPERIOVAR_H */
|
#endif /* _EVBSH5_SUPERIOVAR_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user