summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtem Bityutskiy <artem.bityutskiy@linux.intel.com>2011-12-28 17:14:49 +0100
committerDavid Woodhouse <David.Woodhouse@intel.com>2012-01-09 19:25:54 +0100
commit9cf075f8656524abc44ad3ff2ec3834fe76f186f (patch)
treef4d1bc3254b24d3f032134088ba83f9e79a6a01b
parentmtd: doc: do not initialize mtd_info fields to 0 or NULL (diff)
downloadlinux-9cf075f8656524abc44ad3ff2ec3834fe76f186f.tar.xz
linux-9cf075f8656524abc44ad3ff2ec3834fe76f186f.zip
mtd: always initialize retlen to zero
Make sure that the retlen is set to 0 in case of error. This harmonizes drivers - some set it to 0 in some error cases and do not write anything in other error cases. Now we can do this consistently for all drivers. Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com> Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
-rw-r--r--include/linux/mtd/mtd.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/include/linux/mtd/mtd.h b/include/linux/mtd/mtd.h
index 8ae37e9d45de..a09077aca45b 100644
--- a/include/linux/mtd/mtd.h
+++ b/include/linux/mtd/mtd.h
@@ -258,6 +258,7 @@ static inline int mtd_erase(struct mtd_info *mtd, struct erase_info *instr)
static inline int mtd_point(struct mtd_info *mtd, loff_t from, size_t len,
size_t *retlen, void **virt, resource_size_t *phys)
{
+ *retlen = 0;
return mtd->point(mtd, from, len, retlen, virt, phys);
}
@@ -289,6 +290,7 @@ static inline int mtd_read(struct mtd_info *mtd, loff_t from, size_t len,
static inline int mtd_write(struct mtd_info *mtd, loff_t to, size_t len,
size_t *retlen, const u_char *buf)
{
+ *retlen = 0;
return mtd->write(mtd, to, len, retlen, buf);
}
@@ -302,18 +304,21 @@ static inline int mtd_write(struct mtd_info *mtd, loff_t to, size_t len,
static inline int mtd_panic_write(struct mtd_info *mtd, loff_t to, size_t len,
size_t *retlen, const u_char *buf)
{
+ *retlen = 0;
return mtd->panic_write(mtd, to, len, retlen, buf);
}
static inline int mtd_read_oob(struct mtd_info *mtd, loff_t from,
struct mtd_oob_ops *ops)
{
+ ops->retlen = ops->oobretlen = 0;
return mtd->read_oob(mtd, from, ops);
}
static inline int mtd_write_oob(struct mtd_info *mtd, loff_t to,
struct mtd_oob_ops *ops)
{
+ ops->retlen = ops->oobretlen = 0;
return mtd->write_oob(mtd, to, ops);
}
@@ -332,6 +337,7 @@ static inline int mtd_read_fact_prot_reg(struct mtd_info *mtd, loff_t from,
size_t len, size_t *retlen,
u_char *buf)
{
+ *retlen = 0;
return mtd->read_fact_prot_reg(mtd, from, len, retlen, buf);
}
@@ -346,6 +352,7 @@ static inline int mtd_read_user_prot_reg(struct mtd_info *mtd, loff_t from,
size_t len, size_t *retlen,
u_char *buf)
{
+ *retlen = 0;
return mtd->read_user_prot_reg(mtd, from, len, retlen, buf);
}
@@ -353,6 +360,7 @@ static inline int mtd_write_user_prot_reg(struct mtd_info *mtd, loff_t to,
size_t len, size_t *retlen,
u_char *buf)
{
+ *retlen = 0;
return mtd->write_user_prot_reg(mtd, to, len, retlen, buf);
}
@@ -369,6 +377,7 @@ static inline int mtd_lock_user_prot_reg(struct mtd_info *mtd, loff_t from,
static inline int mtd_writev(struct mtd_info *mtd, const struct kvec *vecs,
unsigned long count, loff_t to, size_t *retlen)
{
+ *retlen = 0;
return mtd->writev(mtd, vecs, count, to, retlen);
}