[pasemi] Internal CompactFlash (CF) card device not recognised after the powerpc-4.8-1 merge

Christian Zigotzky chzigotzky at xenosoft.de
Fri Aug 5 21:41:30 AEST 2016


Hi All,

The internal PASEMI CompactFlash (CF) card device doesn't work anymore 
after the powerpc-4.8-1 merge. That means the code for the internal CF 
card device in the Nemo patch doesn't work after the first PowerPC 
merge. The CompactFlash (CF) card slot is wired to the CPU local bus. It 
is typically used to hold the Linux kernel. I know it isn't well to use 
an own patch for that but I think it is a good time to integrate the 
PASEMI internal CompactFlash (CF) card device to the official kernel. 
What do you think? I am not a programmer so I can't integrate the source 
code for the internal CF card device. But maybe you can take the patch 
and integrate it.

We use the following patch for the kernel 4.7:

     diff -rupN a/drivers/ata/pata_of_platform.c 
b/drivers/ata/pata_of_platform.c
     --- a/drivers/ata/pata_of_platform.c   2016-08-05 
09:58:41.410569036 +0200
     +++ b/drivers/ata/pata_of_platform.c   2016-08-05 
09:59:54.414288884 +0200
     @@ -41,14 +41,36 @@ static int pata_of_platform_probe(struct
            return -EINVAL;
         }

     -   ret = of_address_to_resource(dn, 1, &ctl_res);
     -   if (ret) {
     -      dev_err(&ofdev->dev, "can't get CTL address from "
     -         "device tree\n");
     -      return -EINVAL;
     +   if (of_device_is_compatible(dn, "electra-ide")) {
     +      /* Altstatus is really at offset 0x3f6 from the primary window
     +       * on electra-ide. Adjust ctl_res and io_res accordingly.
     +       */
     +      ctl_res = io_res;
     +      ctl_res.start = ctl_res.start+0x3f6;
     +      io_res.end = ctl_res.start-1;
     +
     +#ifdef CONFIG_PPC_PASEMI_SB600
     +       } else if (of_device_is_compatible(dn, "electra-cf")) {
     +               /* Task regs are at 0x800, with alt status @ 0x80e 
in the primary window
     +                * on electra-cf. Adjust ctl_res and io_res 
accordingly.
     +                */
     +               ctl_res = io_res;
     +               io_res.start += 0x800;
     +               ctl_res.start = ctl_res.start + 0x80e;
     +               io_res.end = ctl_res.start-1;
     +#endif
     +   } else {
     +      ret = of_address_to_resource(dn, 1, &ctl_res);
     +      if (ret) {
     +         dev_err(&ofdev->dev, "can't get CTL address from "
     +            "device tree\n");
     +         return -EINVAL;
     +      }
         }

         irq_res = platform_get_resource(ofdev, IORESOURCE_IRQ, 0);
     +   if (irq_res)
     +      irq_res->flags = 0;

         prop = of_get_property(dn, "reg-shift", NULL);
         if (prop)
     @@ -65,6 +87,11 @@ static int pata_of_platform_probe(struct
            dev_info(&ofdev->dev, "pio-mode unspecified, assuming PIO0\n");
         }

     +#ifdef CONFIG_PPC_PASEMI_SB600
     +       irq_res = 0;                    // force irq off (doesn't 
seem to work)
     +#endif
     +
     +
         pio_mask = 1 << pio_mode;
         pio_mask |= (1 << pio_mode) - 1;

     @@ -74,7 +101,11 @@ static int pata_of_platform_probe(struct

      static struct of_device_id pata_of_platform_match[] = {
         { .compatible = "ata-generic", },
     -   { },
     +   { .compatible = "electra-ide", },
     +#ifdef CONFIG_PPC_PASEMI_SB600
     +       { .compatible = "electra-cf",},
     +#endif
     +   {},
      };
      MODULE_DEVICE_TABLE(of, pata_of_platform_match);

dmesg with the kernel 4.7:

zcat /var/log/dmesg.1.gz | grep -i ata7

     [    2.939788] ata7: PATA max PIO0 no IRQ, using PIO polling mmio 
cmd 0xf0000800 ctl 0xf000080e
     [    3.099186] ata7.00: CFA: SanDisk SDCFB-256, HDX 2.33, max PIO4
     [    3.099191] ata7.00: 501760 sectors, multi 0: LBA
     [    3.099199] ata7.00: configured for PIO

The dmesg of the latest Git kernel doesn't have any output of our 
internal CF card device.

Could you please integrate our PASEMI CF card device again?

Thanks,

Christian



More information about the Linuxppc-dev mailing list