forked from enlightenment/efl
revert remaining broken/wrong mount timeout behavior added recently
SVN revision: 74785
This commit is contained in:
parent
e0cec4d456
commit
917ce85269
|
@ -283,11 +283,6 @@ eeze_disk_free(Eeze_Disk *disk)
|
||||||
if (disk->mounter) ecore_exe_kill(disk->mounter);
|
if (disk->mounter) ecore_exe_kill(disk->mounter);
|
||||||
_eeze_disks = eina_list_remove(_eeze_disks, disk);
|
_eeze_disks = eina_list_remove(_eeze_disks, disk);
|
||||||
eeze_events = eina_list_remove(eeze_events, disk);
|
eeze_events = eina_list_remove(eeze_events, disk);
|
||||||
if (disk->mount_fail_delay)
|
|
||||||
{
|
|
||||||
ecore_timer_del(disk->mount_fail_delay);
|
|
||||||
disk->mount_fail_delay = NULL;
|
|
||||||
}
|
|
||||||
free(disk);
|
free(disk);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,49 +48,12 @@ _eeze_disk_mount_error_handler(Eeze_Disk *disk, const char *error)
|
||||||
if (!(de = calloc(1, sizeof(Eeze_Event_Disk_Error))))
|
if (!(de = calloc(1, sizeof(Eeze_Event_Disk_Error))))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (disk->mount_fail_delay)
|
|
||||||
{
|
|
||||||
ecore_timer_del(disk->mount_fail_delay);
|
|
||||||
disk->mount_fail_delay = NULL;
|
|
||||||
}
|
|
||||||
de->disk = disk;
|
de->disk = disk;
|
||||||
de->message = eina_stringshare_add(error);
|
de->message = eina_stringshare_add(error);
|
||||||
/* FIXME: placeholder since currently there are only mount-type errors */
|
/* FIXME: placeholder since currently there are only mount-type errors */
|
||||||
ecore_event_add(EEZE_EVENT_DISK_ERROR, de, (Ecore_End_Cb)_eeze_disk_mount_error_free, NULL);
|
ecore_event_add(EEZE_EVENT_DISK_ERROR, de, (Ecore_End_Cb)_eeze_disk_mount_error_free, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Eina_Bool
|
|
||||||
_eeze_disk_mount_fail_delay_check(void *data)
|
|
||||||
{
|
|
||||||
Eeze_Disk *disk = data;
|
|
||||||
|
|
||||||
disk->fail_pol_check++;
|
|
||||||
if (eeze_disk_mounted_get(disk))
|
|
||||||
{
|
|
||||||
Eeze_Event_Disk_Mount *e;
|
|
||||||
|
|
||||||
disk->mounted = EINA_TRUE;
|
|
||||||
e = malloc(sizeof(Eeze_Event_Disk_Mount));
|
|
||||||
if (e)
|
|
||||||
{
|
|
||||||
e->disk = disk;
|
|
||||||
ecore_event_add(EEZE_EVENT_DISK_MOUNT, e, NULL, NULL);
|
|
||||||
}
|
|
||||||
return EINA_FALSE;
|
|
||||||
}
|
|
||||||
if (disk->fail_pol_check > 30)
|
|
||||||
{
|
|
||||||
if (disk->mount_fail_delay)
|
|
||||||
{
|
|
||||||
ecore_timer_del(disk->mount_fail_delay);
|
|
||||||
disk->mount_fail_delay = NULL;
|
|
||||||
}
|
|
||||||
_eeze_disk_mount_error_handler(disk, "mount failure");
|
|
||||||
return EINA_FALSE;
|
|
||||||
}
|
|
||||||
return EINA_TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static Eina_Bool
|
static Eina_Bool
|
||||||
_eeze_disk_mount_result_handler(void *data __UNUSED__, int type __UNUSED__, Ecore_Exe_Event_Del *ev)
|
_eeze_disk_mount_result_handler(void *data __UNUSED__, int type __UNUSED__, Ecore_Exe_Event_Del *ev)
|
||||||
{
|
{
|
||||||
|
@ -115,19 +78,6 @@ _eeze_disk_mount_result_handler(void *data __UNUSED__, int type __UNUSED__, Ecor
|
||||||
{
|
{
|
||||||
disk->mounter = NULL;
|
disk->mounter = NULL;
|
||||||
if (!ev->exit_code)
|
if (!ev->exit_code)
|
||||||
{
|
|
||||||
if (!eeze_disk_mounted_get(disk))
|
|
||||||
{
|
|
||||||
/* libmount seems to have a nasty race condition... or
|
|
||||||
* mount .. or something... the mount exe returns
|
|
||||||
* BUT its not mounted yet! so poll for a bit.. and see */
|
|
||||||
if (!disk->mount_fail_delay)
|
|
||||||
disk->mount_fail_delay =
|
|
||||||
ecore_timer_add(0.1, _eeze_disk_mount_fail_delay_check,
|
|
||||||
disk);
|
|
||||||
disk->fail_pol_check = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
disk->mounted = EINA_TRUE;
|
disk->mounted = EINA_TRUE;
|
||||||
e = malloc(sizeof(Eeze_Event_Disk_Mount));
|
e = malloc(sizeof(Eeze_Event_Disk_Mount));
|
||||||
|
@ -135,7 +85,6 @@ _eeze_disk_mount_result_handler(void *data __UNUSED__, int type __UNUSED__, Ecor
|
||||||
e->disk = disk;
|
e->disk = disk;
|
||||||
ecore_event_add(EEZE_EVENT_DISK_MOUNT, e, NULL, NULL);
|
ecore_event_add(EEZE_EVENT_DISK_MOUNT, e, NULL, NULL);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else if (ev->exit_code & 2)
|
else if (ev->exit_code & 2)
|
||||||
_eeze_disk_mount_error_handler(disk, "system error (out of memory, cannot fork, no more loop devices)");
|
_eeze_disk_mount_error_handler(disk, "system error (out of memory, cannot fork, no more loop devices)");
|
||||||
else if (ev->exit_code & 4)
|
else if (ev->exit_code & 4)
|
||||||
|
@ -472,11 +421,6 @@ eeze_disk_cancel(Eeze_Disk *disk)
|
||||||
disk->mount_status = EEZE_DISK_NULL;
|
disk->mount_status = EEZE_DISK_NULL;
|
||||||
ecore_exe_kill(disk->mounter);
|
ecore_exe_kill(disk->mounter);
|
||||||
disk->mounter = NULL;
|
disk->mounter = NULL;
|
||||||
if (disk->mount_fail_delay)
|
|
||||||
{
|
|
||||||
ecore_timer_del(disk->mount_fail_delay);
|
|
||||||
disk->mount_fail_delay = NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI const char *
|
EAPI const char *
|
||||||
|
|
|
@ -51,9 +51,7 @@ struct _Eeze_Disk
|
||||||
Eina_Bool unmount_cmd_changed : 1;
|
Eina_Bool unmount_cmd_changed : 1;
|
||||||
Eina_Bool mounted : 1;
|
Eina_Bool mounted : 1;
|
||||||
Ecore_Exe *mounter;
|
Ecore_Exe *mounter;
|
||||||
Ecore_Timer *mount_fail_delay;
|
|
||||||
unsigned int mount_fail_count;
|
unsigned int mount_fail_count;
|
||||||
int fail_pol_check;
|
|
||||||
|
|
||||||
const char *syspath;
|
const char *syspath;
|
||||||
const char *devpath;
|
const char *devpath;
|
||||||
|
|
Loading…
Reference in New Issue