summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc64/dev/psycho.c30
-rw-r--r--sys/arch/sparc64/dev/psychovar.h3
2 files changed, 22 insertions, 11 deletions
diff --git a/sys/arch/sparc64/dev/psycho.c b/sys/arch/sparc64/dev/psycho.c
index 3cba3abf781..b97fa5f7724 100644
--- a/sys/arch/sparc64/dev/psycho.c
+++ b/sys/arch/sparc64/dev/psycho.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: psycho.c,v 1.57 2008/05/24 20:57:46 kettenis Exp $ */
+/* $OpenBSD: psycho.c,v 1.58 2008/05/24 23:31:37 kettenis Exp $ */
/* $NetBSD: psycho.c,v 1.39 2001/10/07 20:30:41 eeh Exp $ */
/*
@@ -187,8 +187,8 @@ struct psycho_type {
{ "SUNW,sabre", PSYCHO_MODE_SABRE },
{ "pci108e,a000", PSYCHO_MODE_SABRE },
{ "pci108e,a001", PSYCHO_MODE_SABRE },
- { "pci10cf,138f", PSYCHO_MODE_PSYCHO },
- { "pci10cf,1390", PSYCHO_MODE_PSYCHO },
+ { "pci10cf,138f", PSYCHO_MODE_CMU_CH },
+ { "pci10cf,1390", PSYCHO_MODE_CMU_CH },
{ NULL, 0 }
};
@@ -272,7 +272,8 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
*/
/* Register layouts are different. stuupid. */
- if (sc->sc_mode == PSYCHO_MODE_PSYCHO) {
+ if (sc->sc_mode == PSYCHO_MODE_PSYCHO ||
+ sc->sc_mode == PSYCHO_MODE_CMU_CH) {
sc->sc_basepaddr = (paddr_t)ma->ma_reg[2].ur_paddr;
if (ma->ma_naddress > 2) {
@@ -308,7 +309,8 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
csr = psycho_psychoreg_read(sc, psy_csr);
sc->sc_ign = INTMAP_IGN; /* APB IGN is always 0x1f << 6 = 0x7c */
- if (sc->sc_mode == PSYCHO_MODE_PSYCHO)
+ if (sc->sc_mode == PSYCHO_MODE_PSYCHO ||
+ sc->sc_mode == PSYCHO_MODE_CMU_CH)
sc->sc_ign = PSYCHO_GCSR_IGN(csr) << 6;
printf(": %s, impl %d, version %d, ign %x\n", ptype->p_name,
@@ -376,7 +378,10 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
/* allocate our tags */
pp->pp_memt = psycho_alloc_mem_tag(pp);
pp->pp_iot = psycho_alloc_io_tag(pp);
- pp->pp_dmat = psycho_alloc_dma_tag(pp);
+ if (sc->sc_mode == PSYCHO_MODE_CMU_CH)
+ pp->pp_dmat = ma->ma_dmatag;
+ else
+ pp->pp_dmat = psycho_alloc_dma_tag(pp);
pp->pp_flags = (pp->pp_memt ? PCI_FLAGS_MEM_ENABLED : 0) |
(pp->pp_iot ? PCI_FLAGS_IO_ENABLED : 0);
@@ -422,7 +427,8 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
psycho_psychoreg_vaddr(sc, power_int_map),
psycho_psychoreg_vaddr(sc, power_clr_int), "powerfail");
#endif
- if (sc->sc_mode == PSYCHO_MODE_PSYCHO) {
+ if (sc->sc_mode == PSYCHO_MODE_PSYCHO ||
+ sc->sc_mode == PSYCHO_MODE_CMU_CH) {
psycho_set_intr(sc, 15, psycho_bus_b,
psycho_psychoreg_vaddr(sc, pciberr_int_map),
psycho_psychoreg_vaddr(sc, pciberr_clr_int),
@@ -489,8 +495,11 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
/* Point out iommu at the strbuf_ctl. */
sc->sc_is->is_sb[0] = &pp->pp_sb;
- printf("%s: ", sc->sc_dev.dv_xname);
- psycho_iommu_init(sc, 2);
+ /* CMU-CH doesn't have an IOMMU. */
+ if (sc->sc_mode != PSYCHO_MODE_CMU_CH) {
+ printf("%s: ", sc->sc_dev.dv_xname);
+ psycho_iommu_init(sc, 2);
+ }
sc->sc_configtag = psycho_alloc_config_tag(sc->sc_psycho_this);
if (bus_space_map(sc->sc_configtag,
@@ -557,7 +566,8 @@ psycho_attach(struct device *parent, struct device *self, void *aux)
pba.pba_pc->conf_write = psycho_conf_write;
pba.pba_pc->intr_map = psycho_intr_map;
- if (sc->sc_mode == PSYCHO_MODE_PSYCHO)
+ if (sc->sc_mode == PSYCHO_MODE_PSYCHO ||
+ sc->sc_mode == PSYCHO_MODE_CMU_CH)
psycho_identify_pbm(sc, pp, &pba);
else
pp->pp_id = PSYCHO_PBM_UNKNOWN;
diff --git a/sys/arch/sparc64/dev/psychovar.h b/sys/arch/sparc64/dev/psychovar.h
index 0bae3d40d45..d9b0ac946c2 100644
--- a/sys/arch/sparc64/dev/psychovar.h
+++ b/sys/arch/sparc64/dev/psychovar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: psychovar.h,v 1.6 2003/05/16 06:59:12 henric Exp $ */
+/* $OpenBSD: psychovar.h,v 1.7 2008/05/24 23:31:37 kettenis Exp $ */
/* $NetBSD: psychovar.h,v 1.6 2001/07/20 00:07:13 eeh Exp $ */
/*
@@ -115,6 +115,7 @@ struct psycho_softc {
int sc_mode; /* (whatareya?) */
#define PSYCHO_MODE_SABRE 1 /* i'm a sabre (yob) */
#define PSYCHO_MODE_PSYCHO 2 /* i'm a psycho (w*nker) */
+#define PSYCHO_MODE_CMU_CH 3 /* i'm a CMU-CH (castrate) */
struct iommu_state *sc_is;
};