diff options
author | Mike Isely <isely@pobox.com> | 2009-03-06 22:21:30 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-03-30 11:43:34 -0400 |
commit | af78e16b5d5ba74566814ba0f50ee1d736d933a5 (patch) | |
tree | e679949245b8ea7f79125f7140ba2909496a9635 /drivers/media/video | |
parent | 6907205bcbe7b8bcdc0720bc75e1d2558162d017 (diff) |
V4L/DVB (11171): pvrusb2: Tie in sub-device decoder start/stop
Implement code to send appropriate streaming start/stop commands to
attached sub-devices
Signed-off-by: Mike Isely <isely@pobox.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/pvrusb2/pvrusb2-hdw.c | 65 |
1 files changed, 39 insertions, 26 deletions
diff --git a/drivers/media/video/pvrusb2/pvrusb2-hdw.c b/drivers/media/video/pvrusb2/pvrusb2-hdw.c index 65e65a4f2ec0..74b365f1cfd2 100644 --- a/drivers/media/video/pvrusb2/pvrusb2-hdw.c +++ b/drivers/media/video/pvrusb2/pvrusb2-hdw.c | |||
@@ -1655,19 +1655,29 @@ static const char *pvr2_get_state_name(unsigned int st) | |||
1655 | 1655 | ||
1656 | static int pvr2_decoder_enable(struct pvr2_hdw *hdw,int enablefl) | 1656 | static int pvr2_decoder_enable(struct pvr2_hdw *hdw,int enablefl) |
1657 | { | 1657 | { |
1658 | if (!hdw->decoder_ctrl) { | 1658 | if (hdw->decoder_ctrl) { |
1659 | if (!hdw->flag_decoder_missed) { | 1659 | hdw->decoder_ctrl->enable(hdw->decoder_ctrl->ctxt, enablefl); |
1660 | pvr2_trace(PVR2_TRACE_ERROR_LEGS, | 1660 | return 0; |
1661 | "WARNING: No decoder present"); | ||
1662 | hdw->flag_decoder_missed = !0; | ||
1663 | trace_stbit("flag_decoder_missed", | ||
1664 | hdw->flag_decoder_missed); | ||
1665 | } | ||
1666 | return -EIO; | ||
1667 | } | 1661 | } |
1668 | hdw->decoder_ctrl->enable(hdw->decoder_ctrl->ctxt,enablefl); | 1662 | /* Even though we really only care about the video decoder chip at |
1669 | // ????? | 1663 | this point, we'll broadcast stream on/off to all sub-devices |
1670 | return 0; | 1664 | anyway, just in case somebody else wants to hear the |
1665 | command... */ | ||
1666 | v4l2_device_call_all(&hdw->v4l2_dev, 0, video, s_stream, enablefl); | ||
1667 | if (hdw->decoder_client_id) { | ||
1668 | /* We get here if the encoder has been noticed. Otherwise | ||
1669 | we'll issue a warning to the user (which should | ||
1670 | normally never happen). */ | ||
1671 | return 0; | ||
1672 | } | ||
1673 | if (!hdw->flag_decoder_missed) { | ||
1674 | pvr2_trace(PVR2_TRACE_ERROR_LEGS, | ||
1675 | "WARNING: No decoder present"); | ||
1676 | hdw->flag_decoder_missed = !0; | ||
1677 | trace_stbit("flag_decoder_missed", | ||
1678 | hdw->flag_decoder_missed); | ||
1679 | } | ||
1680 | return -EIO; | ||
1671 | } | 1681 | } |
1672 | 1682 | ||
1673 | 1683 | ||
@@ -4009,23 +4019,26 @@ int pvr2_hdw_cmd_powerdown(struct pvr2_hdw *hdw) | |||
4009 | 4019 | ||
4010 | int pvr2_hdw_cmd_decoder_reset(struct pvr2_hdw *hdw) | 4020 | int pvr2_hdw_cmd_decoder_reset(struct pvr2_hdw *hdw) |
4011 | { | 4021 | { |
4012 | if (!hdw->decoder_ctrl) { | 4022 | pvr2_trace(PVR2_TRACE_INIT, |
4013 | pvr2_trace(PVR2_TRACE_INIT, | 4023 | "Requesting decoder reset"); |
4014 | "Unable to reset decoder: nothing attached"); | 4024 | if (hdw->decoder_ctrl) { |
4015 | return -ENOTTY; | 4025 | if (!hdw->decoder_ctrl->force_reset) { |
4026 | pvr2_trace(PVR2_TRACE_INIT, | ||
4027 | "Unable to reset decoder: not implemented"); | ||
4028 | return -ENOTTY; | ||
4029 | } | ||
4030 | hdw->decoder_ctrl->force_reset(hdw->decoder_ctrl->ctxt); | ||
4031 | return 0; | ||
4032 | } else { | ||
4016 | } | 4033 | } |
4017 | 4034 | if (hdw->decoder_client_id) { | |
4018 | if (!hdw->decoder_ctrl->force_reset) { | 4035 | v4l2_device_call_all(&hdw->v4l2_dev, hdw->decoder_client_id, |
4019 | pvr2_trace(PVR2_TRACE_INIT, | 4036 | core, reset, 0); |
4020 | "Unable to reset decoder: not implemented"); | 4037 | return 0; |
4021 | return -ENOTTY; | ||
4022 | } | 4038 | } |
4023 | |||
4024 | pvr2_trace(PVR2_TRACE_INIT, | 4039 | pvr2_trace(PVR2_TRACE_INIT, |
4025 | "Requesting decoder reset"); | 4040 | "Unable to reset decoder: nothing attached"); |
4026 | hdw->decoder_ctrl->force_reset(hdw->decoder_ctrl->ctxt); | 4041 | return -ENOTTY; |
4027 | // ????? | ||
4028 | return 0; | ||
4029 | } | 4042 | } |
4030 | 4043 | ||
4031 | 4044 | ||