2009-10-16 12:26:34 +00:00
|
|
|
From becda6e9e9f8edb0042c0ca4844228ccfc907a7b Mon Sep 17 00:00:00 2001
|
2009-10-14 13:40:05 +00:00
|
|
|
From: Tomas Bzatek <tbzatek@redhat.com>
|
2009-10-16 12:26:34 +00:00
|
|
|
Date: Tue, 13 Oct 2009 17:13:02 +0200
|
2009-10-14 13:40:05 +00:00
|
|
|
Subject: [PATCH 3/3] Silently drop eject error messages when detaching drive
|
|
|
|
|
|
|
|
If there's no media in drive and yet it's marked as detachable,
|
|
|
|
calling eject would cause "no media in drive" error.
|
|
|
|
This is the case with my USB SD card reader.
|
|
|
|
---
|
|
|
|
monitor/gdu/ggdudrive.c | 15 +++++++++++++--
|
|
|
|
1 files changed, 13 insertions(+), 2 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/monitor/gdu/ggdudrive.c b/monitor/gdu/ggdudrive.c
|
2009-10-16 12:26:34 +00:00
|
|
|
index 79c6809..309e18c 100644
|
2009-10-14 13:40:05 +00:00
|
|
|
--- a/monitor/gdu/ggdudrive.c
|
|
|
|
+++ b/monitor/gdu/ggdudrive.c
|
2009-10-16 12:26:34 +00:00
|
|
|
@@ -641,6 +641,18 @@ eject_cb (GduDevice *device,
|
2009-10-14 13:40:05 +00:00
|
|
|
{
|
|
|
|
GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (user_data);
|
|
|
|
GGduDrive *drive;
|
|
|
|
+ gboolean drive_detachable;
|
|
|
|
+
|
|
|
|
+ drive = G_GDU_DRIVE (g_async_result_get_source_object (G_ASYNC_RESULT (simple)));
|
|
|
|
+ drive_detachable = drive->can_stop == FALSE && drive->start_stop_type == G_DRIVE_START_STOP_TYPE_SHUTDOWN;
|
|
|
|
+
|
2009-10-16 12:26:34 +00:00
|
|
|
+ if (error != NULL && error->code == G_IO_ERROR_FAILED &&
|
2009-10-14 13:40:05 +00:00
|
|
|
+ drive_detachable && ! drive->has_media && drive->is_media_removable)
|
|
|
|
+ {
|
|
|
|
+ /* Silently drop the error if there's no media in drive and we're still trying to detach it (see below) */
|
|
|
|
+ g_error_free (error);
|
|
|
|
+ error = NULL;
|
|
|
|
+ }
|
|
|
|
|
|
|
|
if (error != NULL)
|
|
|
|
{
|
2009-10-16 12:26:34 +00:00
|
|
|
@@ -651,8 +663,7 @@ eject_cb (GduDevice *device,
|
2009-10-14 13:40:05 +00:00
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
- drive = G_GDU_DRIVE (g_async_result_get_source_object (G_ASYNC_RESULT (simple)));
|
|
|
|
- if (drive->can_stop == FALSE && drive->start_stop_type == G_DRIVE_START_STOP_TYPE_SHUTDOWN)
|
|
|
|
+ if (drive_detachable)
|
|
|
|
{
|
|
|
|
/* If device is not ejectable but it is detachable and we don't support stop(),
|
|
|
|
* then also run Detach() after Eject() - see update_drive() for details for why...
|
|
|
|
--
|
|
|
|
1.6.5.rc2
|
|
|
|
|