From: Corey Minyard <minyard@acm.org>
To: Andrew Morton <akpm@osdl.org>
Cc: linux-kernel@vger.kernel.org
Subject: Re: [PATCH] IPMI driver updates, part 1b
Date: Wed, 25 Feb 2004 09:59:35 -0600 [thread overview]
Message-ID: <403CC667.2000403@acm.org> (raw)
In-Reply-To: <20040224170024.4e75a85c.akpm@osdl.org>
Andrew Morton wrote:
>Corey Minyard <minyard@acm.org> wrote:
>
>
>>It helps to actually attach the code.
>>
>>
>
>Got there eventually.
>
>Patches seem reasonable, thanks. I'm not sure how to judge the suitability
>of the socket interface but it only touches your code..
>
Let's leave the af_ipmi code out for now. I'd like to get some opinions
on it, though.
>
>- Several instances of IPMI_MAX_MSG_LENGTH-sized local arrays. It's not
> toooo large, but watch out for the stack space.
>
I will rework these. These used to be much smaller, but newer hardware
needed larger sizes.
>
>- You should convert the MODULE_PARMs to module_param() sometime.
>
Will do.
>
>- Be aware that the bitfields in struct seq_table will all fall into the
> same word and the compiler doesn't access them atomically. You must
> provide your own locking to prevent updates to them from scribbling on
> each other. Or make them integers.
>
These are only accessed when the sequence number lock is held, so they
should be ok.
>
>- You misspelt breadcrumbs!
>
Argh! I'll get that fixed one of these days :)
>
>- This:
>
> extern struct si_sm_handlers kcs_smi_handlers;
>
> should be in a header file.
>
ok.
>
>- kcs_event_handler() sets `time = 0;' but never uses it again.
>
Actually, that's not true. There's an evil goto that goes back to
"restart:", thus the time needs to be cleared.
>
>- status2txt() should take the caller's char* rather than use a static buffer.
>
Ok, I'll fix that.
>
>- In ipmi_bt_sm.c:
>
> volatile unsigned char status;
>
> The volatile is a red flag. It seems to be unneeded.
>
I'll ask the person who wrote this about it.
>
>- We have #ifdef CONFIG_HIGH_RES_TIMERS code in there?
>
Well, yes. That's so if people add the high-res timer patch, this
driver can take advantage of it. Is that a problem?
>
>- drivers/char/ipmi/ipmi_si.c has lots of
>
> struct smi_info *smi_info = (struct smi_info *) send_info;
>
> You don't need to cast a void* and it's actually a harmful thing to do:
> it suppresses useful warnings if someone goes and changes the type of the
> rhs.
>
Yes, true.
>
>- ipmi_wait_for_queue() doesn't need set_current_state(TASK_RUNNING);
> after schedule_timeout() (I removed it)
>
Ok.
>
>- There's a locking bug in ipmi_recvmsg(): it can unlock i_lock when it
> isn't held. I added this:
>
>diff -puN net/ipmi/af_ipmi.c~af_ipmi-locking-fix net/ipmi/af_ipmi.c
>--- 25/net/ipmi/af_ipmi.c~af_ipmi-locking-fix Tue Feb 24 16:56:36 2004
>+++ 25-akpm/net/ipmi/af_ipmi.c Tue Feb 24 16:57:00 2004
>@@ -336,6 +336,7 @@ static int ipmi_recvmsg(struct kiocb *io
> }
>
> timeo = ipmi_wait_for_queue(i, timeo);
>+ spin_lock_irqsave(&i->lock, flags);
> }
>
> rcvmsg = list_entry(i->msg_list.next, struct ipmi_recv_msg, link);
>
>
> which may or may not be correct.
>
I'll look at this.
>
>
>Anyway, that's all fairly trivial. Please retest this code in the next
>-mm, send me any updates against that as appropriate and we'll get this
>merged up, thanks.
>
Ok.
Thank you for your help.
-Corey
next prev parent reply other threads:[~2004-02-25 15:59 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-02-24 13:55 [PATCH] IPMI driver updates, part 1b Corey Minyard
2004-02-24 23:51 ` Corey Minyard
2004-02-25 1:00 ` Andrew Morton
2004-02-25 15:59 ` Corey Minyard [this message]
2004-02-25 20:02 ` Andrew Morton
2004-02-25 16:15 ` Corey Minyard
2004-02-25 20:05 ` Andrew Morton
2004-02-25 21:12 ` Corey Minyard
2004-02-25 20:32 ` Andrew Morton
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=403CC667.2000403@acm.org \
--to=minyard@acm.org \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.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