From Fedora Project Wiki
 
(94 intermediate revisions by 8 users not shown)
Line 5: Line 5:
== Summary ==
== Summary ==


DeviceKit is a simple system service that a) can enumerate devices; b) emits signals when devices are added removed; c) provides a way to merge device information / quirks onto devices. It is designed to partially replace hal and overcome some of the design limitiations of hal.
'''DeviceKit''' is a simple system service that a) can enumerate devices; b) emits signals when devices are added or removed; c) provides a way to merge device information / quirks onto devices. It is designed to partially replace hal and overcome some of the design limitiations of hal. DeviceKit functionality is provided in the form of dbus services on the system bus.


Apart from DeviceKit itself, there is DeviceKit-disks, which is a system service to keep track of block devices, and gnome-disk-utility, which is a graphical frontend for DeviceKit-disks.
Apart from DeviceKit itself, there is '''DeviceKit-disks''', which is a system service to keep track of block devices. The functionality offered by DeviceKit-disks is a superset of what hal provides for block devices.


Furthermore, there will be a nautilus extension to format disks.
There is also '''DeviceKit-power''', which takes over the power-management-related parts of hal and the more complex functionality of gnome-power-manager. As a consequence, gnome-power-manager itself becomes much simpler.
 
The new '''udev-extra''' module will provide udev rules that are needed to make the DeviceKit architecture work.
Functionality that was provided via .fdi files in hal will eventually be moved to udev rules, and setting acls on devices will also be done here at some point.
 
