Removed bogus patch 1.4 to make osssrc work again.
authorWim Taymans <wim.taymans@gmail.com>
Mon, 27 Jan 2003 20:36:46 +0000 (20:36 +0000)
committerWim Taymans <wim.taymans@gmail.com>
Mon, 27 Jan 2003 20:36:46 +0000 (20:36 +0000)
Original commit message from CVS:
Removed bogus patch 1.4 to make osssrc work again.

sys/oss/gstosscommon.c

index 255ac6a031a1fcc202171a692f7797c214873cb8..fe55656447c0021a1159ddb63df921822eeef780 100644 (file)
@@ -281,41 +281,25 @@ gst_osscommon_open_audio (GstOssCommon *common, GstOssOpenMode mode, gchar **err
   GST_INFO (GST_CAT_PLUGIN_INFO, "common: attempting to open sound device");
 
   /* first try to open the sound card */
-  /* FIXME: This code is dubious, why do we need to open and close this ?
-   *        For linux at least this causes the second open to never return
-   *        if the device was already in use .. */
-#ifndef __linux__
   if (mode == GST_OSSCOMMON_WRITE) {
-#endif
+    /* open non blocking first so that it returns immediatly with an error
+     * when we cannot get to the device */
     common->fd = open (common->device, O_WRONLY | O_NONBLOCK);
-#ifdef __linux__
-       if (common->fd >= 0) {
-         /* remove the non-blocking flag */
-         if(fcntl (common->fd, F_SETFL, 0) < 0) {
-               *error = g_strdup_printf ("osscommon: Can't make filedescriptor blocking for %s",
-                                  common->device);
-               return FALSE;
-         }
-       }
-#else
-    if (errno == EBUSY) {
-      g_warning ("osscommon: unable to open the sound device (in use ?)\n");
-    }
 
-    if (common->fd >= 0)
+    if (common->fd >= 0) {
       close (common->fd);
-  
-    /* re-open the sound device in blocking mode */
-    common->fd = open (common->device, O_WRONLY);
+                         
+      /* re-open the sound device in blocking mode */
+      common->fd = open (common->device, O_WRONLY);
+    }
   }
   else {
     common->fd = open (common->device, O_RDONLY);
   }
-#endif
 
   if (common->fd < 0) {
     switch (errno) {
-         case EBUSY:
+      case EBUSY:
        *error = g_strdup_printf ("osscommon: Unable to open %s (in use ?)",
                           common->device);
        break;