*/
unsigned char oobbuf[16];
+unsigned char imgpage[528];
/*
int main(int argc, char **argv)
{
unsigned long addr;
+ unsigned long offset;
int bs, fd, i;
+ int img=-1;
+ int imglen = 0;
struct mtd_oob_buf oob = {0, 16, (unsigned char *) &oobbuf};
mtd_info_t meminfo;
erase_info_t erase;
/* Make sure a device was specified */
if(argc < 2) {
- printf("usage: %s <mtdname>\n", argv[0]);
+ printf("usage: %s <mtdname> [image name]\n", argv[0]);
exit(1);
}
+
+ if(argc > 2 &&
+ (img = open(argv[2],O_RDONLY)) == -1) {
+ perror("opening image file");
+ exit(1);
+ }
+
+ if(img >= 0){
+ imglen = lseek(img,0,SEEK_END);
+ if(imglen %528){
+ printf("Image not a multiple of 528 bytes\n");
+ exit(1);
+ }
+ }
+
+ lseek(img,0,SEEK_SET);
/* Open the device */
if((fd = open(argv[1], O_RDWR)) == -1) {
- perror("open flash");
+ perror("opening flash");
exit(1);
}
exit(1);
}
+ if(imglen >= 0 &&
+ (imglen/528 +32)*512 > meminfo.size){
+ printf("Image is too big for NAND\n");
+ exit(1);
+ }
+
+ printf("Erasing and programming NAND\n");
for(addr = 0; addr < meminfo.size; addr += meminfo.erasesize)
{
/* Read the OOB data to determine if the block is valid.
exit(1);
}
+ /* Do some programming, but not in the first block */
+
+ if(addr){
+ for(offset = 0; offset <meminfo.erasesize; offset+=512)
+ {
+ if(read(img,imgpage,528) == 528){
+ lseek(fd,addr+offset,SEEK_SET);
+ write(fd,imgpage,512);
+ oob.start = addr+offset;
+ oob.length=16;
+ oob.ptr=&imgpage[512];
+ ioctl(fd,MEMWRITEOOB,&oob);
+ }
+ }
+ }
+
}
}
+
/* All the tests succeeded */
printf("OK\n");
close(fd);