w49f002u.c 2.68 KB
Newer Older
Andrew Ip's avatar
Andrew Ip committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
/*
 * w49f002u.c: driver for Winbond 49F002U flash models
 *
 *
 * Copyright 2000 Silicon Integrated System Corporation
 *
 *	This program is free software; you can redistribute it and/or modify
 *	it under the terms of the GNU General Public License as published by
 *	the Free Software Foundation; either version 2 of the License, or
 *	(at your option) any later version.
 *
 *	This program is distributed in the hope that it will be useful,
 *	but WITHOUT ANY WARRANTY; without even the implied warranty of
 *	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *	GNU General Public License for more details.
 *
 *	You should have received a copy of the GNU General Public License
 *	along with this program; if not, write to the Free Software
 *	Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 *
 * Reference:
 *	W49F002U data sheet
 *
 * $Id
 */

Ronald G. Minnich's avatar
Ronald G. Minnich committed
28
#include <stdio.h>
Andrew Ip's avatar
Andrew Ip committed
29 30
#include "flash.h"
#include "jedec.h"
Ronald G. Minnich's avatar
Ronald G. Minnich committed
31
#include "w49f002u.h"
Andrew Ip's avatar
Andrew Ip committed
32 33 34 35

int probe_49f002 (struct flashchip * flash)
{
	volatile char * bios = flash->virt_addr;
Ronald G. Minnich's avatar
Ronald G. Minnich committed
36
	unsigned char id1, id2;
Andrew Ip's avatar
Andrew Ip committed
37 38 39 40 41 42 43 44 45 46 47 48

	*(bios + 0x5555) = 0xAA;
	*(bios + 0x2AAA) = 0x55;
	*(bios + 0x5555) = 0x90;
    
	id1 = *(volatile unsigned char *) bios;
	id2 = *(volatile unsigned char *) (bios + 0x01);
 
	*bios = 0xF0;

	myusec_delay(10);

49 50
	printf("%s: id1 0x%x, id2 0x%x\n", __FUNCTION__, id1, id2);	

Andrew Ip's avatar
Andrew Ip committed
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
	if (id1 == flash->manufacture_id && id2 == flash->model_id)
		return 1;

	return 0;
}

int erase_49f002 (struct flashchip * flash)
{
	volatile char * bios = flash->virt_addr;

	*(bios + 0x5555) = 0xAA;
	*(bios + 0x2AAA) = 0x55;
	*(bios + 0x5555) = 0x80;
	*(bios + 0x5555) = 0xAA;
	*(bios + 0x2AAA) = 0x55;
	*(bios + 0x5555) = 0x10;

	myusec_delay(100);
	toggle_ready_jedec(bios);

	//   while ((*bios & 0x40) != 0x40)
	//;

#if 0
	toggle_ready_jedec(bios);
	*(bios + 0x0ffff) = 0x30;
	*(bios + 0x1ffff) = 0x30;
	*(bios + 0x2ffff) = 0x30;
	*(bios + 0x37fff) = 0x30;
	*(bios + 0x39fff) = 0x30;
	*(bios + 0x3bfff) = 0x30;
#endif

Ronald G. Minnich's avatar
Ronald G. Minnich committed
84
	return(0);
Andrew Ip's avatar
Andrew Ip committed
85 86
}

Ronald G. Minnich's avatar
Ronald G. Minnich committed
87
int write_49f002 (struct flashchip * flash, unsigned char * buf)
Andrew Ip's avatar
Andrew Ip committed
88 89
{
    int i;
Ronald G. Minnich's avatar
Ronald G. Minnich committed
90
    int total_size = flash->total_size * 1024;
Andrew Ip's avatar
Andrew Ip committed
91
    volatile char * bios = flash->virt_addr;
Ronald G. Minnich's avatar
Ronald G. Minnich committed
92
    volatile char * dst = bios;
Andrew Ip's avatar
Andrew Ip committed
93 94 95 96 97 98 99 100 101

    *bios = 0xF0;
    myusec_delay(10);
    erase_49f002(flash);
    //*bios = 0xF0;
#if 1
   printf ("Programming Page: ");
    for (i = 0; i < total_size; i++) {
	/* write to the sector */
Ronald G. Minnich's avatar
Ronald G. Minnich committed
102
	if ((i & 0xfff) == 0)
Ronald G. Minnich's avatar
Ronald G. Minnich committed
103
	    printf ("address: 0x%08lx", (unsigned long)i);
Andrew Ip's avatar
Andrew Ip committed
104 105 106 107 108 109 110 111
	*(bios + 0x5555) = 0xAA;
	*(bios + 0x2AAA) = 0x55;
	*(bios + 0x5555) = 0xA0;
	*dst++ = *buf++;

	/* wait for Toggle bit ready */
	toggle_ready_jedec(dst);

Ronald G. Minnich's avatar
Ronald G. Minnich committed
112 113
	if ((i & 0xfff) == 0)
	    printf ("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
Andrew Ip's avatar
Andrew Ip committed
114 115 116
    }
#endif
    printf("\n");
Ronald G. Minnich's avatar
Ronald G. Minnich committed
117 118

    return(0);
Andrew Ip's avatar
Andrew Ip committed
119
}