diff options
author | Stéphane Loeuillet <gstreamer@leroutier.net> | 2004-05-31 14:16:54 +0000 |
---|---|---|
committer | Stéphane Loeuillet <gstreamer@leroutier.net> | 2004-05-31 14:16:54 +0000 |
commit | 011ce368b214f489a7efe6917da5ece305f03e81 (patch) | |
tree | 34160595fca2a03faaf4881d19a0692cc1273808 /sys/v4l2/v4l2_calls.c | |
parent | 65f1dc9e434669d152747eb787485c369337544e (diff) | |
download | gst-plugins-bad-011ce368b214f489a7efe6917da5ece305f03e81.tar.gz gst-plugins-bad-011ce368b214f489a7efe6917da5ece305f03e81.tar.bz2 gst-plugins-bad-011ce368b214f489a7efe6917da5ece305f03e81.zip |
gst-libs/gst/tuner/tunerchannel.h: - add a freq_multiplicator field to make the conversion between internal frequency...
Original commit message from CVS:
* gst-libs/gst/tuner/tunerchannel.h:
- add a freq_multiplicator field to make the conversion
between internal frequency unit and Hz
* sys/v4l/gstv4lelement.c:
* sys/v4l2/gstv4l2element.c:
- change default video device to /dev/video0
* sys/v4l/v4l_calls.c:
* sys/v4l2/v4l2_calls.c:
- we only expose frequency to the user in Hz instead of
bastard v4lX unit (either 62.5kHz or 62.5Hz)
Diffstat (limited to 'sys/v4l2/v4l2_calls.c')
-rw-r--r-- | sys/v4l2/v4l2_calls.c | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/sys/v4l2/v4l2_calls.c b/sys/v4l2/v4l2_calls.c index 92de8a42..7b32ad7c 100644 --- a/sys/v4l2/v4l2_calls.c +++ b/sys/v4l2/v4l2_calls.c @@ -123,8 +123,10 @@ gst_v4l2_fill_lists (GstV4l2Element * v4l2element) g_object_unref (G_OBJECT (channel)); return FALSE; } - channel->min_frequency = vtun.rangelow; - channel->max_frequency = vtun.rangehigh; + channel->freq_multiplicator = + 62.5 * ((vtun.capability & V4L2_TUNER_CAP_LOW) ? 1 : 1000); + channel->min_frequency = vtun.rangelow * channel->freq_multiplicator; + channel->max_frequency = vtun.rangehigh * channel->freq_multiplicator; channel->min_signal = 0; channel->max_signal = 0xffff; } @@ -620,10 +622,13 @@ gst_v4l2_get_frequency (GstV4l2Element * v4l2element, gint tunernum, gulong * frequency) { struct v4l2_frequency freq; + GstTunerChannel *channel; DEBUG ("getting current tuner frequency"); GST_V4L2_CHECK_OPEN (v4l2element); + channel = gst_tuner_get_channel (GST_TUNER (v4l2element)); + freq.tuner = tunernum; if (ioctl (v4l2element->video_fd, VIDIOC_G_FREQUENCY, &freq) < 0) { GST_ELEMENT_ERROR (v4l2element, RESOURCE, SETTINGS, (NULL), @@ -632,7 +637,7 @@ gst_v4l2_get_frequency (GstV4l2Element * v4l2element, return FALSE; } - *frequency = freq.frequency; + *frequency = freq.frequency * channel->freq_multiplicator; return TRUE; } @@ -649,15 +654,18 @@ gst_v4l2_set_frequency (GstV4l2Element * v4l2element, gint tunernum, gulong frequency) { struct v4l2_frequency freq; + GstTunerChannel *channel; DEBUG ("setting current tuner frequency to %lu", frequency); GST_V4L2_CHECK_OPEN (v4l2element); GST_V4L2_CHECK_NOT_ACTIVE (v4l2element); + channel = gst_tuner_get_channel (GST_TUNER (v4l2element)); + freq.tuner = tunernum; /* fill in type - ignore error */ ioctl (v4l2element->video_fd, VIDIOC_G_FREQUENCY, &freq); - freq.frequency = frequency; + freq.frequency = frequency / channel->freq_multiplicator; if (ioctl (v4l2element->video_fd, VIDIOC_S_FREQUENCY, &freq) < 0) { GST_ELEMENT_ERROR (v4l2element, RESOURCE, SETTINGS, (NULL), |