|
@@ -1,7 +1,7 @@
|
|
|
/*
|
|
|
* U-boot - flash.c Flash driver for PSD4256GV
|
|
|
*
|
|
|
- * Copyright (c) 2005 blackfin.uclinux.org
|
|
|
+ * Copyright (c) 2005-2007 Analog Devices Inc.
|
|
|
* This file is based on BF533EzFlash.c originally written by Analog Devices, Inc.
|
|
|
*
|
|
|
* (C) Copyright 2000-2004
|
|
@@ -22,8 +22,8 @@
|
|
|
*
|
|
|
* 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., 59 Temple Place, Suite 330, Boston,
|
|
|
- * MA 02111-1307 USA
|
|
|
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
|
|
|
+ * MA 02110-1301 USA
|
|
|
*/
|
|
|
|
|
|
#include <asm/io.h>
|
|
@@ -178,63 +178,66 @@ int flash_erase(flash_info_t * info, int s_first, int s_last)
|
|
|
int write_buff(flash_info_t * info, uchar * src, ulong addr, ulong cnt)
|
|
|
{
|
|
|
int ret;
|
|
|
-
|
|
|
- ret = write_data(addr, cnt, 1, (int *)src);
|
|
|
+ int d;
|
|
|
+ if (addr % 2) {
|
|
|
+ read_flash(addr - 1 - CFG_FLASH_BASE, &d);
|
|
|
+ d = (int)((d & 0x00FF) | (*src++ << 8));
|
|
|
+ ret = write_data(addr - 1, 2, (uchar *) & d);
|
|
|
+ if (ret == FLASH_FAIL)
|
|
|
+ return ERR_NOT_ERASED;
|
|
|
+ ret = write_data(addr + 1, cnt - 1, src);
|
|
|
+ } else
|
|
|
+ ret = write_data(addr, cnt, src);
|
|
|
if (ret == FLASH_FAIL)
|
|
|
return ERR_NOT_ERASED;
|
|
|
return FLASH_SUCCESS;
|
|
|
}
|
|
|
|
|
|
-int write_data(long lStart, long lCount, long lStride, int *pnData)
|
|
|
+int write_data(long lStart, long lCount, uchar * pnData)
|
|
|
{
|
|
|
long i = 0;
|
|
|
- int j = 0;
|
|
|
unsigned long ulOffset = lStart - CFG_FLASH_BASE;
|
|
|
int d;
|
|
|
- int iShift = 0;
|
|
|
- int iNumWords = 2;
|
|
|
- int nLeftover = lCount % 4;
|
|
|
int nSector = 0;
|
|
|
+ int flag = 0;
|
|
|
|
|
|
- for (i = 0; (i < lCount / 4) && (i < BUFFER_SIZE); i++) {
|
|
|
- for (iShift = 0, j = 0; (j < iNumWords);
|
|
|
- j++, ulOffset += (lStride * 2)) {
|
|
|
- if ((ulOffset >= INVALIDLOCNSTART)
|
|
|
- && (ulOffset < INVALIDLOCNEND)) {
|
|
|
- printf
|
|
|
- ("Invalid locations, Try writing to another location \n");
|
|
|
- return FLASH_FAIL;
|
|
|
- }
|
|
|
- get_sector_number(ulOffset, &nSector);
|
|
|
- read_flash(ulOffset, &d);
|
|
|
- if (d != 0xffff) {
|
|
|
- printf
|
|
|
- ("Flash not erased at offset 0x%x Please erase to reprogram \n",
|
|
|
- ulOffset);
|
|
|
- return FLASH_FAIL;
|
|
|
- }
|
|
|
- unlock_flash(ulOffset);
|
|
|
- if (write_flash(ulOffset, (pnData[i] >> iShift)) < 0) {
|
|
|
- printf("Error programming the flash \n");
|
|
|
- return FLASH_FAIL;
|
|
|
- }
|
|
|
- iShift += 16;
|
|
|
- }
|
|
|
+ if (lCount % 2) {
|
|
|
+ flag = 1;
|
|
|
+ lCount = lCount - 1;
|
|
|
}
|
|
|
- if (nLeftover > 0) {
|
|
|
- if ((ulOffset >= INVALIDLOCNSTART)
|
|
|
- && (ulOffset < INVALIDLOCNEND))
|
|
|
+
|
|
|
+ for (i = 0; i < lCount - 1; i += 2, ulOffset += 2) {
|
|
|
+ get_sector_number(ulOffset, &nSector);
|
|
|
+ read_flash(ulOffset, &d);
|
|
|
+ if (d != 0xffff) {
|
|
|
+ printf
|
|
|
+ ("Flash not erased at offset 0x%x Please erase to reprogram \n",
|
|
|
+ ulOffset);
|
|
|
return FLASH_FAIL;
|
|
|
+ }
|
|
|
+ unlock_flash(ulOffset);
|
|
|
+ d = (int)(pnData[i] | pnData[i + 1] << 8);
|
|
|
+ write_flash(ulOffset, d);
|
|
|
+ if (poll_toggle_bit(ulOffset) < 0) {
|
|
|
+ printf("Error programming the flash \n");
|
|
|
+ return FLASH_FAIL;
|
|
|
+ }
|
|
|
+ if ((i > 0) && (!(i % AFP_SectorSize2)))
|
|
|
+ printf(".");
|
|
|
+ }
|
|
|
+ if (flag) {
|
|
|
get_sector_number(ulOffset, &nSector);
|
|
|
read_flash(ulOffset, &d);
|
|
|
if (d != 0xffff) {
|
|
|
printf
|
|
|
- ("Flash already programmed. Please erase to reprogram \n");
|
|
|
- printf("uloffset = 0x%x \t d = 0x%x\n", ulOffset, d);
|
|
|
+ ("Flash not erased at offset 0x%x Please erase to reprogram \n",
|
|
|
+ ulOffset);
|
|
|
return FLASH_FAIL;
|
|
|
}
|
|
|
unlock_flash(ulOffset);
|
|
|
- if (write_flash(ulOffset, pnData[i]) < 0) {
|
|
|
+ d = (int)(pnData[i] | (d & 0xFF00));
|
|
|
+ write_flash(ulOffset, d);
|
|
|
+ if (poll_toggle_bit(ulOffset) < 0) {
|
|
|
printf("Error programming the flash \n");
|
|
|
return FLASH_FAIL;
|
|
|
}
|