From: Adrian McMenamin <adrian@newgolddream.dyndns.info>
To: "Jörn Engel" <joern@logfs.org>
Cc: MTD <linux-mtd@lists.infradead.org>
Subject: Re: [Fwd: Re: [PATCH] 2/2 mtd: Add support for the Dreamcast VMU flash]
Date: Thu, 20 Mar 2008 22:27:57 +0000 [thread overview]
Message-ID: <1206052077.6274.21.camel@localhost.localdomain> (raw)
In-Reply-To: <20080320215807.GC3977@logfs.org>
On Thu, 2008-03-20 at 22:58 +0100, Jörn Engel wrote:
> On Thu, 20 March 2008 20:11:01 +0000, Adrian McMenamin wrote:
> >
> > You don't seem to have grasped that this is one type of device on a
> > proprietary bus which has other (types of) devices. I keep the code
> > consistent so that the API runs the same across the different devices -
> > makes the code easier to understand and maintain.
> >
> > And given that this is also the variable that points to the memory block
> > that also includes the 8 bit based date that gets read in for block
> > writes I it makes perfect sense to have this as a void*.
>
> Maybe this is a misunderstanding. If you are arguing about this bit
> several mails back:
> ---<snip>---
> > + mdev->mq->sendbuf = sendbuf;
>
> Possibly the big-endian annotations need to trickly though the layers
> here as well.
> ---<snap>---
> Then I agree. For a bus driver that only takes opaque data and moves it
> between device driver and hardware, void* is the type to choose. But if
> you are arguing about the actual device driver, I couldn't disagree
> more.
I'm sorry, but the comment above <snap> isn't good english. What do you
mean?
>
> Please take a look at the function below, maybe it becomes clearer then.
>
> static int maple_vmu_read_block(unsigned int num, unsigned char *buf,
> struct mtd_info *mtd)
> {
> struct memcard *card;
> struct mdev_part *mpart;
> struct maple_device *mdev;
> int partition, error, locking;
> __be32 *sendbuf;
>
> mpart = mtd->priv;
> mdev = mpart->mdev;
> partition = mpart->partition;
> card = mdev->private_data;
>
> /* wait for the mutex to be available */
> locking = down_interruptible(&(mdev->mq->sem));
> if (locking) {
> printk(KERN_INFO "Maple: VMU at (%d, %d) is locked -"
> " aborting read\n", mdev->unit, mdev->port);
> return -EIO;
> }
> mdev->mq->command = MAPLE_COMMAND_BREAD;
> mdev->mq->length = 2;
>
> sendbuf = kzalloc(mdev->mq->length * 4, GFP_KERNEL);
> if (!sendbuf)
> return -ENOMEM;
>
> sendbuf[0] = cpu_to_be32(MAPLE_FUNC_MEMCARD);
> sendbuf[1] = cpu_to_be32(partition << 24 | num);
>
> mdev->mq->sendbuf = sendbuf;
> block_read = 0;
>
> maple_getcond_callback(mdev, vmu_blockread, 0, MAPLE_FUNC_MEMCARD);
> maple_add_packet(mdev->mq);
> wait_event_interruptible_timeout(vmu_read, block_read, HZ * 4);
> if (block_read == 0) {
> printk(KERN_INFO "Maple: VMU read failed on block 0x%X\n", num);
> error = -EIO;
> goto out;
> }
> /* FIXME: we kfree a data structure that was allocated elsewhere.
> * Either move allocation and freeing to the same function or
> * thoroughly document this to avoid subtle bugs after future
> * code changes.
> */
> memcpy(buf, card->blockread, card->blocklen);
> kfree(card->blockread);
>
> error = 0;
> out:
> kfree(sendbuf);
> return error;
> }
>
> And after doing these changes a couple more problems stuck out like sore
> thumbs, f.e. the FIXME above. But we can discuss those later.
What is the issue? That the code is wrong or the documentation is
inadequate?
next prev parent reply other threads:[~2008-03-20 22:28 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-03-19 21:20 [Fwd: Re: [PATCH] 2/2 mtd: Add support for the Dreamcast VMU flash] Adrian McMenamin
2008-03-20 10:03 ` Jörn Engel
2008-03-20 11:56 ` Adrian McMenamin
2008-03-20 11:20 ` Jörn Engel
2008-03-20 12:56 ` Adrian McMenamin
2008-03-20 12:31 ` Jörn Engel
2008-03-20 20:11 ` Adrian McMenamin
2008-03-20 21:58 ` Jörn Engel
2008-03-20 22:27 ` Adrian McMenamin [this message]
2008-03-21 9:49 ` Jörn Engel
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1206052077.6274.21.camel@localhost.localdomain \
--to=adrian@newgolddream.dyndns.info \
--cc=joern@logfs.org \
--cc=linux-mtd@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox