Il giorno mercoledì 24 dicembre 2014 00:07:25 UTC+1, Michal Suchanek ha 
scritto:
>
> On 23 December 2014 at 16:13,  <scac...@gmail.com <javascript:>> wrote: 
> > Il giorno venerdì 19 dicembre 2014 05:53:18 UTC+1, Yassin Jaffer ha 
> scritto: 
> >> Hi Michal 
> >> This was answered previously by Brezillon . Please search the mailing 
> list.You have to force bad block erasure to get rid of AW's libnand layout 
> >> (which is overriding bad block markers). 
> >> 
> >> Please follow these steps: 
> >> 1) apply this patch [1] 
> >> 2) boot on your new kernel and launch 
> >> $ flash_erase /dev/mtd0 0 0 
> >> 3) revert the patch 
> >> 4) Boot on your new kernel 
> >> 
> >> Most of your bad blocks should be gone after that... 
> >> 
> >> [1]http://code.bulix.org/k2v1hx-87237 
> >> Yes K9GBG08U0A has two variants of the chip ID and maybe more... 
> >> use some printk in the nand_base.c to get more accurate information 
> about your nand. 
> >> 
> >> 
> >> On Fri, Dec 19, 2014 at 7:44 AM, Michal Suchanek <hram...@gmail.com> 
> wrote:On 18 December 2014 at 14:13, Henrik Nordström 
> >> 
> >> <hen...@henriknordstrom.net> wrote: 
> >> 
> >> > tor 2014-12-18 klockan 13:47 +0100 skrev Michal Suchanek: 
> >> 
> >> > 
> >> 
> >> >> Yes, that's what you can obviously do. If the ID listed in the 
> >> 
> >> >> datasheet and the ID read by the kernel does not agree put the ID 
> read 
> >> 
> >> >> in the table. 
> >> 
> >> >> 
> >> 
> >> >> However, how is Joe User with a Chinese tablet supposed to add his 
> NAND chip? 
> >> 
> >> > 
> >> 
> >> > If the chip supports JEDEC identification then it's supposedly 
> >> 
> >> > automatically configured.. sadly it seems most chineese tablets uses 
> >> 
> >> > non-JEDEC identified NAND chips. 
> >> 
> >> > 
> >> 
> >> > If not then one need to go thru the manual process of finding the 
> >> 
> >> > datasheet and try to find needed parameters from there which means 
> >> 
> >> > opening the device to find the NAND chip model, search the Internet 
> for 
> >> 
> >> > a datasheet (if lucky), or find something usable in the Allwinner 
> >> 
> >> > drivers if you can find usable source version. 
> >> 
> >> > 
> >> 
> >> > 
> >> 
> >> >> If a Joe User sent us this datasheet can we fabricate an ID entry 
> form 
> >> 
> >> >> that datasheet alone? How? 
> >> 
> >> > 
> >> 
> >> > Only if the datasheets lists usable identification strings, something 
> >> 
> >> > many get wrong even from well known NAND manufacturers. 
> >> 
> >> > 
> >> 
> >> >> If not should we add a patch to the kernel to always print the full 
> >> 
> >> >> ID? If so how can we believe *anything* in the datasheet if even 
> >> 
> >> >> something as simple and basic as chip ID is wrong? 
> >> 
> >> > 
> >> 
> >> > General timing data should be correct, but... honestly I have even 
> seen 
> >> 
> >> > page size and OOB size being specified wrongly in datasheets. 
> >> 
> >> > 
> >> 
> >> > For many chips finding any reliable information is not easy. 
> >> 
> >> 
> >> 
> >> hmm, the sunxi nand driver has this: 
> >> 
> >> 
> >> 
> >>     //                NAND_CHIP_ID                     DieCnt SecCnt 
> >> 
> >> PagCnt   BlkCnt    OpOpt   DatBlk  Freq   EccMode ReadRetry DDRType 
> >> 
> >> OperationPar 
> >> 
> >>     { {0xec, 0xd5, 0x94, 0x29, 0xff, 0xff, 0xff, 0xff }, 1,     8, 
> >> 
> >> 128,     4096,   0x0008,   974,    30,     0,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9GAG08U0D 
> >> 
> >>     { {0xec, 0xd5, 0x84, 0x72, 0xff, 0xff, 0xff, 0xff }, 1,    16, 
> >> 
> >> 128,     2048,   0x0000,   950,    24,     2,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9GAG08U0E 
> >> 
> >>     { {0xec, 0xd5, 0x94, 0x76, 0x54, 0xff, 0xff, 0xff }, 1,    16, 
> >> 
> >> 128,     2048,   0x0408,   950,    30,     2,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9GAG08U0E 
> >> 
> >>     { {0xec, 0xd3, 0x84, 0x72, 0xff, 0xff, 0xff, 0xff }, 1,    16, 
> >> 
> >> 128,     1024,   0x0000,   950,    24,     2,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9G8G08U0C 
> >> 
> >>     { {0xec, 0xd7, 0x94, 0x76, 0xff, 0xff, 0xff, 0xff }, 1,    16, 
> >> 
> >> 128,     4096,   0x0088,   974,    30,     3,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9GBG08U0A 
> >> 
> >>     { {0xec, 0xd7, 0x94, 0x7A, 0xff, 0xff, 0xff, 0xff }, 1,    16, 
> >> 
> >> 128,     4096,   0x0088,   974,    30,     3,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9GBG08U0A 
> >> 
> >>     { {0xec, 0xde, 0xd5, 0x7A, 0x58, 0xff, 0xff, 0xff }, 2,    16, 
> >> 
> >> 128,     4096,   0x0888,   974,    30,     3,       0,        0, 
> >> 
> >> &PhysicArchiPara3 },   // K9LCG08U0A 
> >> 
> >> where 0x88 looks like NAND_MULTI_PROGRAM | NAND_RANDOM 
> >> 
> >> and 
> >> 
> >>     974      ValidBlkRatio;                      //the valid block 
> >> 
> >> ratio, based on 1024 blocks 
> >> 
> >>     30       AccessFreq;                         //the highest access 
> >> 
> >> frequence of the nand flash chip, based on MHz 
> >> 
> >>     3       EccMode;                            //the Ecc Mode for the 
> >> 
> >> nand flash chip, 0: bch-16, 1:bch-28, 2:bch_32 
> >> 
> >> 
> >> 
> >> So there are two variants of the K9GBG08U0A chip ID there. 
> >> 
> >> 
> >> 
> >> 
> >> 
> >> -- 
> >> 
> >> You received this message because you are subscribed to the Google 
> Groups "linux-sunxi" group. 
> >> 
> >> To unsubscribe from this group and stop receiving emails from it, send 
> an email to linux-sunxi...@googlegroups.com. 
> >> 
> >> For more options, visit https://groups.google.com/d/optout. 
> > 
> > Hello. 
> > I have a cobieboard a10 with 4GB nand K9GBG08U0A. 
> > I tried the kernel 3.18 nand. 
> > I also followed the indications described by XXXX. 
> > I still have many errors "Bad eraseblock ... No space left to write bad 
> block table". 
>
> This is expected. 
> You need to apply the two patches that make the kernel ignore bad 
> blocks, erase flash, and unapply patches. 
>
> Presumably that gets rid of the bogus bad block markers. 
>
> I did not try the patches. Rather I wanted to keep the bogus flash 
> content so that I can add proper kernel option for ignoring these 
> markers that could be set in DT or somewhere and test it. 
>
> Should not be overly difficult but did not get to it so far. 
>
> Such option is obviously needed so that devices can be upgraded from 
> factory installed image to mainline image. 
>
> The general idea is that when the option is set on a partition the 
> kernel would initialize the MTD although all flash is marked bad but 
> would flag it as unusable and only allow erasing it. 
>
> > (flash_erase with kernel & a10 dts modified does not reduce them). 
> > I try a series combination changing nand_ids.c 
> > The proposed configuration for a 32 GB K9GBG08U0A not work for 4GB. 
> > How can I fix it? 
> > ids for 32G 
> >          {"K9GBG08U0A 32G 3.3V 8-bit" 
> >                  .id = {{0xec, 0xd7, 0x94, 0x7a, 0x54, 0x43}}, 
> >                    SZ_8K, SZ_4K, SZ_1M, 0, 6, 640, NAND_ECC_INFO (40, 
> SZ_1K), 0}, 
> > 
> > ids for 4G? 
>
> It's 32gigabits ~ 4gigabytes, presumably. 
>
> > 
> > the kernel SunXi for this chip (4GB) contains a number of parameters 
> that I have difficulty in translating: 
>
> You can just ignore these if you get the complaint about bad blocks. 
> The only interesting bit I found there so far is that the ID seems to 
> be matched by 5 bytes so possibly more variants of the last byte 
> exist. 
>
> Thanks 
>
> Michal 
>


Hi all.
Resolved with 
$ flash_erase -N /dev/mtd0 0 0

Now with nand kernel i see:
/dev/mtd0  
/dev/mtd0ro  
/dev/mtd1  
/dev/mtd1ro  
/dev/mtd2  
/dev/mtd2ro 

$ dmesg
[    5.504107] nand: device found, Manufacturer ID: 0xec, Chip ID: 0xd7
[    5.510466] nand: Samsung K9GBG08U0A 4GB 3.3V 8-bit
[    5.515302] nand: 4096MiB, MLC, page size: 8192, OOB size: 640
[    5.710997] Bad block table not found for chip 0
[    5.768800] Bad block table not found for chip 0
[    5.773425] Scanning device for bad blocks
[    5.828759] Bad eraseblock 0 at 0x0000000fe000
[    5.867883] Bad eraseblock 1 at 0x0000001fe000
[    5.902372] Bad eraseblock 2 at 0x0000002fe000
[    5.948928] Bad eraseblock 3 at 0x0000003fe000
[    6.020716] Bad eraseblock 6 at 0x0000006fe000
[    6.059723] Bad eraseblock 7 at 0x0000007fe000
[    6.988123] random: nonblocking pool is initialized

I tried to use UBI FS on mtd2. But i have this problem.
A long series of this errors:

[ 3653.750288] CPU: 0 PID: 846 Comm: ubiattach Not tainted 3.18.0-gigi+ #10
[ 3653.757031] [<c0014440>] (unwind_backtrace) from [<c00115cc>] 
(show_stack+0x10/0x14)
[ 3653.764775] [<c00115cc>] (show_stack) from [<c0539e7c>] 
(dump_stack+0x88/0x98)
[ 3653.772023] [<c0539e7c>] (dump_stack) from [<c03653a0>] 
(ubi_io_read+0x128/0x304)
[ 3653.779519] [<c03653a0>] (ubi_io_read) from [<c0365788>] 
(ubi_io_read_ec_hdr+0x44/0x210)
[ 3653.787631] [<c0365788>] (ubi_io_read_ec_hdr) from [<c036a038>] 
(ubi_attach+0x150/0x1368)
[ 3653.795849] [<c036a038>] (ubi_attach) from [<c035ff10>] 
(ubi_attach_mtd_dev+0x648/0xc08)
[ 3653.803936] [<c035ff10>] (ubi_attach_mtd_dev) from [<c036144c>] 
(ctrl_cdev_ioctl+0xcc/0x198)
[ 3653.812385] [<c036144c>] (ctrl_cdev_ioctl) from [<c00e80a0>] 
(do_vfs_ioctl+0x3ec/0x5ac)
[ 3653.820395] [<c00e80a0>] (do_vfs_ioctl) from [<c00e8294>] 
(SyS_ioctl+0x34/0x5c)
[ 3653.827710] [<c00e8294>] (SyS_ioctl) from [<c000e3e0>] 
(ret_fast_syscall+0x0/0x30)
[ 3653.882994] UBI warning: ubi_io_read: error -74 (ECC error) while 
reading 64 bytes from PEB 2503:0, read only 64 bytes, retry
[ 3653.927378] UBI warning: ubi_io_read: error -74 (ECC error) while 
reading 64 bytes from PEB 2503:0, read only 64 bytes, retry
[ 3653.975933] UBI warning: ubi_io_read: error -74 (ECC error) while 
reading 64 bytes from PEB 2503:0, read only 64 bytes, retry
[ 3654.020387] UBI error: ubi_io_read: error -74 (ECC error) while reading 
64 bytes from PEB 2503:0, read 64 bytes

any idea ?
Thanks 

-- 
You received this message because you are subscribed to the Google Groups 
"linux-sunxi" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to linux-sunxi+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to