sys/oss/gstosssrc.c: Set bytes_per_sample correctly (is not always 4, but depends...
authorTim-Philipp Müller <tim@centricular.net>
Mon, 24 Oct 2005 15:57:17 +0000 (15:57 +0000)
committerTim-Philipp Müller <tim@centricular.net>
Mon, 24 Oct 2005 15:57:17 +0000 (15:57 +0000)
Original commit message from CVS:
* sys/oss/gstosssrc.c: (gst_oss_src_prepare):
Set bytes_per_sample correctly (is not always 4, but
depends on width and number of channels).

ChangeLog
sys/oss/gstosssrc.c

index 5f35c0164722f0eca0fa1da5e64c0f86ee72bcc5..0d60da63d6293c4e0d5ad0c6b2f3e674aacbbfc3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2005-10-24  Tim-Philipp Müller  <tim at centricular dot net>
+
+       * sys/oss/gstosssrc.c: (gst_oss_src_prepare):
+         Set bytes_per_sample correctly (is not always 4, but 
+         depends on width and number of channels).
+
 2005-10-24  Tim-Philipp Müller  <tim at centricular dot net>
 
        * ext/flac/gstflacenc.c: (gst_flacenc_base_init),
index 6c2f70082a682dabcfa0947771f1a66bdeea9f48..bb5d7caa7674b2a8e6ad9941b94a3b29c2bdb9e6 100644 (file)
@@ -389,8 +389,12 @@ gst_oss_src_prepare (GstAudioSrc * asrc, GstRingBufferSpec * spec)
 
   spec->segsize = info.fragsize;
   spec->segtotal = info.fragstotal;
-  spec->bytes_per_sample = 4;
-  oss->bytes_per_sample = 4;
+
+  if (spec->width != 16 && spec->width != 8)
+    goto dodgy_width;
+
+  spec->bytes_per_sample = (spec->width / 8) * spec->channels;
+  oss->bytes_per_sample = (spec->width / 8) * spec->channels;
   memset (spec->silence_sample, 0, spec->bytes_per_sample);
 
   GST_DEBUG ("got segsize: %d, segtotal: %d, value: %08x", spec->segsize,
@@ -411,6 +415,12 @@ wrong_format:
         ("Unable to get format %d", spec->format), (NULL));
     return FALSE;
   }
+dodgy_width:
+  {
+    GST_ELEMENT_ERROR (oss, RESOURCE, OPEN_READ,
+        ("Unexpected width %d", spec->width), (NULL));
+    return FALSE;
+  }
 }
 
 static gboolean