patch-2.4.27 linux-2.4.27/drivers/macintosh/nvram.c
Next file: linux-2.4.27/drivers/md/raid5.c
Previous file: linux-2.4.27/drivers/macintosh/ans-lcd.c
Back to the patch index
Back to the overall index
- Lines: 39
- Date:
2004-08-07 16:26:04.863355365 -0700
- Orig file:
linux-2.4.26/drivers/macintosh/nvram.c
- Orig date:
2003-06-13 07:51:34.000000000 -0700
diff -urN linux-2.4.26/drivers/macintosh/nvram.c linux-2.4.27/drivers/macintosh/nvram.c
@@ -37,14 +37,15 @@
static ssize_t read_nvram(struct file *file, char *buf,
size_t count, loff_t *ppos)
{
- unsigned int i;
+ loff_t n = *ppos;
+ unsigned int i = n;
char *p = buf;
if (verify_area(VERIFY_WRITE, buf, count))
return -EFAULT;
- if (*ppos >= NVRAM_SIZE)
+ if (i != n || i >= NVRAM_SIZE)
return 0;
- for (i = *ppos; count > 0 && i < NVRAM_SIZE; ++i, ++p, --count)
+ for (; count > 0 && i < NVRAM_SIZE; ++i, ++p, --count)
if (__put_user(nvram_read_byte(i), p))
return -EFAULT;
*ppos = i;
@@ -54,15 +55,16 @@
static ssize_t write_nvram(struct file *file, const char *buf,
size_t count, loff_t *ppos)
{
- unsigned int i;
+ loff_t n = *ppos;
+ unsigned int i = n;
const char *p = buf;
char c;
if (verify_area(VERIFY_READ, buf, count))
return -EFAULT;
- if (*ppos >= NVRAM_SIZE)
+ if (i != n || i >= NVRAM_SIZE)
return 0;
- for (i = *ppos; count > 0 && i < NVRAM_SIZE; ++i, ++p, --count) {
+ for (; count > 0 && i < NVRAM_SIZE; ++i, ++p, --count) {
if (__get_user(c, p))
return -EFAULT;
nvram_write_byte(c, i);
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)