Re: [alsa-devel] [RFC] [PATCH 1/3] ASoC: Add support for Conexant CX20442-11 voice modem codec

From: Janusz Krzysztofik
Date: Tue Jul 28 2009 - 11:01:03 EST


Wednesday 22 July 2009 12:10:28 Mark Brown wrote:
> On Wed, Jul 22, 2009 at 05:22:28AM +0200, Janusz Krzysztofik wrote:
> > This patch adds support for Conexant CX20442-11 voice modem codec,
> > suitable for use by the ASoC board driver for Amstrad E3 (Delta)
> > videophone. Related sound card driver will follow.
> >
> You'll want to run checkpatch over it and send a followup fixing the
> issues it identifies. Looking at this I suspect that it may be possible
> to refactor things so that more of the line discipline interaction is
> pushed down into the CODEC driver but that can also be done as a
> followup.
>
> would also be nice to add some documentation somewhere explaining how
> the hw_write() function is expected to be set up since it's a little
> surprising (if the line discipline stuff were pushed down into the code
> that'd become a lot more obvious).

Mark,
I am ready with a followup that corrects those minor issues, as well as with a
new, corrected version of the machine driver. However, before I submit them,
I'd like to discuss again your idea of pushing down the line discipline code
into the codec driver.

As you may have noticed, my codec driver was ready for adopting it to one or
more additional buses of different types, in a way similiar to those
implemented in other codec drivers. There was a room for a hypothetical
cx20442_xxx_probe() function, invoked by a hypothetical xxx bus driver after
the bus comes up or a device is detected on it. That function could then set
up its own codec->control_data and codec->hw_write pointers for talking to
the codec via a hypothetical xxx bus adapter using its write method. In
particular, that could be a line discipline provided acceess to the codec
assosociated modem.

Following that model, the line discipline code didn't seam to belong to a
codec driver for me. If it could be recognized as a new bus dirver, it should
be pushed down probably into a separate module. However, if it was rather
some kind of a bus adapter driver, it seamed to belong to the machine code.

As I had got no positive feedback to my RFC on inventing a new bus (votes were
rather neutral, and I agreed with them[1]), I decided to put the line
discipline code into the machine driver.

If you see things somehow different, please let me know, I can try to follow
your ideas and rearrange the code.

Cheers,
Janusz

[1] http://www.spinics.net/lists/linux-serial/msg01856.html
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/