diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2008-12-21 19:40:42 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2008-12-21 19:40:42 +0000 |
commit | b69e2f1d5297e16abd52798283c22900870ae240 (patch) | |
tree | ebe166c0aedad7a5c315def7555706fa02df7657 /sys/arch | |
parent | ee5179aeb4781dd03c2c9b2ad68ae72b119a6f17 (diff) |
Make the "machine xir" ddb command work on machines with pyro(4).
tested by deraadt@
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sparc64/dev/pyro.c | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/sys/arch/sparc64/dev/pyro.c b/sys/arch/sparc64/dev/pyro.c index 5570e623027..8f8fa75052d 100644 --- a/sys/arch/sparc64/dev/pyro.c +++ b/sys/arch/sparc64/dev/pyro.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pyro.c,v 1.14 2008/07/12 13:08:04 kettenis Exp $ */ +/* $OpenBSD: pyro.c,v 1.15 2008/12/21 19:40:41 kettenis Exp $ */ /* * Copyright (c) 2002 Jason L. Wright (jason@thought.net) @@ -38,6 +38,10 @@ #include <machine/bus.h> #include <machine/autoconf.h> +#ifdef DDB +#include <machine/db_machdep.h> +#endif + #include <dev/pci/pcivar.h> #include <dev/pci/pcireg.h> @@ -56,6 +60,10 @@ int pyro_debug = ~0; #define DPRINTF(l, s) #endif +#define FIRE_RESET_GEN 0x7010 + +#define FIRE_RESET_GEN_XIR 0x0000000000000002L + #define FIRE_INTRMAP_INT_CNTRL_NUM_MASK 0x000003c0 #define FIRE_INTRMAP_INT_CNTRL_NUM0 0x00000040 #define FIRE_INTRMAP_INT_CNTRL_NUM1 0x00000080 @@ -98,6 +106,10 @@ void *_pyro_intr_establish(bus_space_tag_t, bus_space_tag_t, int, int, int, int pyro_dmamap_create(bus_dma_tag_t, bus_dma_tag_t, bus_size_t, int, bus_size_t, bus_size_t, int, bus_dmamap_t *); +#ifdef DDB +void pyro_xir(void *, int); +#endif + int pyro_match(struct device *parent, void *match, void *aux) { @@ -214,6 +226,10 @@ pyro_init(struct pyro_softc *sc, int busa) free(busranges, M_DEVBUF); +#ifdef DDB + db_register_xir(pyro_xir, sc); +#endif + config_found(&sc->sc_dv, &pba, pyro_print); } @@ -539,6 +555,17 @@ _pyro_intr_establish(bus_space_tag_t t, bus_space_tag_t t0, int ihandle, return (ih); } +#ifdef DDB +void +pyro_xir(void *arg, int cpu) +{ + struct pyro_softc *sc = arg; + + bus_space_write_8(sc->sc_bust, sc->sc_xbch, FIRE_RESET_GEN, + FIRE_RESET_GEN_XIR); +} +#endif + const struct cfattach pyro_ca = { sizeof(struct pyro_softc), pyro_match, pyro_attach }; |