2 * YAFFS: Yet another FFS. A NAND-flash specific file system.
3 * mkyaffs.c Format a chunk of NAND for YAFFS.
5 * Copyright (C) 2002 Aleph One Ltd.
6 * for Toby Churchill Ltd and Brightstar Engineering
8 * Created by Charles Manning <charles@aleph1.co.uk>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * published by the Free Software Foundation.
15 * This file is crafted from nandtest.c by Miguel Freitas (miguel@cetuc.puc-rio.br)
16 * and Steven J. Hill (sjhill@cotw.com)
19 * Formatting a YAFFS device is very simple. Just erase all undamaged blocks.
20 * NB Don't erase blocks maked as damaged.
31 #include <sys/ioctl.h>
32 #include <sys/types.h>
33 #include <asm/types.h>
34 #include <linux/config.h>
35 #include <linux/mtd/mtd.h>
38 // countBits is a quick way of counting the number of bits in a byte.
39 // ie. countBits[n] holds the number of 1 bits in a byte with the value n.
41 static const char countBits[256] =
43 0,1,1,2,1,2,2,3,1,2,2,3,2,3,3,4,
44 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5,
45 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5,
46 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
47 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5,
48 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
49 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
50 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7,
51 1,2,2,3,2,3,3,4,2,3,3,4,3,4,4,5,
52 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
53 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
54 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7,
55 2,3,3,4,3,4,4,5,3,4,4,5,4,5,5,6,
56 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7,
57 3,4,4,5,4,5,5,6,4,5,5,6,5,6,6,7,
58 4,5,5,6,5,6,6,7,5,6,6,7,6,7,7,8
62 * Buffer arrays used for running tests
65 unsigned char oobbuf[16];
66 unsigned char imgpage[528];
72 int main(int argc, char **argv)
79 struct mtd_oob_buf oob = {0, 16, (unsigned char *) &oobbuf};
83 /* Make sure a device was specified */
85 printf("usage: %s <mtdname> [image name]\n", argv[0]);
90 (img = open(argv[2],O_RDONLY)) == -1) {
91 perror("opening image file");
96 imglen = lseek(img,0,SEEK_END);
98 printf("Image not a multiple of 528 bytes\n");
103 lseek(img,0,SEEK_SET);
105 /* Open the device */
106 if((fd = open(argv[1], O_RDWR)) == -1) {
107 perror("opening flash");
111 /* Fill in MTD device capability structure */
112 if(ioctl(fd, MEMGETINFO, &meminfo) != 0) {
113 perror("MEMGETINFO");
118 /* Make sure device page sizes are valid */
119 if( !(meminfo.oobsize == 16 && meminfo.oobblock == 512))
121 printf("Unknown flash (not normal NAND)\n");
127 (imglen/528 +32)*512 > meminfo.size){
128 printf("Image is too big for NAND\n");
133 printf("Erasing and programming NAND\n");
134 for(addr = 0; addr < meminfo.size; addr += meminfo.erasesize)
136 /* Read the OOB data to determine if the block is valid.
137 * If the block is damaged, then byte 5 of the OOB data will
138 * have at least 2 zero bits.
143 if (ioctl(fd, MEMREADOOB, &oob) != 0)
145 perror("ioctl(MEMREADOOB)");
150 if(countBits[oobbuf[5]] < 7)
152 printf("Block at 0x08%lx is damaged and is not being formatted\n",addr);
156 /* Erase this block */
158 erase.length = meminfo.erasesize;
159 printf("Erasing block at 0x08%lx\n",addr);
160 if(ioctl(fd, MEMERASE, &erase) != 0)
162 perror("\nMTD Erase failure\n");
167 /* Do some programming, but not in the first block */
170 for(offset = 0; offset <meminfo.erasesize; offset+=512)
172 if(read(img,imgpage,528) == 528){
173 lseek(fd,addr+offset,SEEK_SET);
174 write(fd,imgpage,512);
175 oob.start = addr+offset;
177 oob.ptr=&imgpage[512];
178 ioctl(fd,MEMWRITEOOB,&oob);
189 /* All the tests succeeded */