162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci *  Copyright (C) 2005 Mike Isely <isely@pobox.com>
562306a36Sopenharmony_ci *  Copyright (C) 2004 Aurelien Alleaume <slts@free.fr>
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#include "pvrusb2-audio.h"
962306a36Sopenharmony_ci#include "pvrusb2-hdw-internal.h"
1062306a36Sopenharmony_ci#include "pvrusb2-debug.h"
1162306a36Sopenharmony_ci#include <linux/videodev2.h>
1262306a36Sopenharmony_ci#include <media/drv-intf/msp3400.h>
1362306a36Sopenharmony_ci#include <media/v4l2-common.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_cistruct routing_scheme {
1762306a36Sopenharmony_ci	const int *def;
1862306a36Sopenharmony_ci	unsigned int cnt;
1962306a36Sopenharmony_ci};
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_cistatic const int routing_scheme0[] = {
2262306a36Sopenharmony_ci	[PVR2_CVAL_INPUT_TV]        = MSP_INPUT_DEFAULT,
2362306a36Sopenharmony_ci	[PVR2_CVAL_INPUT_RADIO]     = MSP_INPUT(MSP_IN_SCART2,
2462306a36Sopenharmony_ci						MSP_IN_TUNER1,
2562306a36Sopenharmony_ci						MSP_DSP_IN_SCART,
2662306a36Sopenharmony_ci						MSP_DSP_IN_SCART),
2762306a36Sopenharmony_ci	[PVR2_CVAL_INPUT_COMPOSITE] = MSP_INPUT(MSP_IN_SCART1,
2862306a36Sopenharmony_ci						MSP_IN_TUNER1,
2962306a36Sopenharmony_ci						MSP_DSP_IN_SCART,
3062306a36Sopenharmony_ci						MSP_DSP_IN_SCART),
3162306a36Sopenharmony_ci	[PVR2_CVAL_INPUT_SVIDEO]    = MSP_INPUT(MSP_IN_SCART1,
3262306a36Sopenharmony_ci						MSP_IN_TUNER1,
3362306a36Sopenharmony_ci						MSP_DSP_IN_SCART,
3462306a36Sopenharmony_ci						MSP_DSP_IN_SCART),
3562306a36Sopenharmony_ci};
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_cistatic const struct routing_scheme routing_def0 = {
3862306a36Sopenharmony_ci	.def = routing_scheme0,
3962306a36Sopenharmony_ci	.cnt = ARRAY_SIZE(routing_scheme0),
4062306a36Sopenharmony_ci};
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_cistatic const struct routing_scheme *routing_schemes[] = {
4362306a36Sopenharmony_ci	[PVR2_ROUTING_SCHEME_HAUPPAUGE] = &routing_def0,
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_civoid pvr2_msp3400_subdev_update(struct pvr2_hdw *hdw, struct v4l2_subdev *sd)
4762306a36Sopenharmony_ci{
4862306a36Sopenharmony_ci	if (hdw->input_dirty || hdw->force_dirty) {
4962306a36Sopenharmony_ci		const struct routing_scheme *sp;
5062306a36Sopenharmony_ci		unsigned int sid = hdw->hdw_desc->signal_routing_scheme;
5162306a36Sopenharmony_ci		u32 input;
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci		pvr2_trace(PVR2_TRACE_CHIPS, "subdev msp3400 v4l2 set_stereo");
5462306a36Sopenharmony_ci		sp = (sid < ARRAY_SIZE(routing_schemes)) ?
5562306a36Sopenharmony_ci			routing_schemes[sid] : NULL;
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci		if ((sp != NULL) &&
5862306a36Sopenharmony_ci		    (hdw->input_val >= 0) &&
5962306a36Sopenharmony_ci		    (hdw->input_val < sp->cnt)) {
6062306a36Sopenharmony_ci			input = sp->def[hdw->input_val];
6162306a36Sopenharmony_ci		} else {
6262306a36Sopenharmony_ci			pvr2_trace(PVR2_TRACE_ERROR_LEGS,
6362306a36Sopenharmony_ci				   "*** WARNING *** subdev msp3400 set_input: Invalid routing scheme (%u) and/or input (%d)",
6462306a36Sopenharmony_ci				   sid, hdw->input_val);
6562306a36Sopenharmony_ci			return;
6662306a36Sopenharmony_ci		}
6762306a36Sopenharmony_ci		sd->ops->audio->s_routing(sd, input,
6862306a36Sopenharmony_ci			MSP_OUTPUT(MSP_SC_IN_DSP_SCART1), 0);
6962306a36Sopenharmony_ci	}
7062306a36Sopenharmony_ci}
71