Udisks2 prevents HDDs from going to standby because of polling SMART information

Bug #1373318 reported by TheNinja
This bug report is a duplicate of:  Bug #1281588: Disk standby timer is broken. Edit Remove
42
This bug affects 8 people
Affects Status Importance Assigned to Milestone
udisks2 (Ubuntu)
Confirmed
Undecided
Unassigned

Bug Description

1) Ubuntu Version:
Description: Ubuntu 14.04.1 LTS
Release: 14.04

2) Package Version
udisks2:
  Installiert: 2.1.3-1
  Installationskandidat: 2.1.3-1
  Versionstabelle:
 *** 2.1.3-1 0
        500 http://archive.ubuntu.com/ubuntu/ trusty/main i386 Packages
        100 /var/lib/dpkg/status

3) What I expected to happen:
My two Seagate drives go to sleep after 10 minutes of inactivity.

4) What happened instead:
The drives stay on all the time.

The full story:
The problem is that the minimum time for the drives to go to sleep is 10 minutes, but they are kept awake by the udisks2 daemon which polls them every 10 minutes for SMART data, resetting the idle timer by doing so. Also this might not happen to all drives, there should be a workaround.
Would be great if the patch proposed here [1] would also be integrated into udisks2.
A more universal approach might be to make the polling interval configurable with 0=polling disabled.

Disabling SMART for the disks works partially:

a) The following UDEV flags don't have any effect:
E: ID_ATA_FEATURE_SET_SMART=0
E: ID_ATA_FEATURE_SET_SMART_ENABLED=0
E: UDISKS_DISABLE_POLLING=1
E: UDISKS_IGNORE=1

b) The following works:
(Note: without killing the daemon, according to "udisksctl monitor" it keeps polling.
By polling, the SMART support is reactivated, which seems to be some unexpected behaviour from libatasmart [2])

sudo killall udisksd
sudo smartctl --smart=off /dev/sdb
# verify
sudo smartctl --all /dev/sdb | grep "SMART support"
I think it is quite a bad workaround to kill the deamon after every reboot to be able to diable SMART. And disabling SMART is not good either, but it would be fine for me as workaround.

[1] https://www.libreoffice.org/bugzilla/show_bug.cgi?id=26508

[2] can be verified with
sudo smartctl --smart=off /dev/sdb
sudo smartctl --all /dev/sdb | grep "SMART support"
sudo skdump --overall /dev/sdb
sudo smartctl --all /dev/sdb | grep "SMART support"

PS:
This is mainly about the old udisks1, but may provide some additional information:
https://www.libreoffice.org/bugzilla/show_bug.cgi?id=26508
This is about gnome-disk-utility, but the underlying problem seems udisks2
https://bugzilla.redhat.com/show_bug.cgi?id=1047339

Tags: patch
TheNinja (uss-ninja)
description: updated
description: updated
TheNinja (uss-ninja)
description: updated
Revision history for this message
TheNinja (uss-ninja) wrote :

So, I did some debugging and I can confirm that changing the houskeeping from 10 minutes to at least 11 minutes fixes the problem for me. I attached a patch that changes the housekeeping to 15 minutes.

btw: I cloned from here
http://anonscm.debian.org/cgit/pkg-utopia/udisks2.git/
(git://anonscm.debian.org/pkg-utopia/udisks2.git)
I hope that's the right repository.

Revision history for this message
TheNinja (uss-ninja) wrote :

In addition to the above patch, I made the housekeeping more configurable. It adds the commandline parameter "housekeeping" which can be used to set the amount of minutes of the interval (0=disable housekeeping). Might not be a clean implementation, but at least it's pretty straight forward to get the idea.

To apply the changes in the system add "--housekeeping=15" to the command lines in
/usr/share/dbus-1/system-services/org.freedesktop.UDisks2.service
and
/lib/systemd/system/udisks2.service

Revision history for this message
TheNinja (uss-ninja) wrote :

Another hint: If you want to compile udisks, use ./configure --prefix=/usr if you want to replace udisksd on your system otherwise the new version will be in /usr/local/lib/udisks2/.

Revision history for this message
Ubuntu Foundations Team Bug Bot (crichton) wrote :

The attachment "Changes the housekeeping to 15 minutes" seems to be a patch. If it isn't, please remove the "patch" flag from the attachment, remove the "patch" tag, and if you are a member of the ~ubuntu-reviewers, unsubscribe the team.

[This is an automated message performed by a Launchpad user owned by ~brian-murray, for any issues please contact him.]

tags: added: patch
Revision history for this message
Launchpad Janitor (janitor) wrote :

Status changed to 'Confirmed' because the bug affects multiple users.

Changed in udisks2 (Ubuntu):
status: New → Confirmed
To post a comment you must log in.
This report contains Public information  
Everyone can see this information.

Other bug subscribers

Remote bug watches

Bug watches keep track of this bug in other bug trackers.