2009-04-09 05:52:42

by Kevin Cernekee

[permalink] [raw]
Subject: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

New MEMERASE/MEMREADOOB/MEMWRITEOOB ioctls are needed in order to support
64-bit offsets into large NAND flash devices.

Signed-off-by: Kevin Cernekee <[email protected]>

---
drivers/mtd/mtdchar.c | 29 +++++++++++++++++++++--------
fs/compat_ioctl.c | 1 +
include/mtd/mtd-abi.h | 6 ++++++
3 files changed, 28 insertions(+), 8 deletions(-)

diff --git a/drivers/mtd/mtdchar.c b/drivers/mtd/mtdchar.c
index 763d3f0..ad4b861 100644
--- a/drivers/mtd/mtdchar.c
+++ b/drivers/mtd/mtdchar.c
@@ -417,6 +417,7 @@ static int mtd_ioctl(struct inode *inode, struct file *file,
break;

case MEMERASE:
+ case MEMERASE64:
{
struct erase_info *erase;

@@ -427,20 +428,32 @@ static int mtd_ioctl(struct inode *inode, struct
file *file,
if (!erase)
ret = -ENOMEM;
else {
- struct erase_info_user einfo;
-
wait_queue_head_t waitq;
DECLARE_WAITQUEUE(wait, current);

init_waitqueue_head(&waitq);

- if (copy_from_user(&einfo, argp,
- sizeof(struct erase_info_user))) {
- kfree(erase);
- return -EFAULT;
+ if (cmd == MEMERASE64) {
+ struct erase_info_user64 einfo64;
+
+ if (copy_from_user(&einfo64, argp,
+ sizeof(struct erase_info_user64))) {
+ kfree(erase);
+ return -EFAULT;
+ }
+ erase->addr = einfo64.start;
+ erase->len = einfo64.length;
+ } else {
+ struct erase_info_user einfo32;
+
+ if (copy_from_user(&einfo32, argp,
+ sizeof(struct erase_info_user))) {
+ kfree(erase);
+ return -EFAULT;
+ }
+ erase->addr = einfo32.start;
+ erase->len = einfo32.length;
}
- erase->addr = einfo.start;
- erase->len = einfo.length;
erase->mtd = mtd;
erase->callback = mtdchar_erase_callback;
erase->priv = (unsigned long)&waitq;
diff --git a/fs/compat_ioctl.c b/fs/compat_ioctl.c
index 3e87ce4..06d4e0c 100644
--- a/fs/compat_ioctl.c
+++ b/fs/compat_ioctl.c
@@ -2441,6 +2441,7 @@ COMPATIBLE_IOCTL(MEMGETREGIONCOUNT)
COMPATIBLE_IOCTL(MEMGETREGIONINFO)
COMPATIBLE_IOCTL(MEMGETBADBLOCK)
COMPATIBLE_IOCTL(MEMSETBADBLOCK)
+COMPATIBLE_IOCTL(MEMERASE64)
/* NBD */
ULONG_IOCTL(NBD_SET_SOCK)
ULONG_IOCTL(NBD_SET_BLKSIZE)
diff --git a/include/mtd/mtd-abi.h b/include/mtd/mtd-abi.h
index b6595b3..2e32be1 100644
--- a/include/mtd/mtd-abi.h
+++ b/include/mtd/mtd-abi.h
@@ -12,6 +12,11 @@ struct erase_info_user {
__u32 length;
};

+struct erase_info_user64 {
+ __u64 start;
+ __u64 length;
+};
+
struct mtd_oob_buf {
__u32 start;
__u32 length;
@@ -95,6 +100,7 @@ struct otp_info {
#define ECCGETLAYOUT _IOR('M', 17, struct nand_ecclayout)
#define ECCGETSTATS _IOR('M', 18, struct mtd_ecc_stats)
#define MTDFILEMODE _IO('M', 19)
+#define MEMERASE64 _IOW('M', 20, struct erase_info_user64)

/*
* Obsolete legacy interface. Keep it in order not to break userspace
--
1.5.4.3


2009-04-10 22:09:20

by Andrew Morton

[permalink] [raw]
Subject: Re: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

On Wed, 8 Apr 2009 22:52:28 -0700
Kevin Cernekee <[email protected]> wrote:

> Subject: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

triviata:

The text inside [] is usually removed by the patch recipient - the []
denotes transient information such as "patch" and the kernel version,
etc.

The preferred form for patch titles is

subsytem-identifier: what-i-did-to-it

so this patch should have been

mtd: add MEMERASE64 ioctl for >4GiB devices

>
> @@ -427,20 +428,32 @@ static int mtd_ioctl(struct inode *inode, struct
> file *file,

Your email client is wordwrapping the text.

2009-04-17 07:31:03

by Artem Bityutskiy

[permalink] [raw]
Subject: Re: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

On Wed, 2009-04-08 at 22:52 -0700, Kevin Cernekee wrote:
> New MEMERASE/MEMREADOOB/MEMWRITEOOB ioctls are needed in order to support
> 64-bit offsets into large NAND flash devices.
>
> Signed-off-by: Kevin Cernekee <[email protected]>
>

Kevin, are you going to re-send patches 2-4, taking into account
Arnd's and Andrew's suggestions?

--
Best regards,
Artem Bityutskiy (Битюцкий Артём)

2009-04-18 16:21:39

by Kevin Cernekee

[permalink] [raw]
Subject: Re: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

On Fri, Apr 17, 2009 at 12:30 AM, Artem Bityutskiy
<[email protected]> wrote:
> Kevin, are you going to re-send patches 2-4, taking into account
> Arnd's and Andrew's suggestions?

For Arnd's suggestion, I posted a followup patch here:

http://lists.infradead.org/pipermail/linux-mtd/2009-April/025269.html

Andrew brought up two issues: [MTD] in the subject line, and
linewrapping. I am assuming that he fixed these himself since he
pulled all five patches (originals + followup) into the -mm tree.

Should I fix and repost the set anyway?

Thanks.

2009-04-20 06:47:44

by Artem Bityutskiy

[permalink] [raw]
Subject: Re: [PATCH 2/4] [MTD] Add MEMERASE64 ioctl for >4GiB devices

On Sat, 2009-04-18 at 09:21 -0700, Kevin Cernekee wrote:
> On Fri, Apr 17, 2009 at 12:30 AM, Artem Bityutskiy
> <[email protected]> wrote:
> > Kevin, are you going to re-send patches 2-4, taking into account
> > Arnd's and Andrew's suggestions?
>
> For Arnd's suggestion, I posted a followup patch here:
>
> http://lists.infradead.org/pipermail/linux-mtd/2009-April/025269.html
>
> Andrew brought up two issues: [MTD] in the subject line, and
> linewrapping. I am assuming that he fixed these himself since he
> pulled all five patches (originals + followup) into the -mm tree.
>
> Should I fix and repost the set anyway?

No, I just missed that patch. Pushed your patches to l2-mtd-2.6.git.
Will ping dwmw2 about this. I also checked that your patches at
least do not break MTD for UBI/UBIFS. Thanks.

--
Best regards,
Artem Bityutskiy (Битюцкий Артём)