Re: [PATCH v4] media: spi: Add support for LMH0395
From: Laurent Pinchart
Date: Mon Nov 03 2014 - 08:42:03 EST
On Monday 03 November 2014 14:36:26 Hans Verkuil wrote:
> On 11/03/2014 02:13 PM, Laurent Pinchart wrote:
> > Hi Jean-Michel,
> >
> > Thank you for the patch.
>
> > On Wednesday 10 September 2014 11:43:54 Jean-Michel Hautbois wrote:
> <snip>
>
> >> +static int lmh0395_s_routing(struct v4l2_subdev *sd, u32 input, u32
> >> output, + u32 config)
> >> +{
> >> + struct lmh0395_state *state = to_state(sd);
> >> + int err = 0;
> >> +
> >> + if (state->output_type != output)
> >> + err = lmh0395_set_output_type(sd, output);
> >> +
> >> + return err;
> >>
> > if (state->output_type == output)
> > return 0;
> >
> > return lmh0395_set_output_type(sd, output);
> >
> > You can then get rid of the err variable.
> >
> > I don't really like this implementation though, the output argument is
> > device- specific, you thus require explicit knowledge of the LMH0395 in
> > your bridge driver.
>
> Well, that's the way s_routing is defined. It's the bridge driver's job to
> translate between V4L2 inputs/outputs and low-level routing information.
>
> > I'm not sure what the config argument is used for, but naively I would
> > have
>
> config is normally not used. There are one or two drivers that need it for
> additional routing configuration, but it's rare.
OK.
> > used it to tell whether to enable (1) or disable (0) the route from input
> > to output. The input value should then always be 0, and the output value
> > can be 1 or 2. Another option would be to use the new S_ROUTING userspace
> > ioctl I've proposed in
> > http://git.linuxtv.org/cgit.cgi/pinchartl/media.git/commit/?h=xilinx-wip&i
> > d=fc094c354338861673464ed4b8fa198089fe7bf0.
> >
> > Hans, could you comment on that ?
>
> Well, first of all your proposed API isn't merged yet, or even posted on the
> mailinglist, so it's a bit unfair to require someone else to use it :-)
It's not a requirement, just a proposal :-) I can send a patch series if
there's enough interest for using that API.
> Also, while I do agree with your proposed new API I am a lot less
> enthusiastic about creating yet another duplicate pad op for an existing
> audio/video routing op.
>
> The problem is that existing drivers are never updated for the new op and
> you are stuck with competing internal APIs. Not nice at all.
Agreed, it's not nice, feel free to propose a better solution :-)
> Bottom line is that this driver uses s_routing like any other driver
> currently in the kernel, so I have no problem with that.
I do :-)
The bridge to subdev dependency is fine for PCI or USB devices where the
hardware topology is known to the driver. It isn't for composite embedded
devices, as we don't want to teach all bridges about all subdevs.
--
Regards,
Laurent Pinchart
--
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/