Lines Matching +full:out +full:- +full:mono

1 // SPDX-License-Identifier: GPL-2.0-or-later
5 * (c) 1997-2001 Gerd Knorr <kraxel@bytesex.org>
9 * AM-Mono
13 * FM-Mono
14 * should work. The stereo modes are backward compatible to FM-mono,
15 * therefore FM-Mono should be always available.
17 * FM-Stereo (B/G, used in germany)
20 * FM-Stereo (satellite)
21 * should work, no autodetect (i.e. default is mono, but you can
22 * switch to stereo -- untested)
29 * - better SAT support
43 #include <media/v4l2-device.h>
44 #include <media/v4l2-ioctl.h>
45 #include <media/drv-intf/msp3400.h>
47 #include "msp3400-driver.h"
49 /* ---------------------------------------------------------------------- */
59 bool msp_amsound; /* hard-wire AM sound at 6.5 Hz (france),
66 (msp34xxg only) 0x00a0-0x03c0 */
68 /* read-only */
71 /* read-write */
81 MODULE_PARM_DESC(debug, "Enable debug messages [0-3]");
87 /* ---------------------------------------------------------------------- */
97 /* ----------------------------------------------------------------------- */
109 .addr = client->addr, in msp_reset()
115 .addr = client->addr, in msp_reset()
123 .addr = client->addr, in msp_reset()
128 .addr = client->addr, in msp_reset()
135 dev_dbg_lvl(&client->dev, 3, msp_debug, "msp_reset\n"); in msp_reset()
136 if (i2c_transfer(client->adapter, &reset[0], 1) != 1 || in msp_reset()
137 i2c_transfer(client->adapter, &reset[1], 1) != 1 || in msp_reset()
138 i2c_transfer(client->adapter, test, 2) != 2) { in msp_reset()
139 dev_err(&client->dev, "chip reset failed\n"); in msp_reset()
140 return -1; in msp_reset()
152 .addr = client->addr, in msp_read()
157 .addr = client->addr, in msp_read()
169 if (i2c_transfer(client->adapter, msgs, 2) == 2) in msp_read()
171 dev_warn(&client->dev, "I/O error #%d (read 0x%02x/0x%02x)\n", err, in msp_read()
176 dev_warn(&client->dev, "resetting chip, sound will go off.\n"); in msp_read()
178 return -1; in msp_read()
181 dev_dbg_lvl(&client->dev, 3, msp_debug, "msp_read(0x%x, 0x%x): 0x%x\n", in msp_read()
207 dev_dbg_lvl(&client->dev, 3, msp_debug, "msp_write(0x%x, 0x%x, 0x%x)\n", in msp_write()
212 dev_warn(&client->dev, "I/O error #%d (write 0x%02x/0x%02x)\n", err, in msp_write()
217 dev_warn(&client->dev, "resetting chip, sound will go off.\n"); in msp_write()
219 return -1; in msp_write()
234 /* ----------------------------------------------------------------------- *
235 * bits 9 8 5 - SCART DSP input Select:
236 * 0 0 0 - SCART 1 to DSP input (reset position)
237 * 0 1 0 - MONO to DSP input
238 * 1 0 0 - SCART 2 to DSP input
239 * 1 1 1 - Mute DSP input
241 * bits 11 10 6 - SCART 1 Output Select:
242 * 0 0 0 - undefined (reset position)
243 * 0 1 0 - SCART 2 Input to SCART 1 Output (for devices with 2 SCARTS)
244 * 1 0 0 - MONO input to SCART 1 Output
245 * 1 1 0 - SCART 1 DA to SCART 1 Output
246 * 0 0 1 - SCART 2 DA to SCART 1 Output
247 * 0 1 1 - SCART 1 Input to SCART 1 Output
248 * 1 1 1 - Mute SCART 1 Output
250 * bits 13 12 7 - SCART 2 Output Select (for devices with 2 Output SCART):
251 * 0 0 0 - SCART 1 DA to SCART 2 Output (reset position)
252 * 0 1 0 - SCART 1 Input to SCART 2 Output
253 * 1 0 0 - MONO input to SCART 2 Output
254 * 0 0 1 - SCART 2 DA to SCART 2 Output
255 * 0 1 1 - SCART 2 Input to SCART 2 Output
256 * 1 1 0 - Mute SCART 2 Output
259 * ----------------------------------------------------------------------- */
262 /* MASK IN1 IN2 IN3 IN4 IN1_DA IN2_DA MONO MUTE */
264 { 0x0320, 0x0000, 0x0200, 0x0300, 0x0020, -1, -1, 0x0100, 0x0320 },
272 "in1", "in2", "in3", "in4", "in1 da", "in2 da", "mono", "mute"
275 void msp_set_scart(struct i2c_client *client, int in, int out) in msp_set_scart() argument
279 state->in_scart = in; in msp_set_scart()
281 if (in >= 0 && in <= 7 && out >= 0 && out <= 2) { in msp_set_scart()
282 if (-1 == scarts[out][in + 1]) in msp_set_scart()
285 state->acb &= ~scarts[out][0]; in msp_set_scart()
286 state->acb |= scarts[out][in + 1]; in msp_set_scart()
288 state->acb = 0xf60; /* Mute Input and SCART 1 Output */ in msp_set_scart()
290 dev_dbg_lvl(&client->dev, 1, msp_debug, "scart switch: %s => %d (ACB=0x%04x)\n", in msp_set_scart()
291 scart_names[in], out, state->acb); in msp_set_scart()
292 msp_write_dsp(client, 0x13, state->acb); in msp_set_scart()
295 if (state->has_i2s_conf) in msp_set_scart()
296 msp_write_dem(client, 0x40, state->i2s_mode); in msp_set_scart()
299 /* ------------------------------------------------------------------------ */
305 if (NULL == state->kthread) in msp_wake_thread()
307 state->watch_stereo = 0; in msp_wake_thread()
308 state->restart = 1; in msp_wake_thread()
309 wake_up_interruptible(&state->wq); in msp_wake_thread()
316 add_wait_queue(&state->wq, &wait); in msp_sleep()
327 remove_wait_queue(&state->wq, &wait); in msp_sleep()
329 return state->restart; in msp_sleep()
332 /* ------------------------------------------------------------------------ */
337 struct i2c_client *client = v4l2_get_subdevdata(&state->sd); in msp_s_ctrl()
338 int val = ctrl->val; in msp_s_ctrl()
340 switch (ctrl->id) { in msp_s_ctrl()
343 int reallymuted = state->muted->val | state->scan_in_progress; in msp_s_ctrl()
348 dev_dbg_lvl(&client->dev, 1, msp_debug, "mute=%s scanning=%s volume=%d\n", in msp_s_ctrl()
349 state->muted->val ? "on" : "off", in msp_s_ctrl()
350 state->scan_in_progress ? "yes" : "no", in msp_s_ctrl()
351 state->volume->val); in msp_s_ctrl()
355 if (state->has_scart2_out_volume) in msp_s_ctrl()
357 if (state->has_headphones) in msp_s_ctrl()
363 val = ((val - 32768) * 0x60 / 65535) << 8; in msp_s_ctrl()
365 if (state->has_headphones) in msp_s_ctrl()
370 val = ((val - 32768) * 0x60 / 65535) << 8; in msp_s_ctrl()
372 if (state->has_headphones) in msp_s_ctrl()
379 if (state->has_headphones) in msp_s_ctrl()
384 val = (u8)((val / 256) - 128); in msp_s_ctrl()
386 if (state->has_headphones) in msp_s_ctrl()
391 return -EINVAL; in msp_s_ctrl()
399 v4l2_ctrl_lock(state->volume); in msp_update_volume()
400 state->volume->val = state->volume->cur.val; in msp_update_volume()
401 state->muted->val = state->muted->cur.val; in msp_update_volume()
402 msp_s_ctrl(state->volume); in msp_update_volume()
403 v4l2_ctrl_unlock(state->volume); in msp_update_volume()
406 /* --- v4l2 ioctls --- */
412 if (state->radio) in msp_s_radio()
414 state->radio = 1; in msp_s_radio()
415 dev_dbg_lvl(&client->dev, 1, msp_debug, "switching to radio mode\n"); in msp_s_radio()
416 state->watch_stereo = 0; in msp_s_radio()
417 switch (state->opmode) { in msp_s_radio()
438 /* new channel -- kick audio carrier scan */ in msp_s_frequency()
448 *id &= state->detected_std; in msp_querystd()
450 dev_dbg_lvl(&client->dev, 2, msp_debug, in msp_querystd()
452 msp_standard_std_name(state->std), state->detected_std); in msp_querystd()
461 int update = state->radio || state->v4l2_std != id; in msp_s_std()
463 state->v4l2_std = id; in msp_s_std()
464 state->radio = 0; in msp_s_std()
483 if (state->route_in == input && state->route_out == output) in msp_s_routing()
485 state->route_in = input; in msp_s_routing()
486 state->route_out = output; in msp_s_routing()
492 state->mode = extern_input ? MSP_MODE_EXTERN : MSP_MODE_AM_DETECT; in msp_s_routing()
493 state->rxsubchans = V4L2_TUNER_SUB_STEREO; in msp_s_routing()
498 reg = (state->opmode == OPMODE_AUTOSELECT) ? 0x30 : 0xbb; in msp_s_routing()
511 if (vt->type != V4L2_TUNER_ANALOG_TV) in msp_g_tuner()
513 if (!state->radio) { in msp_g_tuner()
514 if (state->opmode == OPMODE_AUTOSELECT) in msp_g_tuner()
516 vt->rxsubchans = state->rxsubchans; in msp_g_tuner()
518 vt->audmode = state->audmode; in msp_g_tuner()
519 vt->capability |= V4L2_TUNER_CAP_STEREO | in msp_g_tuner()
529 if (state->radio) /* TODO: add mono/stereo support for radio */ in msp_s_tuner()
531 if (state->audmode == vt->audmode) in msp_s_tuner()
533 state->audmode = vt->audmode; in msp_s_tuner()
544 dev_dbg_lvl(&client->dev, 1, msp_debug, "Setting I2S speed to %d\n", freq); in msp_s_i2s_clock_freq()
548 state->i2s_mode = 0; in msp_s_i2s_clock_freq()
551 state->i2s_mode = 1; in msp_s_i2s_clock_freq()
554 return -EINVAL; in msp_s_i2s_clock_freq()
566 if (state->opmode == OPMODE_AUTOSELECT) in msp_log_status()
568 dev_info(&client->dev, "%s rev1 = 0x%04x rev2 = 0x%04x\n", in msp_log_status()
569 client->name, state->rev1, state->rev2); in msp_log_status()
570 snprintf(prefix, sizeof(prefix), "%s: Audio: ", sd->name); in msp_log_status()
571 v4l2_ctrl_handler_log_status(&state->hdl, prefix); in msp_log_status()
572 switch (state->mode) { in msp_log_status()
575 case MSP_MODE_FM_TERRA: p = "Terrestrial FM-mono/stereo"; break; in msp_log_status()
576 case MSP_MODE_FM_SAT: p = "Satellite FM-mono"; break; in msp_log_status()
584 if (state->mode == MSP_MODE_EXTERN) { in msp_log_status()
585 dev_info(&client->dev, "Mode: %s\n", p); in msp_log_status()
586 } else if (state->opmode == OPMODE_MANUAL) { in msp_log_status()
587 dev_info(&client->dev, "Mode: %s (%s%s)\n", p, in msp_log_status()
588 (state->rxsubchans & V4L2_TUNER_SUB_STEREO) ? "stereo" : "mono", in msp_log_status()
589 (state->rxsubchans & V4L2_TUNER_SUB_LANG2) ? ", dual" : ""); in msp_log_status()
591 if (state->opmode == OPMODE_AUTODETECT) in msp_log_status()
592 dev_info(&client->dev, "Mode: %s\n", p); in msp_log_status()
593 dev_info(&client->dev, "Standard: %s (%s%s)\n", in msp_log_status()
594 msp_standard_std_name(state->std), in msp_log_status()
595 (state->rxsubchans & V4L2_TUNER_SUB_STEREO) ? "stereo" : "mono", in msp_log_status()
596 (state->rxsubchans & V4L2_TUNER_SUB_LANG2) ? ", dual" : ""); in msp_log_status()
598 dev_info(&client->dev, "Audmode: 0x%04x\n", state->audmode); in msp_log_status()
599 dev_info(&client->dev, "Routing: 0x%08x (input) 0x%08x (output)\n", in msp_log_status()
600 state->route_in, state->route_out); in msp_log_status()
601 dev_info(&client->dev, "ACB: 0x%04x\n", state->acb); in msp_log_status()
609 dev_dbg_lvl(&client->dev, 1, msp_debug, "suspend\n"); in msp_suspend()
617 dev_dbg_lvl(&client->dev, 1, msp_debug, "resume\n"); in msp_resume()
623 /* ----------------------------------------------------------------------- */
657 /* ----------------------------------------------------------------------- */
682 strscpy(client->name, "msp3400", sizeof(client->name)); in msp_probe()
684 if (msp_reset(client) == -1) { in msp_probe()
685 dev_dbg_lvl(&client->dev, 1, msp_debug, "msp3400 not found\n"); in msp_probe()
686 return -ENODEV; in msp_probe()
689 state = devm_kzalloc(&client->dev, sizeof(*state), GFP_KERNEL); in msp_probe()
691 return -ENOMEM; in msp_probe()
693 sd = &state->sd; in msp_probe()
697 state->pads[MSP3400_PAD_IF_INPUT].flags = MEDIA_PAD_FL_SINK; in msp_probe()
698 state->pads[MSP3400_PAD_IF_INPUT].sig_type = PAD_SIGNAL_AUDIO; in msp_probe()
699 state->pads[MSP3400_PAD_OUT].flags = MEDIA_PAD_FL_SOURCE; in msp_probe()
700 state->pads[MSP3400_PAD_OUT].sig_type = PAD_SIGNAL_AUDIO; in msp_probe()
702 sd->entity.function = MEDIA_ENT_F_IF_AUD_DECODER; in msp_probe()
704 ret = media_entity_pads_init(&sd->entity, 2, state->pads); in msp_probe()
709 state->v4l2_std = V4L2_STD_NTSC; in msp_probe()
710 state->detected_std = V4L2_STD_ALL; in msp_probe()
711 state->audmode = V4L2_TUNER_MODE_STEREO; in msp_probe()
712 state->input = -1; in msp_probe()
713 state->i2s_mode = 0; in msp_probe()
714 init_waitqueue_head(&state->wq); in msp_probe()
716 state->route_in = MSP_INPUT_DEFAULT; in msp_probe()
717 state->route_out = MSP_OUTPUT_DEFAULT; in msp_probe()
719 state->rev1 = msp_read_dsp(client, 0x1e); in msp_probe()
720 if (state->rev1 != -1) in msp_probe()
721 state->rev2 = msp_read_dsp(client, 0x1f); in msp_probe()
722 dev_dbg_lvl(&client->dev, 1, msp_debug, "rev1=0x%04x, rev2=0x%04x\n", in msp_probe()
723 state->rev1, state->rev2); in msp_probe()
724 if (state->rev1 == -1 || (state->rev1 == 0 && state->rev2 == 0)) { in msp_probe()
725 dev_dbg_lvl(&client->dev, 1, msp_debug, in msp_probe()
727 return -ENODEV; in msp_probe()
730 msp_family = ((state->rev1 >> 4) & 0x0f) + 3; in msp_probe()
731 msp_product = (state->rev2 >> 8) & 0xff; in msp_probe()
734 msp_revision = (state->rev1 & 0x0f) + '@'; in msp_probe()
735 msp_hard = ((state->rev1 >> 8) & 0xff) + '@'; in msp_probe()
736 msp_rom = state->rev2 & 0x1f; in msp_probe()
738 state->ident = msp_family * 10000 + 4000 + msp_product * 10 + in msp_probe()
739 msp_revision - '@'; in msp_probe()
742 state->has_nicam = in msp_probe()
745 state->has_radio = in msp_probe()
748 state->has_headphones = in msp_probe()
751 state->has_scart2 = in msp_probe()
754 state->has_scart3 = in msp_probe()
757 state->has_scart4 = in msp_probe()
761 state->has_scart2_out = in msp_probe()
763 /* Has scart2 a volume control? Not in pre-D revisions. */ in msp_probe()
764 state->has_scart2_out_volume = in msp_probe()
765 msp_revision > 'C' && state->has_scart2_out; in msp_probe()
766 /* Has a configurable i2s out? */ in msp_probe()
767 state->has_i2s_conf = in msp_probe()
769 /* Has subwoofer output: not in pre-D revs and not in stripped down in msp_probe()
771 state->has_subwoofer = in msp_probe()
775 state->has_sound_processing = in msp_probe()
778 state->has_virtual_dolby_surround = in msp_probe()
781 state->has_dolby_pro_logic = in msp_probe()
785 state->force_btsc = in msp_probe()
788 state->opmode = opmode; in msp_probe()
789 if (state->opmode < OPMODE_MANUAL in msp_probe()
790 || state->opmode > OPMODE_AUTOSELECT) { in msp_probe()
793 state->opmode = OPMODE_AUTOSELECT; in msp_probe()
796 state->opmode = OPMODE_AUTODETECT; in msp_probe()
798 state->opmode = OPMODE_MANUAL; in msp_probe()
801 hdl = &state->hdl; in msp_probe()
803 if (state->has_sound_processing) { in msp_probe()
811 state->volume = v4l2_ctrl_new_std(hdl, &msp_ctrl_ops, in msp_probe()
815 state->muted = v4l2_ctrl_new_std(hdl, &msp_ctrl_ops, in msp_probe()
817 sd->ctrl_handler = hdl; in msp_probe()
818 if (hdl->error) { in msp_probe()
819 int err = hdl->error; in msp_probe()
825 v4l2_ctrl_cluster(2, &state->volume); in msp_probe()
828 dev_info(&client->dev, in msp_probe()
829 "MSP%d4%02d%c-%c%d found on %s: supports %s%s%s, mode is %s\n", in msp_probe()
832 client->adapter->name, in msp_probe()
833 (state->has_nicam) ? "nicam" : "", in msp_probe()
834 (state->has_nicam && state->has_radio) ? " and " : "", in msp_probe()
835 (state->has_radio) ? "radio" : "", in msp_probe()
836 opmode_str[state->opmode]); in msp_probe()
838 /* version-specific initialization */ in msp_probe()
839 switch (state->opmode) { in msp_probe()
853 state->kthread = kthread_run(thread_func, client, "msp34xx"); in msp_probe()
855 if (IS_ERR(state->kthread)) in msp_probe()
856 dev_warn(&client->dev, "kernel_thread() failed\n"); in msp_probe()
866 v4l2_device_unregister_subdev(&state->sd); in msp_remove()
868 if (state->kthread) { in msp_remove()
869 state->restart = 1; in msp_remove()
870 kthread_stop(state->kthread); in msp_remove()
874 v4l2_ctrl_handler_free(&state->hdl); in msp_remove()
877 /* ----------------------------------------------------------------------- */