diff options
Diffstat (limited to 'drivers/mtd/onenand/onenand_base.c')
| -rw-r--r-- | drivers/mtd/onenand/onenand_base.c | 38 | 
1 files changed, 13 insertions, 25 deletions
| diff --git a/drivers/mtd/onenand/onenand_base.c b/drivers/mtd/onenand/onenand_base.c index 1de33b5d3903..635ee0027691 100644 --- a/drivers/mtd/onenand/onenand_base.c +++ b/drivers/mtd/onenand/onenand_base.c @@ -24,7 +24,6 @@  #include <linux/module.h>  #include <linux/moduleparam.h>  #include <linux/slab.h> -#include <linux/init.h>  #include <linux/sched.h>  #include <linux/delay.h>  #include <linux/interrupt.h> @@ -3238,20 +3237,17 @@ static int onenand_otp_walk(struct mtd_info *mtd, loff_t from, size_t len,  /**   * onenand_get_fact_prot_info - [MTD Interface] Read factory OTP info   * @param mtd		MTD device structure - * @param buf		the databuffer to put/get data   * @param len		number of bytes to read + * @param retlen	pointer to variable to store the number of read bytes + * @param buf		the databuffer to put/get data   *   * Read factory OTP info.   */ -static int onenand_get_fact_prot_info(struct mtd_info *mtd, -			struct otp_info *buf, size_t len) +static int onenand_get_fact_prot_info(struct mtd_info *mtd, size_t len, +				      size_t *retlen, struct otp_info *buf)  { -	size_t retlen; -	int ret; - -	ret = onenand_otp_walk(mtd, 0, len, &retlen, (u_char *) buf, NULL, MTD_OTP_FACTORY); - -	return ret ? : retlen; +	return onenand_otp_walk(mtd, 0, len, retlen, (u_char *) buf, NULL, +				MTD_OTP_FACTORY);  }  /** @@ -3273,20 +3269,17 @@ static int onenand_read_fact_prot_reg(struct mtd_info *mtd, loff_t from,  /**   * onenand_get_user_prot_info - [MTD Interface] Read user OTP info   * @param mtd		MTD device structure - * @param buf		the databuffer to put/get data + * @param retlen	pointer to variable to store the number of read bytes   * @param len		number of bytes to read + * @param buf		the databuffer to put/get data   *   * Read user OTP info.   */ -static int onenand_get_user_prot_info(struct mtd_info *mtd, -			struct otp_info *buf, size_t len) +static int onenand_get_user_prot_info(struct mtd_info *mtd, size_t len, +				      size_t *retlen, struct otp_info *buf)  { -	size_t retlen; -	int ret; - -	ret = onenand_otp_walk(mtd, 0, len, &retlen, (u_char *) buf, NULL, MTD_OTP_USER); - -	return ret ? : retlen; +	return onenand_otp_walk(mtd, 0, len, retlen, (u_char *) buf, NULL, +				MTD_OTP_USER);  }  /** @@ -3995,11 +3988,8 @@ int onenand_scan(struct mtd_info *mtd, int maxchips)  	/* Allocate buffers, if necessary */  	if (!this->page_buf) {  		this->page_buf = kzalloc(mtd->writesize, GFP_KERNEL); -		if (!this->page_buf) { -			printk(KERN_ERR "%s: Can't allocate page_buf\n", -				__func__); +		if (!this->page_buf)  			return -ENOMEM; -		}  #ifdef CONFIG_MTD_ONENAND_VERIFY_WRITE  		this->verify_buf = kzalloc(mtd->writesize, GFP_KERNEL);  		if (!this->verify_buf) { @@ -4012,8 +4002,6 @@ int onenand_scan(struct mtd_info *mtd, int maxchips)  	if (!this->oob_buf) {  		this->oob_buf = kzalloc(mtd->oobsize, GFP_KERNEL);  		if (!this->oob_buf) { -			printk(KERN_ERR "%s: Can't allocate oob_buf\n", -				__func__);  			if (this->options & ONENAND_PAGEBUF_ALLOC) {  				this->options &= ~ONENAND_PAGEBUF_ALLOC;  				kfree(this->page_buf); |