From: Arnaud Giersch <arnaud.giersch@free.fr>
To: Andrew Morton <akpm@osdl.org>
Cc: philb@gnu.org, tim@cyberelk.net, andrea@suse.de,
linux-parport@lists.infradead.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCHv2] parport: add parallel port support for SGI O2
Date: Tue, 24 Jan 2006 00:38:57 +0100 [thread overview]
Message-ID: <87ek2ycy5q.fsf@groumpf.homeip.net> (raw)
In-Reply-To: <20060122222425.6907656f.akpm@osdl.org> (Andrew Morton's message of "Sun, 22 Jan 2006 22:24:25 -0800")
Lundi 23 janvier 2006, vers 07:24:25 (+0100), Andrew Morton a écrit:
>> From: Arnaud Giersch <arnaud.giersch@free.fr>
>>
>> Add support for the built-in parallel port on SGI O2 (a.k.a. IP32).
>> Define a new configuration option: PARPORT_IP32. The module is named
>> parport_ip32.
>
> Nice looking driver. Big.
Thanks.
> It does rather a lot of
>
> if (foo) do_something();
>
> whereas we prefer
>
> if (foo)
> do_something();
Those are limited to the parport_ip32_dump_state() function. The
rationale is that this function is only here for debugging purpose,
and I did not want to make it longer than it already is.
I will correct the style.
>> +static void parport_ip32_dma_setup_context(unsigned int limit)
[...]
>> + volatile u64 __iomem *ctxreg = (parport_ip32_dma.ctx == 0) ?
>> + &mace->perif.ctrl.parport.context_a :
>> + &mace->perif.ctrl.parport.context_b;
>
> Does this need to be volatile? writeq() should do the right thing.
The "volatile" is here for type consistency. Both variables
"mace->perif.ctrl.parport.context_a" and "context_b" (defined in
include/asm-mips/ip32/mace.h) are from type "volatile u64". Omitting
the "volatile" qualifier for "ctxreg" would make gcc and sparse
complain.
I will add a comment to explain it in the code.
>> +static size_t parport_ip32_epp_read(void __iomem *eppreg,
[...]
>> + if ((flags & PARPORT_EPP_FAST) && (len > 1)) {
>> + readsb(eppreg, buf, len);
>
> readsb() is a mips thing, and doesn't seem to be documented. What does it
> do, and why does the driver use it (only) here?
>
>> + writesb(eppreg, buf, len);
readsb() and writesb() are like ioread8_rep() and iowrite8_rep(). The
io{read,write} family functions are however not available in the
linux-mips.org tree.
The usage of readsb() here is similar to that of insb() in the
corresponding code of the parport_pc driver.
>> +static unsigned int parport_ip32_fifo_wait_break(struct parport *p,
[...]
>> + if (signal_pending(current)) {
>> + printk(KERN_DEBUG PPIP32
>> + "%s: Signal pending\n", p->name);
>> + return 1;
>> + }
>
> This printk could be a bit noisy, if someone hoses a signal stream at a
> printing program.
I did not realized that. I will try to correct the problem.
Thank you for your attention.
Arnaud
next prev parent reply other threads:[~2006-01-23 23:39 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-01-20 23:14 [PATCHv2] parport: add parallel port support for SGI O2 Arnaud Giersch
2006-01-23 6:24 ` Andrew Morton
2006-01-23 23:38 ` Arnaud Giersch [this message]
2006-01-24 23:33 ` Arnaud Giersch
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=87ek2ycy5q.fsf@groumpf.homeip.net \
--to=arnaud.giersch@free.fr \
--cc=akpm@osdl.org \
--cc=andrea@suse.de \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-parport@lists.infradead.org \
--cc=philb@gnu.org \
--cc=tim@cyberelk.net \
/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