DeviceKit-disks comes with a graphical frontend called '''palimpsest''' (the package name is '''gnome-disk-utility'''). Furthermore, there's a nautilus extension to format disks ('''nautilus-gdu'''), accessible from context menu.


== Owner ==
== Owner ==
* Name: DavidZeuthen
* Name: [[DavidZeuthen | David Zeuthen]], [[RichardHughes | Richard Hughes]], [[TomasBzatek | Tomáš Bžatek]]


== Current status ==
== Current status ==
* Targeted release: [[Releases/10|  Fedora 10]]  
* Targeted release: [[Releases/11|  Fedora 11]]  
* Last updated: 2008-07-10
* Last updated: 2009-03-06
* Percentage of completion: 50%
* Percentage of completion: 100%
 
DeviceKit, DeviceKit-disks, DeviceKit-power and gnome-disk-utility (i.e. palimpsest) packages have been built in rawhide.


DeviceKit is still not in rawhide, since there are still some device-mapper prerequisites missing. The current goal is to have it in rawhide by F10 alpha.
gnome-power-manager 2.25 in rawhide uses DeviceKit-power instead of hal.
 
The port of gvfs to DeviceKit-disks is in rawhide.
 
udev-extras is hosted on [http://git.kernel.org/?p=linux/hotplug/udev-extras.git;a=summary kernel.org]
and has been packaged for rawhide.
 
The nautilus extension for disk formatting is being worked on [http://fedorapeople.org/gitweb?p=tbzatek/public_git/nautilus-gdu.git;a=summary here]. It is called nautilus-gdu. It is available in rawhide.
 
Still todo:
* remove the properties page from gnome-mount
* add a status icon for smart warnings, critical raid events and delayed write warnings
* bug fixes


== Detailed Description ==
== Detailed Description ==
Line 34: Line 53:
== Scope ==
== Scope ==


DeviceKit depends on bug fixes and enhancements in unreleased versions of a number of components, such as kernel, udev, mdadm, lvm. These will have to appear in rawhide first. Also, in order to peacefully coexist with DeviceKit-disks, hal will need to undergo disk-ectomy. Components which depend directly on the disk functionality in hal, such as gvfs, Solid and thunar-volman, have to be ported to DeviceKit-disks.
DeviceKit depends on bug fixes and enhancements in the following components: kernel, udev, mdadm, and lvm. These will have to appear in rawhide first.  


For completeness, here is a list of all packages in Fedora that depend on hal, libhal.so.1 or libhal-storage.so.1.  
Also, in order to peacefully coexist with DeviceKit-disks, at a very minimum
hal needs to talk to DeviceKit-disks about locking and mounting/unmounting.
Medium term, hal functionality such as disk and power-management support will
be turned off when all important users have been ported over to the equivalent DeviceKit api.
The core components that we plan to port for F11 are: gvfs, gnome-mount, nautilus and gnome-power-manager.


* anaconda - will be ported when and if the installer team thinks that is a good idea
For completeness, [[Features/DeviceKit/HalDependencies]] is a list of ''all'' packages in Fedora that depend on hal, libhal.so.1 or libhal-storage.so.1. Except where noted, we don't expect to port these to DeviceKit for F11.
* bluez-gnome - only uses libhal to get the formfactor, should be fine
* brasero - uses libhal to interact with drives, needs porting
* cheese - uses libhal to find webcams, should be fine
* concordance - only requires hal to install fdi files, should be fine
* conexusmm - uses libhal to find serial ports, should be fine
* control-center - uses libhal to find sound devices, should be fine
* emelfm2 - uses libhal to find storage devices, needs porting
* evolution - ipod plugin uses libhal to find ipod devices, needs porting
* exo - uses libhal to find storage devices, needs porting
* gdm - should be fine
* gimp - uses libhal to find input devices, should be fine
* gnomad2 - uses libhal to find portable audio players, should be fine
* gnome-device-manager - needs porting
* gnome-keyring - uses libhal to monitor removable storage devices, needs porting
* gnome-mount - needs porting
* gnome-pilot - uses libhal to find usb devices, should be fine
* gnome-power-manager - needs porting to DeviceKit-power
* gnome-utils - uses libhal to find floppy device, needs porting
* gnome-vfs2 - needs porting
* gnome-volume-manager - uses libhal to handle volumes, needs porting
* gparted
* gstreamer-plugins-good
* gtkpod
* gvfs - needs porting
* gxine
* hal-cups-utils
* halevt
* hplip
* k3b
* kdebase3
* knetworkmanager
* kpowersave
* libipoddevice
* libmtp
* libsynce
* nautilus-cd-burner
* NetworkManager
* NetworkManager-gnome
* nut - needs porting to DeviceKit-power
* odccm
* oxine
* pcmanfm
* pmount
* pm-utils
* pulseaudio
* python-minihallib
* rhpxl
* rhythmbox
* sane-backends
* smartmontools-config
* sound-juicer
* synaptics
* synce-hal
* thinkfinger
* Thunar
* thunar-volman
* totem-pl-parser
* tracker
* xfce4-volstatus-icon
* xorg-x11-server


== Test Plan ==
== How To Test ==
 
# yum install gnome-disk-utility. This will pull in DeviceKit-disks and DeviceKit via dependencies.
# Use gnome-disk-utility to create, modify and delete partitions and file systems on various media, such as usb sticks, cds, removable hard disks, etc.
# Use palimpsest (the graphical frontend) to create, modify and delete partitions and file systems on various media, such as usb sticks, cds, removable hard disks, etc.
# Use gnome-disk-utility to encrypt partitions and to change passwords for existing encrypted partitions.
# Use palimpsest to encrypt partitions and to change passwords for existing encrypted partitions.
# Verify that gnome-disk-utility correctly reports smart data from disks which support it.
# Use nautilus-gdu to format removable media with various file system types.
# Test the raid support
# Verify that palimpsest correctly reports smart data from disks which support it.
# Test the lvm support
# Test the raid support
# Test that desktop applications like nautilus and the gedit (file chooser) see volumes and mounts
# Test that desktop applications like nautilus and the gedit's file chooser see volumes and mounts
# Similar for other desktop environments, if they are ported to DeviceKit
# Check that gnome-power-manager provides the same functionality it had in previous releases
# Similar for other desktop environments and applications, if they are ported to DeviceKit


== User Experience ==
== User Experience ==


There is a new menu item that brings up gnome-disc-utility.
There is a new menu item that brings up palimpsest: Applications → System Tools → Palimpsest Disk Utility


The nautilus context menu offers to format discs/usb sticks and other devices.
The nautilus context menu offers to format discs/usb sticks and other devices.
palimpsest is a graphical interface for all disc-related tasks, from partitioning and file system creation to encryption, raid and lvm.


gnome-disc-utility is a graphical interface for all disc-related tasks, from partitioning and file system creation to encryption, raid and lvm.
Here are some screenshots of palimpsest and nautilus-gdu in action:
* The main window
[[Image:Palimpsest1.png]]
* SMART details
[[Image:Palimpsest2.png]]
* PolicyKit integration
[[Image:Palimpsest3.png]]
* The nautilus-gdu dialog
[[Image:nautilus-gdu.png]]


== Dependencies ==
== Dependencies ==


hal needs to be built without disc support.
* DeviceKit review: https://bugzilla.redhat.com/show_bug.cgi?id=456032 (Done)
 
* DeviceKit-disks review: https://bugzilla.redhat.com/show_bug.cgi?id=456033 (Done)
gvfs needs to be built against DeviceKit-disks, and the volume monitor in gvfs must be moved out of process to make it a singleton.
* gnome-disk-utility review: https://bugzilla.redhat.com/show_bug.cgi?id=456034 (Done)
 
* DeviceKit-power review: https://bugzilla.redhat.com/show_bug.cgi?id=460912 (Done)
Solid's (KDE's) disk management also needs to be ported to DeviceKit-disks.
* udev-extras review: https://bugzilla.redhat.com/show_bug.cgi?id=480754 (Done)
* nautilus-gdu review: https://bugzilla.redhat.com/show_bug.cgi?id=483277 (Done)
* udev >= 0.139
* mdadm >= 2.6.5
* device-mapper
* parted
* smartmontools
* util-linux-ng
* sqlite3
* PolicyKit >= 0.9
* dbus-glib >= 0.75
* dbus >= 1.1.20
* a nautilus extension for formatting must be written (Done)
* gvfs needs to be ported to DeviceKit-disks (Done)
* gnome-mount and nautilus must be ported to DeviceKit-disks
* hal needs to be patched to remove block device handling


== Contingency Plan ==
== Contingency Plan ==


Don't add the new packages to F10, undo the hal-disk-ectomy, rebuild gvfs against hal instead of DeviceKit-disks.
DeviceKit-disks and DeviceKit-power can coexist with the disk and power management parts of hal. If the porting of applications is not complete by F11, we don't strip the functionality out of hal in F11.


== Documentation ==
== Documentation ==


API docs are here: http://hal.freedesktop.org/docs/DeviceKit/
API docs are here: http://hal.freedesktop.org/docs/DeviceKit/  
http://hal.freedesktop.org/docs/DeviceKit-disks/
http://hal.freedesktop.org/docs/DeviceKit-power/
 
End user documentation will take some time to write, and can't really be started before the tools are publicly available.


== Release Notes ==
== Release Notes ==


Should not be necessary.  
Fedora 11 features DeviceKit, which is a simpler, modular replacement for hal. hal itself is still around, since applications rely on it. DeviceKit also comes with a graphical disk management application called palimpsest that uses the DeviceKit-disks subsystem of DeviceKit to handle partitioning, file system creation, encryption, raid, lvm, etc. gnome-power-manager has been ported to use the DeviceKit-power subsystem of DeviceKit instead of hal.
 
It might be a good idea to mention the encryption support where the release notes talk about encryption.


== Comments and Discussion ==
== Comments and Discussion ==
Line 145: Line 136:


----
----
[[Category:ProposedFeature]]
 
[[Category:FeatureAcceptedF11]]
[[Category:Features with incomplete scope]]

Latest revision as of 15:11, 29 March 2010

DeviceKit

Summary

DeviceKit is a simple system service that a) can enumerate devices; b) emits signals when devices are added or removed; c) provides a way to merge device information / quirks onto devices. It is designed to partially replace hal and overcome some of the design limitiations of hal. DeviceKit functionality is provided in the form of dbus services on the system bus.

Apart from DeviceKit itself, there is DeviceKit-disks, which is a system service to keep track of block devices. The functionality offered by DeviceKit-disks is a superset of what hal provides for block devices.

There is also DeviceKit-power, which takes over the power-management-related parts of hal and the more complex functionality of gnome-power-manager. As a consequence, gnome-power-manager itself becomes much simpler.

The new udev-extra module will provide udev rules that are needed to make the DeviceKit architecture work. Functionality that was provided via .fdi files in hal will eventually be moved to udev rules, and setting acls on devices will also be done here at some point.

DeviceKit-disks comes with a graphical frontend called palimpsest (the package name is gnome-disk-utility). Furthermore, there's a nautilus extension to format disks (nautilus-gdu), accessible from context menu.

Owner

Current status

  • Targeted release: Fedora 11
  • Last updated: 2009-03-06
  • Percentage of completion: 100%

DeviceKit, DeviceKit-disks, DeviceKit-power and gnome-disk-utility (i.e. palimpsest) packages have been built in rawhide.

gnome-power-manager 2.25 in rawhide uses DeviceKit-power instead of hal.

The port of gvfs to DeviceKit-disks is in rawhide.

udev-extras is hosted on kernel.org and has been packaged for rawhide.

The nautilus extension for disk formatting is being worked on here. It is called nautilus-gdu. It is available in rawhide.

Still todo:

  • remove the properties page from gnome-mount
  • add a status icon for smart warnings, critical raid events and delayed write warnings
  • bug fixes

Detailed Description

David has written an extensive explanation of the DeviceKit architecture, and the motivation for rewriting hal. Read all about it here

There is a dedicated devkit-devel mailing list now.

Benefit to Fedora

Fedora gains a comprehensive graphical disk management tool which provides functionality that so far was almost exclusively available in the partitioning screen of anaconda. The tools integrate nicely into the desktop (by e.g. providing a "Format disk..." menuitem in the nautilus context menu where appropriate).

Scope

DeviceKit depends on bug fixes and enhancements in the following components: kernel, udev, mdadm, and lvm. These will have to appear in rawhide first.

Also, in order to peacefully coexist with DeviceKit-disks, at a very minimum hal needs to talk to DeviceKit-disks about locking and mounting/unmounting. Medium term, hal functionality such as disk and power-management support will be turned off when all important users have been ported over to the equivalent DeviceKit api.

The core components that we plan to port for F11 are: gvfs, gnome-mount, nautilus and gnome-power-manager.

For completeness, Features/DeviceKit/HalDependencies is a list of all packages in Fedora that depend on hal, libhal.so.1 or libhal-storage.so.1. Except where noted, we don't expect to port these to DeviceKit for F11.

How To Test

  1. yum install gnome-disk-utility. This will pull in DeviceKit-disks and DeviceKit via dependencies.
  2. Use palimpsest (the graphical frontend) to create, modify and delete partitions and file systems on various media, such as usb sticks, cds, removable hard disks, etc.
  3. Use palimpsest to encrypt partitions and to change passwords for existing encrypted partitions.
  4. Use nautilus-gdu to format removable media with various file system types.
  5. Verify that palimpsest correctly reports smart data from disks which support it.
  6. Test the raid support
  7. Test that desktop applications like nautilus and the gedit's file chooser see volumes and mounts
  8. Check that gnome-power-manager provides the same functionality it had in previous releases
  9. Similar for other desktop environments and applications, if they are ported to DeviceKit

User Experience

There is a new menu item that brings up palimpsest: Applications → System Tools → Palimpsest Disk Utility

The nautilus context menu offers to format discs/usb sticks and other devices. palimpsest is a graphical interface for all disc-related tasks, from partitioning and file system creation to encryption, raid and lvm.

Here are some screenshots of palimpsest and nautilus-gdu in action:

  • The main window

  • SMART details

  • PolicyKit integration

  • The nautilus-gdu dialog

Dependencies

Contingency Plan

DeviceKit-disks and DeviceKit-power can coexist with the disk and power management parts of hal. If the porting of applications is not complete by F11, we don't strip the functionality out of hal in F11.

Documentation

API docs are here: http://hal.freedesktop.org/docs/DeviceKit/ http://hal.freedesktop.org/docs/DeviceKit-disks/ http://hal.freedesktop.org/docs/DeviceKit-power/

End user documentation will take some time to write, and can't really be started before the tools are publicly available.

Release Notes

Fedora 11 features DeviceKit, which is a simpler, modular replacement for hal. hal itself is still around, since applications rely on it. DeviceKit also comes with a graphical disk management application called palimpsest that uses the DeviceKit-disks subsystem of DeviceKit to handle partitioning, file system creation, encryption, raid, lvm, etc. gnome-power-manager has been ported to use the DeviceKit-power subsystem of DeviceKit instead of hal.

Comments and Discussion

See Talk:Features/DeviceKit