mtd raw nand denali.c broken for Intel/Altera Cyclone V
From: Tim Sander
Date: Fri Sep 06 2019 - 08:45:06 EST
Hi
I have noticed that there multiple breakages piling up for the denali nand
driver on the Intel/Altera Cyclone V. Unfortunately i had no time to track the
mainline kernel closely. So the breakage seems to pile up. I am a little
disapointed that Intel is not on the lookout that the kernel works on the
chips they are selling. I was really happy about the state of the platform
before concerning mainline support.
The failure starts with kernel 4.19 or stable kernel release 4.18.19. The
commit is ba4a1b62a2d742df9e9c607ac53b3bf33496508f. The problem here is that
our platform works with a zero in the SPARE_AREA_SKIP_BYTES register. But in
this case the patch assumes the default value 8 which is straight out wrong
on this variant. Without this patch reverted all blocks of the nand flash are
beeing marked bad :-(.
When reverting the patch ba4a1b62a2d742df9e9c607ac53b3bf33496508f i can boot
4.19.10 again.
With 5.0 the it goes further down the drain and i didn't manage to boot it
even with the above patch reverted.
I also tried 5.3-rc7 with the above patch reverted and the variable t_x dirty hacked to the
value 0x1388 as i got the impression that the timing calculation is off too. I still get an
interrupt error and boot failure:
[ 0.817588] nand: device found, Manufacturer ID: 0x2c, Chip ID: 0xda
[ 0.823946] nand: Micron MT29F2G08ABAEAWP
[ 0.827965] nand: 256 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64
[ 1.887052] denali-nand-dt ff900000.nand: timeout while waiting for irq 0x1000
[ 2.911056] denali-nand-dt ff900000.nand: timeout while waiting for irq 0x1000
I have seen this https://lore.kernel.org/patchwork/patch/983055/ thread and
this might fix at least the 4.19 boot problem.
I would be really happy for hints how to get the Intel Cyclone V working again.
Best regards
Tim