void afscattach(struct device *pdp, struct device *dp, void *auxp) { struct siop_softc *sc = (struct siop_softc *)dp; struct zbus_args *zap; siop_regmap_p rp; struct scsipi_adapter *adapt = &sc->sc_adapter; struct scsipi_channel *chan = &sc->sc_channel; printf("\n"); zap = auxp; if (zap->manid == 514 && zap->prodid == 84) sc->sc_siopp = rp = (siop_regmap_p)((char *)zap->va + 0x00800000); else sc->sc_siopp = rp = ztwomap(0xdd0040); /* * CTEST7 = 80 [disable burst] */ sc->sc_clock_freq = 50; /* Clock = 50 MHz */ sc->sc_ctest7 = SIOP_CTEST7_CDIS; sc->sc_dcntl = SIOP_DCNTL_EA; /* * Fill in the scsipi_adapter. */ memset(adapt, 0, sizeof(*adapt)); adapt->adapt_dev = &sc->sc_dev; adapt->adapt_nchannels = 1; adapt->adapt_openings = 7; adapt->adapt_max_periph = 1; adapt->adapt_request = siop_scsipi_request; adapt->adapt_minphys = siop_minphys; /* * Fill in the scsipi_channel. */ memset(chan, 0, sizeof(*chan)); chan->chan_adapter = adapt; chan->chan_bustype = &scsi_bustype; chan->chan_channel = 0; chan->chan_ntargets = 8; chan->chan_nluns = 8; chan->chan_id = 7; siopinitialize(sc); sc->sc_isr.isr_intr = afsc_dmaintr; sc->sc_isr.isr_arg = sc; sc->sc_isr.isr_ipl = 2; add_isr (&sc->sc_isr); /* * attach all scsi units on us */ config_found(dp, chan, scsiprint); }
/* * if we are a Commodore Amiga A4091 or possibly an A4000T */ int afscmatch(struct device *pdp, struct cfdata *cfp, void *auxp) { struct zbus_args *zap; siop_regmap_p rp; u_long temp, scratch; zap = auxp; if (zap->manid == 514 && zap->prodid == 84) return(1); /* It's an A4091 SCSI card */ if (!is_a4000() || !matchname("afsc", auxp)) return(0); /* Not on an A4000 or not A4000T SCSI */ rp = ztwomap(0xdd0040); if (badaddr((void *)__UNVOLATILE(&rp->siop_scratch)) || badaddr((void *)__UNVOLATILE(&rp->siop_temp))) { return(0); } scratch = rp->siop_scratch; temp = rp->siop_temp; rp->siop_scratch = 0xdeadbeef; rp->siop_temp = 0xaaaa5555; if (rp->siop_scratch != 0xdeadbeef || rp->siop_temp != 0xaaaa5555) return(0); rp->siop_scratch = scratch; rp->siop_temp = temp; if (rp->siop_scratch != scratch || rp->siop_temp != temp) return(0); return(1); }
/* Get serial number of the card. */ static char * p5bus_cardsn(void) { char *snr, *sn; sn = kmem_zalloc(P5_SN_LEN + 1, KM_SLEEP); snr = (char *)__UNVOLATILE(ztwomap(P5_ROM_OFF)); memcpy(sn, snr, P5_SN_LEN); return sn; }
static void gencp_acafh_attach(device_t parent, device_t self, void *aux) { struct gencp_softc *sc; struct bus_space_tag cpb_bst; struct clockportbus_attach_args cpb_aa; struct acafhbus_attach_args *aaa_aa; aaa_aa = aux; sc = device_private(self); sc->sc_dev = self; sc->cpb_aa = &cpb_aa; /* Set the address and bus access methods. */ cpb_bst.base = (bus_addr_t) __UNVOLATILE(ztwomap(aaa_aa->aaa_pbase)); cpb_bst.absm = &amiga_bus_stride_4; sc->cpb_aa->cp_iot = &cpb_bst; gencp_attach(sc); }
void wdc_amiga_attach(device_t parent, device_t self, void *aux) { struct wdc_amiga_softc *sc = device_private(self); struct wdc_regs *wdr; int i; aprint_normal("\n"); sc->sc_wdcdev.sc_atac.atac_dev = self; sc->sc_wdcdev.regs = wdr = &sc->sc_wdc_regs; gayle_init(); if (is_a4000()) { sc->cmd_iot.base = (bus_addr_t) ztwomap(GAYLE_IDE_BASE_A4000 + 2); } else { sc->cmd_iot.base = (bus_addr_t) ztwomap(GAYLE_IDE_BASE + 2); } sc->cmd_iot.absm = sc->ctl_iot.absm = &amiga_bus_stride_4swap; wdr->cmd_iot = &sc->cmd_iot; wdr->ctl_iot = &sc->ctl_iot; if (bus_space_map(wdr->cmd_iot, 0, 0x40, 0, &wdr->cmd_baseioh)) { aprint_error_dev(self, "couldn't map registers\n"); return; } for (i = 0; i < WDC_NREG; i++) { if (bus_space_subregion(wdr->cmd_iot, wdr->cmd_baseioh, i, i == 0 ? 4 : 1, &wdr->cmd_iohs[i]) != 0) { bus_space_unmap(wdr->cmd_iot, wdr->cmd_baseioh, 0x40); aprint_error_dev(self, "couldn't map registers\n"); return; } } if (bus_space_subregion(wdr->cmd_iot, wdr->cmd_baseioh, 0x406, 1, &wdr->ctl_ioh)) return; sc->sc_wdcdev.sc_atac.atac_cap = ATAC_CAP_DATA16; sc->sc_wdcdev.sc_atac.atac_pio_cap = 0; sc->sc_chanlist[0] = &sc->sc_channel; sc->sc_wdcdev.sc_atac.atac_channels = sc->sc_chanlist; sc->sc_wdcdev.sc_atac.atac_nchannels = 1; sc->sc_wdcdev.wdc_maxdrives = 2; sc->sc_channel.ch_channel = 0; sc->sc_channel.ch_atac = &sc->sc_wdcdev.sc_atac; sc->sc_channel.ch_queue = &sc->sc_chqueue; wdc_init_shadow_regs(&sc->sc_channel); sc->sc_isr.isr_intr = wdc_amiga_intr; sc->sc_isr.isr_arg = sc; sc->sc_isr.isr_ipl = 2; add_isr (&sc->sc_isr); if (!is_a4000()) gayle_intr_enable_set(GAYLE_INT_IDE); wdcattach(&sc->sc_channel); }