[PATCH 0/9] Devices accessibility control group (v4)

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Pavel Emelyanov
Date: Wednesday, March 5, 2008 - 10:23 am

Changes from v3:
* Ported on 2.6.25-rc3-mm1;
* Re-splitted into smaller pieces;
* Added more comments to tricky places.

This controller allows to tune the devices accessibility by tasks,
i.e. grant full access for /dev/null, /dev/zero etc, grant read-only
access to IDE devices and completely hide SCSI disks.

Tasks still can call mknod to create device files, regardless of
whether the particular device is visible or accessible, but they
may not be able to open it later.

This one hides under CONFIG_CGROUP_DEVS option.

To play with it - run a standard procedure:

 # mount -t container none /cont/devs -o devices
 # mkdir /cont/devs/0
 # echo -n $$ > /cont/devs/0/tasks

and tune device permissions.

The only configuration file called devices.permissions accepts 
strings like '[cb] <major>:(<minor>|*) [r-][w-]' to provide read,
write or read-write access to a particular device. Asterisk as the
minor means "all devices with a given major".

This will be described in Documentation/controllers/devices.txt
file in more details.

Here are some historical notes.

The third version was here:
http://openvz.org/pipermail/devel/2008-February/010832.html
Changes from v2:
* Fixed problems pointed out by Sukadev with permissions
  revoke. Now we have to perform kobject re-lookup on
  each char device open, just like for block ones, so I
  think this is OK.

The second version was here:
http://openvz.org/pipermail/devel/2008-January/010160.html
Changes from v1:
* Added the block devices support :) It turned out to
  be a bit simpler than the char one (or I missed
  something significant);
* Now we can enable/disable not just individual devices,
  but the whole major with all its minors (see the TODO
  list beyond as well);
* Added the ability to restrict the read/write permissions
  to devices, not just visible/invisible state.

The first version was here:
http://openvz.org/pipermail/devel/2007-September/007647.html

Thanks,
Pavel
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH 0/9] Devices accessibility control group (v4), Pavel Emelyanov, (Wed Mar 5, 10:23 am)
[PATCH 1/9] Avoid magic constants in drivers/base/map.c, Pavel Emelyanov, (Wed Mar 5, 10:25 am)
[PATCH 2/9] Cleanup the get_gendisk() a bit, Pavel Emelyanov, (Wed Mar 5, 10:28 am)
[PATCH 3/9] Add a mode on the struct probe, Pavel Emelyanov, (Wed Mar 5, 10:32 am)
[PATCH 5/9] Make use of permissions, returned by kobj_lookup, Pavel Emelyanov, (Wed Mar 5, 10:37 am)
[PATCH 6/9] Extend the drivers/base/map.c functionality, Pavel Emelyanov, (Wed Mar 5, 10:40 am)
[PATCH 9/9] Devices accessibility control group itself, Pavel Emelyanov, (Wed Mar 5, 10:47 am)
Re: [PATCH 0/9] Devices accessibility control group (v4), Serge E. Hallyn, (Wed Mar 5, 8:15 pm)
Re: [PATCH 0/9] Devices accessibility control group (v4), Pavel Emelyanov, (Thu Mar 6, 1:36 am)
Re: [PATCH 0/9] Devices accessibility control group (v4), Pavel Emelyanov, (Fri Mar 7, 1:54 am)