1*2504ba9fSThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
20c0d06caSMauro Carvalho Chehab /*
30c0d06caSMauro Carvalho Chehab *
40c0d06caSMauro Carvalho Chehab * Copyright (C) 2005 Mike Isely <isely@pobox.com>
50c0d06caSMauro Carvalho Chehab * Copyright (C) 2004 Aurelien Alleaume <slts@free.fr>
60c0d06caSMauro Carvalho Chehab */
70c0d06caSMauro Carvalho Chehab
80c0d06caSMauro Carvalho Chehab /*
90c0d06caSMauro Carvalho Chehab
100c0d06caSMauro Carvalho Chehab This source file is specifically designed to interface with the
110c0d06caSMauro Carvalho Chehab v4l-dvb cs53l32a module.
120c0d06caSMauro Carvalho Chehab
130c0d06caSMauro Carvalho Chehab */
140c0d06caSMauro Carvalho Chehab
150c0d06caSMauro Carvalho Chehab #include "pvrusb2-cs53l32a.h"
160c0d06caSMauro Carvalho Chehab
170c0d06caSMauro Carvalho Chehab
180c0d06caSMauro Carvalho Chehab #include "pvrusb2-hdw-internal.h"
190c0d06caSMauro Carvalho Chehab #include "pvrusb2-debug.h"
200c0d06caSMauro Carvalho Chehab #include <linux/videodev2.h>
210c0d06caSMauro Carvalho Chehab #include <media/v4l2-common.h>
220c0d06caSMauro Carvalho Chehab #include <linux/errno.h>
230c0d06caSMauro Carvalho Chehab
240c0d06caSMauro Carvalho Chehab struct routing_scheme {
250c0d06caSMauro Carvalho Chehab const int *def;
260c0d06caSMauro Carvalho Chehab unsigned int cnt;
270c0d06caSMauro Carvalho Chehab };
280c0d06caSMauro Carvalho Chehab
290c0d06caSMauro Carvalho Chehab
300c0d06caSMauro Carvalho Chehab static const int routing_scheme1[] = {
310c0d06caSMauro Carvalho Chehab [PVR2_CVAL_INPUT_TV] = 2, /* 1 or 2 seems to work here */
320c0d06caSMauro Carvalho Chehab [PVR2_CVAL_INPUT_RADIO] = 2,
330c0d06caSMauro Carvalho Chehab [PVR2_CVAL_INPUT_COMPOSITE] = 0,
340c0d06caSMauro Carvalho Chehab [PVR2_CVAL_INPUT_SVIDEO] = 0,
350c0d06caSMauro Carvalho Chehab };
360c0d06caSMauro Carvalho Chehab
370c0d06caSMauro Carvalho Chehab static const struct routing_scheme routing_def1 = {
380c0d06caSMauro Carvalho Chehab .def = routing_scheme1,
390c0d06caSMauro Carvalho Chehab .cnt = ARRAY_SIZE(routing_scheme1),
400c0d06caSMauro Carvalho Chehab };
410c0d06caSMauro Carvalho Chehab
420c0d06caSMauro Carvalho Chehab static const struct routing_scheme *routing_schemes[] = {
430c0d06caSMauro Carvalho Chehab [PVR2_ROUTING_SCHEME_ONAIR] = &routing_def1,
440c0d06caSMauro Carvalho Chehab };
450c0d06caSMauro Carvalho Chehab
460c0d06caSMauro Carvalho Chehab
pvr2_cs53l32a_subdev_update(struct pvr2_hdw * hdw,struct v4l2_subdev * sd)470c0d06caSMauro Carvalho Chehab void pvr2_cs53l32a_subdev_update(struct pvr2_hdw *hdw, struct v4l2_subdev *sd)
480c0d06caSMauro Carvalho Chehab {
490c0d06caSMauro Carvalho Chehab if (hdw->input_dirty || hdw->force_dirty) {
500c0d06caSMauro Carvalho Chehab const struct routing_scheme *sp;
510c0d06caSMauro Carvalho Chehab unsigned int sid = hdw->hdw_desc->signal_routing_scheme;
520c0d06caSMauro Carvalho Chehab u32 input;
530c0d06caSMauro Carvalho Chehab pvr2_trace(PVR2_TRACE_CHIPS, "subdev v4l2 set_input(%d)",
540c0d06caSMauro Carvalho Chehab hdw->input_val);
550c0d06caSMauro Carvalho Chehab sp = (sid < ARRAY_SIZE(routing_schemes)) ?
560c0d06caSMauro Carvalho Chehab routing_schemes[sid] : NULL;
570c0d06caSMauro Carvalho Chehab if ((sp == NULL) ||
580c0d06caSMauro Carvalho Chehab (hdw->input_val < 0) ||
590c0d06caSMauro Carvalho Chehab (hdw->input_val >= sp->cnt)) {
600c0d06caSMauro Carvalho Chehab pvr2_trace(PVR2_TRACE_ERROR_LEGS,
6196292c89SMauro Carvalho Chehab "*** WARNING *** subdev v4l2 set_input: Invalid routing scheme (%u) and/or input (%d)",
620c0d06caSMauro Carvalho Chehab sid, hdw->input_val);
630c0d06caSMauro Carvalho Chehab return;
640c0d06caSMauro Carvalho Chehab }
650c0d06caSMauro Carvalho Chehab input = sp->def[hdw->input_val];
660c0d06caSMauro Carvalho Chehab sd->ops->audio->s_routing(sd, input, 0, 0);
670c0d06caSMauro Carvalho Chehab }
680c0d06caSMauro Carvalho Chehab }
69