Commit 2d4b9712 authored by Akinobu Mita's avatar Akinobu Mita Committed by Benjamin Herrenschmidt

powerpc/pmac: Use string library in nvram code

- Use memchr_inv to check if the data contains all 0xFF bytes.
  It is faster than looping for each byte.

- Use memcmp to compare memory areas
Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: linuxppc-dev@lists.ozlabs.org
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent ad5b7f13
...@@ -279,7 +279,7 @@ static u32 core99_check(u8* datas) ...@@ -279,7 +279,7 @@ static u32 core99_check(u8* datas)
static int sm_erase_bank(int bank) static int sm_erase_bank(int bank)
{ {
int stat, i; int stat;
unsigned long timeout; unsigned long timeout;
u8 __iomem *base = (u8 __iomem *)nvram_data + core99_bank*NVRAM_SIZE; u8 __iomem *base = (u8 __iomem *)nvram_data + core99_bank*NVRAM_SIZE;
...@@ -301,11 +301,10 @@ static int sm_erase_bank(int bank) ...@@ -301,11 +301,10 @@ static int sm_erase_bank(int bank)
out_8(base, SM_FLASH_CMD_CLEAR_STATUS); out_8(base, SM_FLASH_CMD_CLEAR_STATUS);
out_8(base, SM_FLASH_CMD_RESET); out_8(base, SM_FLASH_CMD_RESET);
for (i=0; i<NVRAM_SIZE; i++) if (memchr_inv(base, 0xff, NVRAM_SIZE)) {
if (base[i] != 0xff) { printk(KERN_ERR "nvram: Sharp/Micron flash erase failed !\n");
printk(KERN_ERR "nvram: Sharp/Micron flash erase failed !\n"); return -ENXIO;
return -ENXIO; }
}
return 0; return 0;
} }
...@@ -336,17 +335,16 @@ static int sm_write_bank(int bank, u8* datas) ...@@ -336,17 +335,16 @@ static int sm_write_bank(int bank, u8* datas)
} }
out_8(base, SM_FLASH_CMD_CLEAR_STATUS); out_8(base, SM_FLASH_CMD_CLEAR_STATUS);
out_8(base, SM_FLASH_CMD_RESET); out_8(base, SM_FLASH_CMD_RESET);
for (i=0; i<NVRAM_SIZE; i++) if (memcmp(base, datas, NVRAM_SIZE)) {
if (base[i] != datas[i]) { printk(KERN_ERR "nvram: Sharp/Micron flash write failed !\n");
printk(KERN_ERR "nvram: Sharp/Micron flash write failed !\n"); return -ENXIO;
return -ENXIO; }
}
return 0; return 0;
} }
static int amd_erase_bank(int bank) static int amd_erase_bank(int bank)
{ {
int i, stat = 0; int stat = 0;
unsigned long timeout; unsigned long timeout;
u8 __iomem *base = (u8 __iomem *)nvram_data + core99_bank*NVRAM_SIZE; u8 __iomem *base = (u8 __iomem *)nvram_data + core99_bank*NVRAM_SIZE;
...@@ -382,12 +380,11 @@ static int amd_erase_bank(int bank) ...@@ -382,12 +380,11 @@ static int amd_erase_bank(int bank)
/* Reset */ /* Reset */
out_8(base, 0xf0); out_8(base, 0xf0);
udelay(1); udelay(1);
for (i=0; i<NVRAM_SIZE; i++) if (memchr_inv(base, 0xff, NVRAM_SIZE)) {
if (base[i] != 0xff) { printk(KERN_ERR "nvram: AMD flash erase failed !\n");
printk(KERN_ERR "nvram: AMD flash erase failed !\n"); return -ENXIO;
return -ENXIO; }
}
return 0; return 0;
} }
...@@ -429,11 +426,10 @@ static int amd_write_bank(int bank, u8* datas) ...@@ -429,11 +426,10 @@ static int amd_write_bank(int bank, u8* datas)
out_8(base, 0xf0); out_8(base, 0xf0);
udelay(1); udelay(1);
for (i=0; i<NVRAM_SIZE; i++) if (memcmp(base, datas, NVRAM_SIZE)) {
if (base[i] != datas[i]) { printk(KERN_ERR "nvram: AMD flash write failed !\n");
printk(KERN_ERR "nvram: AMD flash write failed !\n"); return -ENXIO;
return -ENXIO; }
}
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment