diff options
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/video/cx2341x.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/drivers/media/video/cx2341x.c b/drivers/media/video/cx2341x.c index 65f00fc08fa9..657e0b969145 100644 --- a/drivers/media/video/cx2341x.c +++ b/drivers/media/video/cx2341x.c | |||
@@ -691,7 +691,7 @@ void cx2341x_fill_defaults(struct cx2341x_mpeg_params *p) | |||
691 | .video_luma_spatial_filter_type = V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_HOR, | 691 | .video_luma_spatial_filter_type = V4L2_MPEG_CX2341X_VIDEO_LUMA_SPATIAL_FILTER_TYPE_1D_HOR, |
692 | .video_chroma_spatial_filter_type = V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_1D_HOR, | 692 | .video_chroma_spatial_filter_type = V4L2_MPEG_CX2341X_VIDEO_CHROMA_SPATIAL_FILTER_TYPE_1D_HOR, |
693 | .video_temporal_filter_mode = V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_MANUAL, | 693 | .video_temporal_filter_mode = V4L2_MPEG_CX2341X_VIDEO_TEMPORAL_FILTER_MODE_MANUAL, |
694 | .video_temporal_filter = 0, | 694 | .video_temporal_filter = 8, |
695 | .video_median_filter_type = V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_OFF, | 695 | .video_median_filter_type = V4L2_MPEG_CX2341X_VIDEO_MEDIAN_FILTER_TYPE_OFF, |
696 | .video_luma_median_filter_top = 255, | 696 | .video_luma_median_filter_top = 255, |
697 | .video_luma_median_filter_bottom = 0, | 697 | .video_luma_median_filter_bottom = 0, |
@@ -731,6 +731,7 @@ int cx2341x_update(void *priv, cx2341x_mbox_func func, | |||
731 | }; | 731 | }; |
732 | 732 | ||
733 | int err = 0; | 733 | int err = 0; |
734 | u16 temporal = new->video_temporal_filter; | ||
734 | 735 | ||
735 | cx2341x_api(priv, func, CX2341X_ENC_SET_OUTPUT_PORT, 2, new->port, 0); | 736 | cx2341x_api(priv, func, CX2341X_ENC_SET_OUTPUT_PORT, 2, new->port, 0); |
736 | 737 | ||
@@ -741,6 +742,7 @@ int cx2341x_update(void *priv, cx2341x_mbox_func func, | |||
741 | 742 | ||
742 | if (old == NULL || old->width != new->width || old->height != new->height || | 743 | if (old == NULL || old->width != new->width || old->height != new->height || |
743 | old->video_encoding != new->video_encoding) { | 744 | old->video_encoding != new->video_encoding) { |
745 | int is_scaling; | ||
744 | u16 w = new->width; | 746 | u16 w = new->width; |
745 | u16 h = new->height; | 747 | u16 h = new->height; |
746 | 748 | ||
@@ -750,6 +752,20 @@ int cx2341x_update(void *priv, cx2341x_mbox_func func, | |||
750 | } | 752 | } |
751 | err = cx2341x_api(priv, func, CX2341X_ENC_SET_FRAME_SIZE, 2, h, w); | 753 | err = cx2341x_api(priv, func, CX2341X_ENC_SET_FRAME_SIZE, 2, h, w); |
752 | if (err) return err; | 754 | if (err) return err; |
755 | |||
756 | /* Adjust temporal filter if necessary. The problem with the temporal | ||
757 | filter is that it works well with full resolution capturing, but | ||
758 | not when the capture window is scaled (the filter introduces | ||
759 | a ghosting effect). So if the capture window changed, and there is | ||
760 | no updated filter value, then the filter is set depending on whether | ||
761 | the new window is full resolution or not. | ||
762 | |||
763 | For full resolution a setting of 8 really improves the video | ||
764 | quality, especially if the original video quality is suboptimal. */ | ||
765 | is_scaling = new->width != 720 || new->height != (new->is_50hz ? 576 : 480); | ||
766 | if (old && old->video_temporal_filter == temporal) { | ||
767 | temporal = is_scaling ? 0 : 8; | ||
768 | } | ||
753 | } | 769 | } |
754 | 770 | ||
755 | if (old == NULL || old->stream_type != new->stream_type) { | 771 | if (old == NULL || old->stream_type != new->stream_type) { |
@@ -815,9 +831,9 @@ int cx2341x_update(void *priv, cx2341x_mbox_func func, | |||
815 | } | 831 | } |
816 | if (old == NULL || | 832 | if (old == NULL || |
817 | old->video_spatial_filter != new->video_spatial_filter || | 833 | old->video_spatial_filter != new->video_spatial_filter || |
818 | old->video_temporal_filter != new->video_temporal_filter) { | 834 | old->video_temporal_filter != temporal) { |
819 | err = cx2341x_api(priv, func, CX2341X_ENC_SET_DNR_FILTER_PROPS, 2, | 835 | err = cx2341x_api(priv, func, CX2341X_ENC_SET_DNR_FILTER_PROPS, 2, |
820 | new->video_spatial_filter, new->video_temporal_filter); | 836 | new->video_spatial_filter, temporal); |
821 | if (err) return err; | 837 | if (err) return err; |
822 | } | 838 | } |
823 | if (old == NULL || old->video_temporal_decimation != new->video_temporal_decimation) { | 839 | if (old == NULL || old->video_temporal_decimation != new->video_temporal_decimation) { |
@@ -855,6 +871,9 @@ void cx2341x_log_status(struct cx2341x_mpeg_params *p, const char *prefix) | |||
855 | printk(KERN_INFO "%s: Stream: %s\n", | 871 | printk(KERN_INFO "%s: Stream: %s\n", |
856 | prefix, | 872 | prefix, |
857 | cx2341x_menu_item(p, V4L2_CID_MPEG_STREAM_TYPE)); | 873 | cx2341x_menu_item(p, V4L2_CID_MPEG_STREAM_TYPE)); |
874 | printk(KERN_INFO "%s: VBI Format: %s\n", | ||
875 | prefix, | ||
876 | cx2341x_menu_item(p, V4L2_CID_MPEG_STREAM_VBI_FMT)); | ||
858 | 877 | ||
859 | /* Video */ | 878 | /* Video */ |
860 | printk(KERN_INFO "%s: Video: %dx%d, %d fps\n", | 879 | printk(KERN_INFO "%s: Video: %dx%d, %d fps\n", |