On Thu, Oct 2, 2014 at 8:56 AM, Finn Thain <fthain@xxxxxxxxxxxxxxxxxxx> wrote:
Convert mac_scsi to platform device and eliminate scsi_register(). Platform resources for chip registers now follow the documentation. This should fix issues with the Mac IIci (and possibly other models too). Signed-off-by: Finn Thain <fthain@xxxxxxxxxxxxxxxxxxx> --- The new hwreg_present() call is not protected by local_irq_save/restore. This assumes Geert's patch, "Disable/restore interrupts in hwreg_present()/hwreg_write()": http://marc.info/?l=linux-kernel&m=141189640826704&w=2
OK, so this cannot go in before v3.18-rc1.
--- linux.orig/drivers/scsi/mac_scsi.c 2014-10-02 16:56:18.000000000 +1000 +++ linux/drivers/scsi/mac_scsi.c 2014-10-02 16:56:19.000000000 +1000
@@ -480,7 +380,117 @@ static struct scsi_host_template driver_ .use_clustering = DISABLE_CLUSTERING }; +static int __init mac_scsi_probe(struct platform_device *pdev) +{ + struct Scsi_Host *instance; + int error; + int host_flags = 0; + struct resource *irq, *pio_mem, *pdma_mem = NULL; + + if (!MACH_IS_MAC) + return -ENODEV;
This check is not needed, asuming you'll only instantiate the platform device when running on a Mac.
--- linux.orig/arch/m68k/mac/config.c 2014-10-02 16:55:28.000000000 +1000 +++ linux/arch/m68k/mac/config.c 2014-10-02 16:56:19.000000000 +1000
@@ -929,6 +929,36 @@ static struct platform_device swim_pdev .resource = &swim_rsrc, }; +static struct resource mac_scsi_0_rsrc[] = { + { + .flags = IORESOURCE_IRQ, + .start = IRQ_MAC_SCSI, + .end = IRQ_MAC_SCSI, + }, + { .flags = IORESOURCE_MEM }, + { .flags = IORESOURCE_MEM }, +}; + +static struct resource mac_scsi_1_rsrc[] = { + /* IRQ_NUBUS_E maybe? */ + { .flags = IORESOURCE_MEM }, + { .flags = IORESOURCE_MEM }, +}; + +static struct platform_device mac_scsi_0_pdev = { + .name = "mac_scsi", + .id = 0, + .resource = mac_scsi_0_rsrc, + .num_resources = ARRAY_SIZE(mac_scsi_0_rsrc), +}; + +static struct platform_device mac_scsi_1_pdev = { + .name = "mac_scsi", + .id = 1, + .resource = mac_scsi_1_rsrc, + .num_resources = ARRAY_SIZE(mac_scsi_1_rsrc), +}; + static struct platform_device esp_0_pdev = { .name = "mac_esp", .id = 0, @@ -1000,6 +1030,53 @@ int __init mac_platform_init(void) (macintosh_config->ident == MAC_MODEL_Q950)) platform_device_register(&esp_1_pdev); break; + case MAC_SCSI_IIFX: + /* Addresses from The Guide to Mac Family Hardware. */ + mac_scsi_0_rsrc[1].start = 0x50008000; /* SCSI DMA */ + mac_scsi_0_rsrc[1].end = mac_scsi_0_rsrc[1].start + 0x1FFF; + /* $5000 E000 - $5000 FFFF: Alternate SCSI (Hsk) */ + /* $5000 C000 - $5000 DFFF: Alternate SCSI (DMA) */ + /* The SCSI DMA custom IC embeds the 53C80 core. mac_scsi does + * not make use of its DMA or hardware handshaking logic. + */ + mac_scsi_0_pdev.num_resources--; + platform_device_register(&mac_scsi_0_pdev);
What about removing the static mac_scsi_0_pdev and mac_scsi_1_pdev, and calling platform_device_register_simple() instead? That way you (a) don't have to fiddle with mac_scsi_0_pdev.num_resources, and (b) the resources can become const and __initconst, as a copy will be allocated dynamically. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds -- To unsubscribe from this list: send the line "unsubscribe linux-m68k" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html