]> git.ipfire.org Git - thirdparty/libcgroup.git/log
thirdparty/libcgroup.git
15 years agocgget tool
Jan Safranek [Tue, 22 Dec 2009 08:15:10 +0000 (09:15 +0100)] 
cgget tool

Add a tool to query for parameter values. The syntax is very similar to cgset,
including IMHO ugly group specification without list of controllers.

Usage:
cgget [-nv] -r <param. name> [-r <param. name>] [...] <path to group> [...]

 -n - no headers
 -v - print values only (no parameter names)

Example:

$ cgget -r cpuset.cpus / /second
/:
cpuset.cpus=0-1

/second:
cpuset.cpus=1

$ cgget -nv -r cpuset.cpus / /second
0-1
1

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
15 years agolibcgroup: trivial: Fix typo
Dhaval Giani [Wed, 16 Dec 2009 10:14:34 +0000 (15:44 +0530)] 
libcgroup: trivial: Fix typo

opened is spelled as opened and not opend

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoFix an invalid access to yytext.
Ken'ichi Ohmichi [Fri, 11 Dec 2009 03:22:19 +0000 (12:22 +0900)] 
Fix an invalid access to yytext.

Hi,

I tested "cgconfig" service with a big /etc/cgconfig.conf file, and the
service failed by signal SIGSEGV.
There are two problems. The first is that "cgconfig" service fails with
a big /etc/cgconfig.conf file. The second is that the error handling is
stopped by signal SIGSEGV.
This patch fixes the second problem.

The following is the gdb output of the problem.
You can see the problem happens in yyerror().

 # gdb cgconfigparser
 (gdb) run -l /etc/cgconfig.conf
 Starting program: /usr/local/sbin/cgconfigparser -l /etc/cgconfig.conf
 [Thread debugging using libthread_db enabled]
 [New Thread 139764254320624 (LWP 15169)]

 Program received signal SIGSEGV, Segmentation fault.
 [Switching to Thread 139764254320624 (LWP 15169)]
 0x00007f1d66bd1604 in yyerror (s=0x7f1d66bd955a "syntax error") at parse.y:30
 30              fprintf(stderr, "error at line number %d at %c:%s", line_no, *yytext,
 (gdb) bt
 #0  0x00007f1d66bd1604 in yyerror (s=0x7f1d66bd955a "syntax error")
     at parse.y:30
 #1  0x00007f1d66bd1a9e in yyparse () at parse.c:1689
 #2  0x00007f1d66bd79b5 in cgroup_config_load_config (
     pathname=<value optimized out>) at config.c:467
 #3  0x00000000004008a3 in main (argc=3, argv=0x7fffa20c8358) at cgconfig.c:60
 (gdb)

This problem is due to an invalid access to yytext, and this patch fixes it.
(If you need a big /etc/cgconfig.conf file for reproducing the problem,
please let me know it. I will send it to you without the mailing list.)

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Acked-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoFix a memory leak in "cgconfig" service.
Ken'ichi Ohmichi [Wed, 9 Dec 2009 06:47:26 +0000 (15:47 +0900)] 
Fix a memory leak in "cgconfig" service.

Hi,

When I operated "cgconfig" service on valgrind, I found a memory leak
like the following:

  # cat /etc/cgconfig.conf
  mount {
    cpuset = /cgroup/cpuset;
    cpu    = /cgroup/cpu;
    memory = /cgroup/memory;
  }
  group user000 {
    cpuset {
        cpuset.cpus = 0;
        cpuset.mems = 0;
    }
  }
  group user000/sleep000 {
    cpuset {
        cpuset.cpus = 0;
        cpuset.mems = 0;
    }
  }

  # valgrind --tool=memcheck --leak-check=yes cgconfigparser -l /etc/cgconfig.conf
  ==13095== Memcheck, a memory error detector.
  ==13095== Copyright (C) 2002-2006, and GNU GPL'd, by Julian Seward et al.
  ==13095== Using LibVEX rev 1658, a library for dynamic binary translation.
  ==13095== Copyright (C) 2004-2006, and GNU GPL'd, by OpenWorks LLP.
  ==13095== Using valgrind-3.2.1, a dynamic binary instrumentation framework.
  ==13095== Copyright (C) 2000-2006, and GNU GPL'd, by Julian Seward et al.
  ==13095== For more details, rerun with: -v
  ==13095==
  ==13095==
  ==13095== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 4 from 1)
  ==13095== malloc/free: in use at exit: 43,062 bytes in 10 blocks.
  ==13095== malloc/free: 129 allocs, 119 frees, 85,399 bytes allocated.
  ==13095== For counts of detected errors, rerun with: -v
  ==13095== searching for pointers to 10 not-freed blocks.
  ==13095== checked 6,795,480 bytes.
  ==13095==
  ==13095== 28 bytes in 2 blocks are definitely lost in loss record 1 of 5
  ==13095==    at 0x4A0590B: realloc (vg_replace_malloc.c:306)
  ==13095==    by 0x4C0CC24: yyparse (parse.y:117)
  ==13095==    by 0x4C12914: cgroup_config_load_config (config.c:467)
  ==13095==    by 0x4008A2: main (cgconfig.c:60)
  ==13095==
  ==13095== LEAK SUMMARY:
  ==13095==    definitely lost: 28 bytes in 2 blocks.
  ==13095==      possibly lost: 0 bytes in 0 blocks.
  ==13095==    still reachable: 43,034 bytes in 8 blocks.
  ==13095==         suppressed: 0 bytes in 0 blocks.
  ==13095== Reachable blocks (those to which a pointer was found) are not shown.
  ==13095== To see them, rerun with: --show-reachable=yes
  #

This patch fixes the memory leak.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoFix compilation outside of source directory
Jan Safranek [Mon, 14 Dec 2009 08:22:36 +0000 (09:22 +0100)] 
Fix compilation outside of source directory

Configure script can be invoked outside of source directory, which allows
to compile sources without spoiling the source directory with compilation
artifacts (like .o files). This patch tries to fix our Makefiles to allow
this to work.

You can test it in current GIT checkout (in the root dir):
# mkdir build; cd build; ../configure; make

As result, you should see all binary files in the 'build' directory.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoRemove the init script installation from .spec
Jan Safranek [Mon, 14 Dec 2009 08:22:29 +0000 (09:22 +0100)] 
Remove the init script installation from .spec

If we have our init scripts in /etc/init.d as result of 'make install', we
don't need to install them again in the .spec file.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoInstall init scripts during 'make install'
Jan Safranek [Mon, 14 Dec 2009 08:22:22 +0000 (09:22 +0100)] 
Install init scripts during 'make install'

Install init scripts during 'make install'.

I am not sure this is right thing to do, all the other projects I
participate in do not install their init scripts, but Dhaval thinks it's
nice to have it.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoEnable get_all_controller test
Ivana Hutarova Varekova [Thu, 10 Dec 2009 12:26:11 +0000 (13:26 +0100)] 
Enable get_all_controller test

This patch enable get_all_controller test

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoFix cgroup_get_all_controller_{begin, next, end} api
Ivana Hutarova Varekova [Thu, 10 Dec 2009 12:26:00 +0000 (13:26 +0100)] 
Fix cgroup_get_all_controller_{begin, next, end} api

remove the cgroup_initialized need from all of them - not needed

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agolssubsys: new option -a,--all
Ivana Hutarova Varekova [Thu, 10 Dec 2009 12:25:21 +0000 (13:25 +0100)] 
lssubsys: new option -a,--all

This patch adds new option to lssubsys command
lssubsys with this option displays moreover controllers which are
not mounted
The patch change the behavior of lssubsys a bit - there is no
error message if controllers are not mounted and lssubsys is called.

Example:
$  ./lssubsys -a
devices
cpuset,cpuacct
ns
cpu

$  ./lssubsys -am
devices /mnt/cgroups/devices
cpuset,cpuacct /mnt/cgroups/cpuset
ns
cpu

$  ./lssubsys

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoman page for lssubsys tool
Ivana Hutarova Varekova [Thu, 12 Nov 2009 12:51:25 +0000 (13:51 +0100)] 
man page for lssubsys tool

This patch adds the man page for lssubsys tool

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoFix a cgconfig behavior of wrong /etc/cgconfig.conf.
Ken'ichi Ohmichi [Wed, 4 Nov 2009 01:54:30 +0000 (10:54 +0900)] 
Fix a cgconfig behavior of wrong /etc/cgconfig.conf.

Changelog since v2:
o Avoid breaking ABI by changing the ECGCONFIGPARSEFAIL value.

Changelog since v1:
o Change a parser error value of /etc/cgconfig.conf to ECGCONFIGPARSEFAIL.

The cgconfig service succeeds even if there are something wrong
in /etc/cgconfig.conf. For example, it succeeds even if specifying
not-existing user (nouser) as a perm.task.uid like the following:

 # cat /etc/cgconfig.conf
 mount {
        cpuset = /mnt/cgroups/cpuset;
        memory = /mnt/cgroups/memory;
 }
 group root {
        perm {
                task {
                        uid = nouser;
                        gid = root;
                }
                admin {
                        uid = root;
                        gid = root;
                }
        }
        cpuset {
                cpuset.cpus = 0;
                cpuset.mems = 0;
        }
        memory {
                memory.use_hierarchy = 1;
                memory.limit_in_bytes = 1000000000000;
        }
 }
 #
 # service cgconfig start
 Starting cgconfig service: parsing failed at line number 10
                                                           [  OK  ]
 # echo $?
 0
 #

That is not a good behavior and the cgconfig service should fail
if there are something wrong in /etc/cgconfig.conf.
This patch fixes the behavior. In the above case, the behavior is
changed like the following by this patch:

 # service cgconfig start
 Starting cgconfig service: parsing failed at line number 10
 Loading configuration file /etc/cgconfig.conf failed
 Cgroup parsing failed
 Failed to parse /etc/cgconfig.conf                         [FAILED]
 #

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoCleanup: Define ECGRULESPARSEFAIL for the parser error of cgrules.conf.
Ken'ichi Ohmichi [Wed, 4 Nov 2009 01:51:33 +0000 (10:51 +0900)] 
Cleanup: Define ECGRULESPARSEFAIL for the parser error of cgrules.conf.

Changelog since v2:
o Define ECGRULESPARSEFAIL for avoiding breaking ABI.

Changelog since v1:
o A new patch [Cleanup: Rename ECGROUPPARSEFAIL to ECGRULESPARSEFAIL.]

Now ECGROUPPARSEFAIL is defined for a parser error of /etc/cgrules.conf and
this patch defines ECGRULESPARSEFAIL for the same value for clarifying its
meaning.

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoman page for lscgroup tool
Ivana Hutarova Varekova [Mon, 9 Nov 2009 13:13:58 +0000 (14:13 +0100)] 
man page for lscgroup tool

This patch adds the man page for lscgroup tool

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoAdd copyright header to cgcreate
Ivana Hutarova Varekova [Mon, 9 Nov 2009 10:38:14 +0000 (11:38 +0100)] 
Add copyright header to cgcreate

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoAdd man page for cgdelete
Jan Safranek [Fri, 30 Oct 2009 11:51:01 +0000 (12:51 +0100)] 
Add man page for cgdelete

Add man page for cgdelete.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoAllow cgcreate to create unlimited nr. of groups
Jan Safranek [Thu, 29 Oct 2009 14:48:06 +0000 (15:48 +0100)] 
Allow cgcreate to create unlimited nr. of groups

Don't limit the number of groups cgcreate can create, allocate them
dynamically. The size of allocated space for the group is only aproximate, but
still should be better than hard CG_HIER_MAX.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoAllow cgdelete to process unlimited nr. of groups
Jan Safranek [Thu, 29 Oct 2009 14:47:59 +0000 (15:47 +0100)] 
Allow cgdelete to process unlimited nr. of groups

Don't limit the number of groups cgdelete can remove, allocate them
dynamically.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
15 years agoRemove the CG_HIER_MAX from tools-common
Jan Safranek [Thu, 29 Oct 2009 14:47:52 +0000 (15:47 +0100)] 
Remove the CG_HIER_MAX from tools-common

Some libcgroup tools are limited to CG_HIER_MAX arguments. This hard limit
is suitable only to some of the tools, namely cgdelete and cgcreate should not
be limited to any particular numbers of groups to create/delete.

This patches removes the hard limit from tools-common.c and puts it to the
individual tools.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: cgclear manpage
Dhaval Giani [Fri, 23 Oct 2009 11:20:03 +0000 (16:50 +0530)] 
libcgroup: cgclear manpage

Add a manpage for cgclear

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Reviewed-by : Ivana Hutarova Varekova <varekova@redhat.com>

16 years agoconfig.h.in is generated by "autoheader" and since we removed all generated
Jan Safranek [Tue, 27 Oct 2009 15:42:14 +0000 (21:12 +0530)] 
config.h.in is generated by "autoheader" and since we removed all generated
files, we should remove this one too. "autoreconf" creates it when needed.

I am annoyed by reverting changes in it when I post git patches - the file
seems to change quite often, especially when I play with automake/autoconf.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoDon't link with -lpam unless necessary II
Jan Safranek [Fri, 23 Oct 2009 12:10:25 +0000 (14:10 +0200)] 
Don't link with -lpam unless necessary II

Oops, I sent older working version, here is correct one. I need to rest :(.
Here is the correct one:

All binaries are compiled with '-lpam' if --enable-pam is specified (and it
is on by default). We want only the PAM module linked with it.

The autoconf manual says about AC_CHECK_LIB:
If action-if-found is not specified, the default action prepends
-llibrary to LIBS

And the action-if-found we used was '[]', i.e. empty -> -lpam was added to
LIBS -> everything links with it. Simple action-if-found overrides this
default.

Changelog:
 - use 'dnl' as comments and ':' as the 'noop' action to reflect autoconf
 coding style.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoChange the libcgroup group
Jan Safranek [Mon, 26 Oct 2009 14:28:16 +0000 (15:28 +0100)] 
Change the libcgroup group

IMHO libcgroup is not part of "Development/Libraries" group - only the devel
subpackage is. Question is, part of which group it is. Looking at
https://fedoraproject.org/wiki/RPMGroups, I like "System
Environment/Libraries" (the package provides library) or "Applications/System"
the package provides various system tools).

What is your opinion?

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoDistribute the PAM module in separate subpackage
Jan Safranek [Mon, 26 Oct 2009 14:28:09 +0000 (15:28 +0100)] 
Distribute the PAM module in separate subpackage

As discussed on IRC, it might be nice to distribute the PAM module as
separate subpackage.

Regarding the Group:, it seems to me all PAM modules are in "System
Environment/Base" group, so let's put this one there too.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoAdd new executables to .spec file
Jan Safranek [Mon, 26 Oct 2009 14:28:02 +0000 (15:28 +0100)] 
Add new executables to .spec file

We have some new tools available in /bin and /sbin and we should distribute
them.

Changelog:
 - list the files instead of using wildcard

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoMinor improvements and refactoring of lscgroups
Balbir Singh [Fri, 9 Oct 2009 14:45:34 +0000 (20:15 +0530)] 
Minor improvements and refactoring of lscgroups

This patch removes the excess "/"'s and makes the output
more readable. Please test on your systems as well.

Signed-off-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoadds lscgroup tool
Ivana Hutarova Varekova [Fri, 9 Oct 2009 09:40:04 +0000 (11:40 +0200)] 
adds lscgroup tool

Description:
create tool which shows cgroups which are on system:

Usage: lscgroup [<controllers>:<path>] [...]
list all cgroups

Changes since V1(the previous versions was not enumerated):
* fix the format of comments which have more than 1 line
* printf of help -> fprintf(stdout,...
* change the sequence of processing of cgroups on input (now
    first) and internal controller list(first in the previous version), now the
    cgroups are output in order in which they are put to input
* fix return values/error messages - now if the controller is not mount
    the tool return error - it returns 0 otherwise
Changes since V2
    * fix problem with slash characters
  ( $ lscgroup cpu:/1/2
  cpu:/1/2/
  cpu:/1/2/1
  $ lscgroup cpu:1/2
  cpu:/2/
  cpu:/2/1 )
Changes since V3
    * rename the variables (dp1 -> cgroup_dir_path, dp2 -> input_dir_path)
    * improve the coding style

Examples:
    $ lscgroup
    devices:/
    devices:/sysdefault
    cpuset,cpuacct:/
    cpuset,cpuacct:/sysdefault
    cpuset,cpuacct:/daemons
    cpuset,cpuacct:/daemons/ftp

    $ lscgroup cpuset:/
    cpuset,cpuacct:/
    cpuset,cpuacct:/sysdefault
    cpuset,cpuacct:/daemons
    cpuset,cpuacct:/daemons/ftp

    $ lscgroup cpuset:/daemons
    cpuset,cpuacct:/daemons/
    cpuset,cpuacct:/daemons/ftp

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRestrict the effective range of SIGUSR2 signal.
Ken'ichi Ohmichi [Mon, 13 Jul 2009 03:14:29 +0000 (12:14 +0900)] 
Restrict the effective range of SIGUSR2 signal.

Hi,

If a cgrulesengd daemon receives a SIGUSR2 signal (for reloading rules
configuration) while waiting in select(), a daemon finishes incorrectly
due to an "Interrupted system call" error.
If applying a patch "Add the strings of errno to cgrulesengd daemon's
message." and running `service cgred reload`, you can see the message
"selecting error: Interrupted system call". This patch fixes the problem.

There were some problems the deadlock happens related to a SIGUSR2 signal
and they have been fixed by the followings already:

* [PATCH] Fix the deadlock of vsyslog() call.
  http://libcg.git.sourceforge.net/git/gitweb.cgi?p=libcg;a=commit;h=70111cd03653c3ceab9d907c14fa35e5881b2735
* [PATCH] Fix the deadlock of rl_lock.
  http://libcg.git.sourceforge.net/git/gitweb.cgi?p=libcg;a=commit;h=0241c6f1df5068c006f756005c8e7faa63058c27

The above two patches fixed the problems by protecting the important
codes from receiving a SIGUSR2 signal. But this way was not good, because
the protecting code will be necessary if increasing the important codes.

Instead of protecting the important codes, this patch restricts the
effective range of receiving SIGUSR2 signal. So we will not need to add
a new protecting code by this patch.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the strings of errno to cgrulesengd daemon's message.
Ken'ichi Ohmichi [Mon, 13 Jul 2009 03:14:00 +0000 (12:14 +0900)] 
Add the strings of errno to cgrulesengd daemon's message.

Hi,

This patch adds  the strings of errno to cgrulesengd daemon's message.

For investigating a problem that cgrulesengd daemon finishes by
`service cgred reload`, I added the strings of errno to the daemon's
message. This strings were useful for investigating.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoadds lssubsys tool
Ivana Hutarova Varekova [Mon, 24 Aug 2009 09:46:17 +0000 (11:46 +0200)] 
adds lssubsys tool

Description:
 Show controller, which are mounted/which are on input
 and if option -m is used shows the mount point on which are mounted:

Changes since V1(the previous versions was not enumerated):
*   fix the size of array cont_name - so no allocation and c_max variable
removed
*   change the sequence of processing of controllers list on input (now
first) and internal controller list(first in the previous version), now the
controllers are output in order in which they are put to input
*   fix return values/error messages - now if the controller is not mount
the tool return error - it returns 0 otherwise

Changes since V2
* fix the format of comments which have more than 1 line

Changes since V3
* printf of help -> fprintf(stdout,

Syntax:
 lssubsys [-m] [controller1] [controller2] [...]

 -m - show mount points

Examples:
 $lssubsys -m cpuacct
 cpuset,cpuacct /mnt/cgroups/cpuset

 $ lssubsys
 devices
 cpuset,cpuacct

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRemove VERSION macro from api.c
Jan Safranek [Thu, 6 Aug 2009 12:03:45 +0000 (14:03 +0200)] 
Remove VERSION macro from api.c

The macro and assosicated cg_version is not used anywhere and it generates
warning:
api.c:58:1: warning: "VERSION" redefined

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRemove warnings from test_functions.c
Jan Safranek [Thu, 6 Aug 2009 12:03:32 +0000 (14:03 +0200)] 
Remove warnings from test_functions.c

Fix following warnings:
test_functions.c: In function â€˜group_modified’:
test_functions.c:435: warning: format â€˜%d’ expects type â€˜int *’, but argument
3 has type â€˜_Bool *’
test_functions.c:440: warning: format â€˜%lld’ expects type â€˜long long int *’,
but argument 3 has type â€˜int64_t *’
test_functions.c:445: warning: format â€˜%llu’ expects type â€˜long long unsigned
int *’, but argument 3 has type â€˜u_int64_t *’

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRemove unnecessary includes from libcgroup.h
Jan Safranek [Thu, 6 Aug 2009 12:03:26 +0000 (14:03 +0200)] 
Remove unnecessary includes from libcgroup.h

libcgroup.h includes some header files, which are not then used. These should
be removed, resp. moved to the source files where they are actually needed.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoShorten error text of ECGOTHER
Jan Safranek [Thu, 6 Aug 2009 12:03:19 +0000 (14:03 +0200)] 
Shorten error text of ECGOTHER

Let's reformat cgroup_strerror output from

Cgroup generic error, error message: Device or resource busy

to shorter and clearer

Device or resource busy

The patch assumes that _GNU_SOURCE is defined.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Use the correct data type in the get_all_controller test case
Dhaval Giani [Thu, 6 Aug 2009 06:33:18 +0000 (12:03 +0530)] 
libcgroup: Use the correct data type in the get_all_controller test case

get_all_controller.c: In function â€˜main’:
get_all_controller.c:18: warning: passing argument 1 of â€˜cgroup_get_all_controller_begin’ from incompatible pointer type
get_all_controller.c:23: warning: passing argument 1 of â€˜cgroup_get_all_controller_next’ from incompatible pointer type
get_all_controller.c:31: warning: passing argument 1 of â€˜cgroup_get_all_controller_end’ from incompatible pointer type

The test case used a FILE * instead of a void *. Correct this change (The datatype is opaque to the caller)

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Fix compile error
Dhaval Giani [Thu, 6 Aug 2009 06:29:35 +0000 (11:59 +0530)] 
libcgroup: Fix compile error

The correct error code is ECGOTHER and not CGOTHER

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoadd api for generating the list of all controllers (not only mount ones)
Ivana Hutarova Varekova [Fri, 17 Jul 2009 07:41:12 +0000 (09:41 +0200)] 
add api for generating the list of all controllers (not only mount ones)

this patch add api for generating the list of all controllers (not only mount ones)
- it uses three functions:
cgroup_get_all_controller_begin
cgroup_get_all_controller_next
cgroup_get_all_controller_end

and structure:
struct controller_data {
char name[FILENAME_MAX];
int hierarchy;
int num_cgroups;
int enabled;
};

the data are read from /proc/cgroups file

Signed-off-by: Ivana Hutarova Varekova <varekova@redhat.com>
Reviewed-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRefactor cgclear to use new recursive delete
Jan Safranek [Tue, 4 Aug 2009 12:28:29 +0000 (14:28 +0200)] 
Refactor cgclear to use new recursive delete

Let's rework cgroup_config_unload_controller to use the brand new recursive
removal of groups. It saves *lot of* fopen() and fclose() calls:

On my (semi-broken) Fedora 11 with 196 running processes and 3 cgroup
hierarchies, the old cgclear does 668 open("*/tasks"). With the
optimized cgclear, I can see just 22 open("*/tasks") calls.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd cgdelete tool
Jan Safranek [Tue, 4 Aug 2009 12:28:22 +0000 (14:28 +0200)] 
Add cgdelete tool

The cgdelete command line tool removes given control groups.

Usage: cgdelete [-r]  <controllers>:<group> [...]

# I have group 1 with many subgroups:
$ cgdelete cpu,freezer:1
cgdelete: cannot remove group '1': Cgroup generic error, error message:
Device or resource busy

$ cgdelete -r cpu,freezer:1
$

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd recursive cgroup_delete_cgroup_ext.
Jan Safranek [Tue, 4 Aug 2009 12:28:15 +0000 (14:28 +0200)] 
Add recursive cgroup_delete_cgroup_ext.

Changelog:
- add braces to cgroup_delete_cgroup_ext to improve readability
- use enum instead of macro to define flags

The new function allows to recursively delete whole tree of groups. There is
new infrastructure created around (cg_delete_cgroup_controller_recursive).

It has inconsistent behavior when root group removal is requested - it removes
all children (if requested), but does not remove the root itself and returns
success value. This allows simple rewrite of cgclear functions to use this
function.

Original cgroup_delete_cgroup now leads to cgroup_delete_cgroup_ext.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoSplit cgroup removal to separate functions.
Jan Safranek [Tue, 4 Aug 2009 12:28:09 +0000 (14:28 +0200)] 
Split cgroup removal to separate functions.

Changelog:
- simplify error handling in cg_move_task_files

cgroup_delete_cgroup does all the stuff on it's own. This patch refactors
the function and moves the parts with complete error handling.

The new functions are cg_delete_cgroup_controller and cg_move_task_files.
They are not necessarily needed, but it simplifies error handling and clearly
distinguishes functionality of cgroup_delete_cgroup.

Purpose of the functions should be clearly specified in the doxygen comments.

Especially note that cg_delete_cgroup_controller wants already opened file,
where all tasks should be moved - this is optimization, which will be used in
subsequent patches. I could use cgroup_get_task_* and cgroup_attach_task, which
would look definitely nicer, but it would lead to lot of fopen() and fclose()
calls. Let me know what do you think about it.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoRFC: Fix cgroup_find_parent function
Jan Safranek [Tue, 28 Jul 2009 14:20:25 +0000 (16:20 +0200)] 
RFC: Fix cgroup_find_parent function

There are more issues with cgroup_find_parent function:

1.
The cgroup_find_parent expects, that it's argument is group in
cg_mount_table[0] controller, which is not always the case.

IMHO the function should accept complete struct cgroup and find real parent.

2.
when checking the st_dev of the group and it's parent to prevent
"underflow" to real filesystem, actually the parent and it's parent are
checked instead of group and it's parent.

In addition, I enhanced the function to return real error code when something
goes wrong.

Open question is, if the function should return just char* as parent's
name or whole struct cgroup*. The second case is more natural - we should
work with groups and not group names, but in some cases just the name is
needed and whole cgroup creation would be unnecessary overhead (I have
prepared cgcdelete tool, which needs just parent's name).

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoremoves copy_name_value_from_rules to wrapper
Ivana Varekova [Wed, 15 Jul 2009 08:28:56 +0000 (10:28 +0200)] 
removes copy_name_value_from_rules to wrapper

move copy_name_value_from_rules procedure to wrapper.c file and
add the header to libcgroup-internal.h

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Acked-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd a process name to the log of cgrulesengd daemon.
Ken'ichi Ohmichi [Mon, 6 Jul 2009 04:42:36 +0000 (13:42 +0900)] 
Add a process name to the log of cgrulesengd daemon.

Hi,

Current cgrulesengd daemon changes the cgroup of each process by a rule
based on uid, gid, and process name. And it is good that the log of the
daemon contains a process name with uid and gid.
This patch adds a process name to the log message.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoReduce "Cgroup change for PID:X, UID:X, GID:X FAILED!" messages.
Ken'ichi Ohmichi [Mon, 6 Jul 2009 04:23:44 +0000 (13:23 +0900)] 
Reduce "Cgroup change for PID:X, UID:X, GID:X FAILED!" messages.

Hi,

Changelog since v1:
===================
 * Rebase the latest code.
 * Cleanup.

The log message "Cgroup change for PID:X, UID:X, GID:X FAILED!" is output
by cgrulesengd daemon, even if a process finished already and that is not
a problem.
This patch prevents the daemon from outputting this spam log message.

* Reference
  [PATCH 2/2] Reduce "Cgroup change for PID:X, UID:X, GID:X FAILED!" messages.
  http://sourceforge.net/mailarchive/message.php?msg_name=4A10EE7E.60403%40mxs.nes.nec.co.jp

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoConfigure the location of cgrulesengd socket v0.34
Jan Safranek [Tue, 30 Jun 2009 12:29:19 +0000 (14:29 +0200)] 
Configure the location of cgrulesengd socket

This patch allows users to configure location of cgrulesengd socket before
compilation:

./configure --enable-cgred-socket=/var/run/cgred.socket

In addition, /var/run/cgred.socket is now default location of the socket - this
sounds LSB compliant to me. Feel free to suggest better one.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: find better name for CGRULE_CGRED_TEMP_FILE
Jan Safranek [Tue, 30 Jun 2009 12:29:12 +0000 (14:29 +0200)] 
Cleanup: find better name for CGRULE_CGRED_TEMP_FILE

Rename CGRULE_CGRED_TEMP_FILE to CGRULE_CGRED_SOCKET_PATH to better describe
the macro usage - it's not a temporary file, it's a socket.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoFix cgroup_find_matching_rule() call.
Ken'ichi Ohmichi [Tue, 30 Jun 2009 00:02:37 +0000 (09:02 +0900)] 
Fix cgroup_find_matching_rule() call.

Hi,

If compiling the latest code (8cc1d9743201cb9ae9a5286c898b9d47e318ed46),
the following warning messages are printed. The problem is due to invalid
call of cgroup_find_matching_rule_uid_gid(). Instead of this function call,
cgroup_find_matching_rule() should be called as
"[PATCH-v6 03/11] Add the key "process name" to find a matching rule.".

 $ make
 [snip]
 api.c: In function 'cgroup_change_cgroup_flags':
 api.c:1994: warning: passing argument 3 of 'cgroup_find_matching_rule_uid_gid' from incompatible pointer type
 api.c: At top level:
 api.c:1923: warning: 'cgroup_find_matching_rule' defined but not used
 [snip]
 $

* Reference:
  "[PATCH-v6 03/11] Add the key "process name" to find a matching rule."
  http://sourceforge.net/mailarchive/message.php?msg_name=4A44617E.9060002%40mxs.nes.nec.co.jp

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoFix too many program name in the usage message of "cgset" command.
Ken'ichi Ohmichi [Tue, 30 Jun 2009 00:24:29 +0000 (09:24 +0900)] 
Fix too many program name in the usage message of "cgset" command.

Hi,

If compiling the latest code (8cc1d9743201cb9ae9a5286c898b9d47e318ed46),
the following warning messages are printed.

 $ make
 [snip]
 cgset.c: In function 'usage':
 cgset.c:123: warning: too many arguments for format
 [snip]
 $

This patch fixes too many program name in the usage message of "cgset"
command.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agocgset: fix the man-page -add new parameters
Ivana Varekova [Fri, 19 Jun 2009 15:09:03 +0000 (17:09 +0200)] 
cgset: fix the man-page -add new parameters

This patch fixed man page and adds newly added parameters

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agocgset: Add --copy-from option to cgset
Ivana Varekova [Fri, 19 Jun 2009 15:08:52 +0000 (17:08 +0200)] 
cgset: Add --copy-from option to cgset

Add copy-from option to cgset

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agocgset: Change the handling of options, add --help
Ivana Varekova [Fri, 19 Jun 2009 15:08:35 +0000 (17:08 +0200)] 
cgset: Change the handling of options, add --help

Change the handling of options
- add the possibility to use long options
- add --help option
- change the type of c (see man 3 getopt_long)

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agocgset: Change the generation of cgroup
Ivana Varekova [Fri, 19 Jun 2009 15:08:13 +0000 (17:08 +0200)] 
cgset: Change the generation of cgroup

- This patch change the system of generating cgroup  to
1/ create one src cgroup
2/ for each input cgroup name cgroup_copy_cgroup
   the name-value data from original one
This method is better because the name-values pairs should not be
parsed several times. And this method will be used in new coption
--copy-from too (the src group will be find in option)

move the part in which src is generated to separate function

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agocgset: Add cgset_SOURCES to Makefile
Ivana Varekova [Fri, 19 Jun 2009 15:07:55 +0000 (17:07 +0200)] 
cgset: Add cgset_SOURCES to Makefile

Add cgset_SOURCES to Makefile

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Clarify the number meanings of string length.
Ken'ichi Ohmichi [Thu, 25 Jun 2009 00:12:00 +0000 (09:12 +0900)] 
Cleanup: Clarify the number meanings of string length.

Hi,

This patch clarifies the number meanings of string length in the function
cgroup_get_uid_gid_from_procfs(). This is recreated based on Igawa-san's
patch for the latest code.

* Reference
  Igawa-san's patch
  http://sourceforge.net/mailarchive/message.php?msg_name=20090515.085922.109268324.igawa%40mxs.nes.nec.co.jp

Signed-off-by: Masayuki Igawa <igawa@mxs.nes.nec.co.jp>
Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd a new test command "proctest".
Ken'ichi Ohmichi [Fri, 26 Jun 2009 06:11:16 +0000 (15:11 +0900)] 
Add a new test command "proctest".

Hi,

Changelog of v6:
================
 * New patch.

This patch adds a new test command "proctest" for testing both
cgroup_get_uid_gid_from_procfs() and cgroup_get_procname_from_procfs().

 # sleep 100 &
 [1] 28558
 # ./tests/proctest $$ 28558
   Pid  |        Process name              |  Uid  |  Gid
 -------+----------------------------------+-------+-------
  27219 |                        /bin/bash |     0 |     0
  28558 |                       /bin/sleep |     0 |     0
 #

The functions get a process information from /proc fs, and they are
fragile because the content of /proc fs is not stable. If changing
/proc fs in future, this test command will be useful for catching
the change.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the description about a new rule.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:51:46 +0000 (14:51 +0900)] 
Add the description about a new rule.

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5:
================
 * New patch.

Description:
============
This patch add the description about a new rule to both the manpage
of cgrules.conf and the sample of cgrules.conf.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoApply a new rule to 'cgclassify' command.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:51:33 +0000 (14:51 +0900)] 
Apply a new rule to 'cgclassify' command.

Hi,

Changelog of v6:
================
 * Change the cgroup_get_procname_from_procfs() calling for the
   returning value's change.

Changelog of v5:
================
 * Add the description of a new option "--sticky".

Changelog of v4:
================
 * Add a new option "--sticky" so that cgrulesengd daemon does not change
   the children's cgroups which is classified by 'cgclassify' command.

Changelog of v3:
================
 * New patch.

Description:
============
This patch applies a new rule to 'cgclassify' command.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoApply a new rule to 'cgexec' command.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:51:20 +0000 (14:51 +0900)] 
Apply a new rule to 'cgexec' command.

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5:
================
 * Add the description of a new option "--sticky".

Changelog of v4:
================
 * Add a new option "--sticky" so that cgrulesengd daemon does not change
   the children's cgroups which is executed by 'cgexec' command.

Changelog of v3:
================
 * Set a SETUID to "cgexec" command file.
 * An euid is changed to the executing user from a root user.

Changelog of v2:
================
 * New patch.

Description:
============
This patch applies a new rule to 'cgexec' command.

cgroup_register_unchanged_process() is called so that cgrulesengd
daemon does not change the cgroup of a process, which is executed
by 'cgexec' command.
And cgroup_change_cgroup_flags() is called for applying a new rule.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the library function cgroup_register_unchanged_process().
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:51:06 +0000 (14:51 +0900)] 
Add the library function cgroup_register_unchanged_process().

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5:
================
 * Rebase the patch to the latest code.

Changelog of v4:
================
 * No change.

Changelog of v3:
================
 * No change.

Changelog of v2:
================
 * New patch.

Description:
============
This patch adds the library function cgroup_register_unchanged_process()
for notifying cgrulesengd daemon of the unchanged process.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the handler of unchanged process to cgrulesengd daemon.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:50:54 +0000 (14:50 +0900)] 
Add the handler of unchanged process to cgrulesengd daemon.

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5:
================
 * No change.

Changelog of v4:
================
 * Add the comment "FIXME: Change the temporary file to configurable one."
 * Define the number of allocation.

Changelog of v3:
================
 * Set the value 0x1 to CGROUP_DAEMON_UNCHANGE_CHILDREN flag.

Changelog of v2:
================
 * New patch.

Description:
============
This patch adds the handler of unchanged process to the cgrulesengd daemon.
By this patch, the daemon does not change a process which is executed by
'cgexec' command, because it is possible to notify the unchanged process to
the daemon by using "unix domain socket".

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Separate the netlink method to cgre_receive_netlink_msg().
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:50:31 +0000 (14:50 +0900)] 
Cleanup: Separate the netlink method to cgre_receive_netlink_msg().

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5:
================
 * No change.

Changelog of v4:
================
 * Remove unused parameter "cn_hdr" from cgre_receive_netlink_msg().

Changelog of v3:
================
 * No change.

Changelog of v2:
================
 * New patch.

Description:
============
This patch separates the netlink method for the readability, because
the later patch [PATCH 6/9] adds "unix domain socket" handling method
around the netlink method.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd a exec event to the event handler of cgrulesengd daemon.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:50:09 +0000 (14:50 +0900)] 
Add a exec event to the event handler of cgrulesengd daemon.

Hi,

Changelog of v6:
================
 * Change the cgroup_get_procname_from_procfs() calling for the
   returning value's change.

Changelog of v5:
================
 * No change.

Changelog of v4:
================
 * No change.

Changelog of v3:
================
 * No change.

Changelog of v2:
================
 * No change.

Description:
============
A process name is changed when execve(2), so a new rule based on
process name should be applied when execve(2) happens.
Then this patch adds an EXEC event to the event handler.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the key "process name" to find a matching rule.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:49:50 +0000 (14:49 +0900)] 
Add the key "process name" to find a matching rule.

Hi,

Changelog of v6:
================
 * No change.

Changelog of v5.1:
==================
 * BUGFIX: Clear the flags meaning "found a matching rule"
   when a process name does not match.

   There was a problem that cgexec and cgclassify didn't work correctly
   if a user executes cgexec/cgclassify based on /etc/cgrules.conf.
   For example, if a root user executes `cgclassify $$` on the following
   /etc/cgrules.conf, the process ($$) should be moved to users/root on
   cpuset and memory subsystems. But the process was moved to users/root/cp
   on memory subsystem only.
     Example of /etc/cgrules.conf:
     =============================
     root:cp          cpuset  users/root/cp
     %                memory  users/root/cp
     root             cpuset  users/root
     %                memory  users/root

   The cause is why the flags meaning "found a matching rule" (uid, gid, and
   matched) is not cleared when a process name does not match. This problem
   is fixed on this patch.

Changelog of v5:
================
 * Rebase the patch to the latest code.

Changelog of v4:
================
 * No change.

Changelog of v3:
================
 * BUGFIX: Fix the handling of '%' in /etc/cgrules.conf.

Changelog of v2:
================
 * Use strcmp() instead of strncmp() for checking a process name strictly.
 * Some cleanups.

Description:
============
This patch adds the key "process name" to find a matching rule.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd the parser of process name in /etc/cgrules.conf.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:49:36 +0000 (14:49 +0900)] 
Add the parser of process name in /etc/cgrules.conf.

Hi,

Changelog of v6:
================
 * The definations of CGROUP_RULE_MAXKEY and CGROUP_RULE_MAXLINE are
   moved to libcgroup-internal.h since no one from outside should be
   using them.

Changelog of v5:
================
 * Rebase the patch to the latest code.

Changelog of v4:
================
 * Use more safety length of a user name for the buffer "username".
 * Move the macros min()/max() to src/libcgroup-internal.h for using
   in src/api.c also.

Changelog of v3:
================
 * Fix unclear buffer of user by memset().

Changelog of v2:
================
 * Remove unnecessary memset().
 * Some cleanups.

Description:
============
This patch adds the parser of process name in /etc/cgrules.conf.

A new rule based on process name is as the following, and the process
name is stored into the member "procname" in struct cgroup_rule.
  <user>:<process name>  <controllers>   <destination>

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd cgroup_get_procname_from_procfs() for getting a process name.
Ken'ichi Ohmichi [Fri, 26 Jun 2009 05:49:16 +0000 (14:49 +0900)] 
Add cgroup_get_procname_from_procfs() for getting a process name.

Hi,

Changelog of v6:
================
 * Change the returning values of *_get_procname_from_proc*() to integer
   from charactor pointer.
 * Clarify the number meaning of string length in cg_get_procname_from_
   ~proc_status()

Changelog of v5:
================
 * Rebase the patch to the latest code.

Changelog of v4:
================
 * Add the error handling for strdup()'s error.
 * Reduce strlen() calls.
 * Make the check code of a process name simple.

Changelog of v3:
================
 * Move cgroup_get_procname_from_procfs() to libcgroup-internal.h.
 * Fix unclear buffer of buf_cwd by memset().
 * Get a real path of script file by realpath().

Changelog of v2:
================
 * It is possible to handle a process, which name length is over than
   16 characters, also.

Description:
============
This patch adds a new function cgroup_get_procname_from_procfs()
for getting a process name.

This function allocates the memory for a process name, and writes
the name to the memory, and returns the pointer of the memory.
So a caller should free the memory if unusing it.

The process name, which is wrotten by this function, depends on
the specified process:

 If a command process)      the full path of command.
 If a shell script process) the full path of shell script.
 If a kernel thread)        the process name of kernel thread.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Add get_mount_point test case
Dhaval Giani [Fri, 26 Jun 2009 17:46:22 +0000 (23:16 +0530)] 
libcgroup: Add get_mount_point test case

The test case to test the new mount point API.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Introduce an API to get the mount point of a specific subsystem
Dhaval Giani [Fri, 26 Jun 2009 17:36:18 +0000 (23:06 +0530)] 
libcgroup: Introduce an API to get the mount point of a specific subsystem

Introduce an API which will query the mount table and return the mount point
of a specific subsystem. This is needed in the case when the user knows which
subsystem he wants the details of, which would make the use of the get_controller*
APIs cumbersome.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoFix some warnings.
Ken'ichi Ohmichi [Tue, 23 Jun 2009 06:32:43 +0000 (15:32 +0900)] 
Fix some warnings.

Hi,

The latest source (commit: 5ea9a7819b717a83af03aa2ea234f105ed717589)
outputs some following warnings:

 $ make
 [snip]
 api.c: In function 'cgroup_walk_tree_begin':
 api.c:2350: warning: passing argument 3 of 'cg_walk_node' makes integer from pointer without a cast
 api.c:2315: warning: unused variable 'fts'
 [snip]
 $

This patch fixes them.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Fix a missing goto in clean cgroups API
Dhaval Giani [Mon, 22 Jun 2009 13:09:55 +0000 (18:39 +0530)] 
libcgroup: Fix a missing goto in clean cgroups API

Jan pointed out that there was a goto missing in the error
handling paths. Fix that bug.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agolibcgroup: Introduce a unload cgroups API
Dhaval Giani [Mon, 22 Jun 2009 11:50:09 +0000 (17:20 +0530)] 
libcgroup: Introduce a unload cgroups API

This API will unload the cgroups created in the cgroupfs and
unmount and delete the filesystem mount point. The action is
equivalent to what is done currently in service cgconfig stop.

The reason for this API is to make sure we don't end up with a
asymmetric library API subset. Today an application program can
programatically through cgroup_config_load_config() load a
configuration file, but has no means to cleanup (including all
temporarily created groups).

changes from v3
1. Address Jan's comments from http://article.gmane.org/gmane.comp.lib.libcg.devel/1105
changes from v2
1. Fix a leak as noted by Bharata
2. Address Balbir's review comments at
http://article.gmane.org/gmane.comp.lib.libcg.devel/1080
changes from v1
1. Change the name of the function to cgroup_unload_cgroups
2. Change the name of the executatble to cgclear
3. Split out the funtions

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agolibcgroup: Introduce get_controller API
Dhaval Giani [Thu, 18 Jun 2009 14:12:48 +0000 (19:42 +0530)] 
libcgroup: Introduce get_controller API

This set of APIs will allow the caller to query the mount table
and find out what controller is mounted at what path.

Test program has been included in the patch. Running the test program
results in

[dhaval@gondor tests]$ ../libtool --mode=execute ./get_controller
Controller cpu is mounted at /cgroup
Controller cpuacct is mounted at /cgroup
Controller memory is mounted at /cgroup1
[dhaval@gondor tests]$

Which is the setup on this system.

Changes from v2
1. Remove the incorrect comments as pointed out by Bharata

Changes from v1
1. Use a new structure as mentioned by bharata to return the values.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Cc: Jan Safranek <jsafrane@redhat.com>
Acked-by: Bharata B Rao <bharata@linux.vnet.ibm.com>
16 years agolibcgroup: Use double pointers everywhere in the get_task APIs
Dhaval Giani [Thu, 18 Jun 2009 14:12:47 +0000 (19:42 +0530)] 
libcgroup: Use double pointers everywhere in the get_task APIs

As Jan Safranek pointed out, it is better to have double pointers
everywhere in the get_task API to keep consistency. Do the same.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agolibcgroup: Introduce post order walk
Dhaval Giani [Thu, 18 Jun 2009 14:12:46 +0000 (19:42 +0530)] 
libcgroup: Introduce post order walk

With the introduction of the flags, we now actually make use of them.
This patch adds a post mode and modifies the test case to also do a post
order walk.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Acked-by: Bharata B Rao <bharata@linux.vnet.ibm.com>
16 years agolibcgroup: Add flags to the walk_tree handle
Dhaval Giani [Thu, 18 Jun 2009 14:12:45 +0000 (19:42 +0530)] 
libcgroup: Add flags to the walk_tree handle

Introduce a cgroup_tree_handle structure so that we can track flags for
the walk_tree operation. In a number of cases we would prefer to walk the
tree in postorder as opposed to pre-order which is the current default.
This patch does the addition.

Changes since V1:
1. Added checks for !handle as suggested by Bharata

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Acked-by: Bharata B Rao <bharata@linux.vnet.ibm.com>
16 years agocgconfigparser: Change mkdir in cgroup_config_mount_fs to mkdir -p
Dhaval Giani [Thu, 18 Jun 2009 14:12:44 +0000 (19:42 +0530)] 
cgconfigparser: Change mkdir in cgroup_config_mount_fs to mkdir -p

https://bugzilla.redhat.com/show_bug.cgi?id=502687 mentioned that the directory
was not getting created when a cgconfig start was being run.

This is was because we failed the mkdir. The mkdir for directories at depth
was not succeeding.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
16 years agoAdds cgset man page
Ivana Varekova [Thu, 4 Jun 2009 14:43:46 +0000 (16:43 +0200)] 
Adds cgset man page

This patch adds cgset man page - it includes Makefile changes

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoThis patch adds cgset tool
Ivana Varekova [Thu, 4 Jun 2009 14:43:38 +0000 (16:43 +0200)] 
This patch adds cgset tool

This patch adds cgset tool, which sets parameters of controllers
for given cgroup based on input name-variable pairs
- the syntax is:

cgset -r <name=value> <relative path to cgroup>

-------------------------------------------------
EXAMPLES:
$ cgcreate -g cpuset:test1
$ cgset -r cpuset.cpus=1 test
$ cat ./test/cpuset.cpus
1

$ cgcreate -g cpuset:test1 -g cpuset:test2
$ cgset -r cpuset.cpus=0 test1 test2
$ cat /mnt/cgroups/cpuset/test1/cpuset.cpus
0
$ cat /mnt/cgroups/cpuset/test2/cpuset.cpus
0

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoPrevent to add multiple versions of the same controller to mount_table
Ivana Varekova [Thu, 18 Jun 2009 05:50:30 +0000 (07:50 +0200)] 
Prevent to add multiple versions of the same controller to mount_table

This patche add a test to cgroup_init function, which prevent to add
multiple records for the same controller (this is a problem eg. in
cgroup_get_cgroup function - which looks to mount table and add all
relevant controllers using cgroup_add_controller function and when the
function calls cgroup_add_cgroup function twice on the same controller,
it returns error so the result is cgroup_get_cgroup failed).

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Integrate similar code to cgroup_get_uid_gid_from_procfs().
Ken'ichi Ohmichi [Mon, 8 Jun 2009 08:18:43 +0000 (17:18 +0900)] 
Cleanup: Integrate similar code to cgroup_get_uid_gid_from_procfs().

CHANGELOG of v2.1:
================
* Rebase the patch for commit '340feae163c4797a6cb1247b3812c1ccdc52fa41'.

There are some similar functions for getting process's data (uid, gid) from
/proc/<pid>/status file, so this patch integrates these functions into one
cgroup_get_uid_gid_from_procfs().

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Remove unnecessary 'err' value.
Ken'ichi Ohmichi [Wed, 3 Jun 2009 06:03:44 +0000 (15:03 +0900)] 
Cleanup: Remove unnecessary 'err' value.

Hi,

CHANGELOG of v2:
================
* New patch.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Rename "name" to "username" in struct cgroup_rule.
Ken'ichi Ohmichi [Wed, 3 Jun 2009 06:03:24 +0000 (15:03 +0900)] 
Cleanup: Rename "name" to "username" in struct cgroup_rule.

Hi,

CHANGELOG of v2:
================
* No change.

To add the member "procname" to struct cgroup_rule by later patch, this
patch renames the member "name" to "username" for the clarification.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Add cg_skip_unused_charactors_in_rule().
Ken'ichi Ohmichi [Wed, 3 Jun 2009 06:02:59 +0000 (15:02 +0900)] 
Cleanup: Add cg_skip_unused_charactors_in_rule().

Hi,

CHANGELOG of v2:
================
* No change.

The loop in cgroup_parse_rules() is a little long now, and it is not
easy to read the loop.
Then, This patch shortens the loop for the readability.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Use sizeof() in memset().
Ken'ichi Ohmichi [Thu, 4 Jun 2009 04:59:49 +0000 (13:59 +0900)] 
Cleanup: Use sizeof() in memset().

Changelog of v3:
================
* Remove unnecessary memset().

fgets()/sscanf() does not care what is in the buffer, and it is
unnecessary to clear the buffer before.

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: Remove unnecessary strlen() in strncpy().
Ken'ichi Ohmichi [Wed, 3 Jun 2009 06:01:56 +0000 (15:01 +0900)] 
Cleanup: Remove unnecessary strlen() in strncpy().

Hi,

CHANGELOG of v2:
================
* Specify the buffer size of 'user' instead of strlen().

It actually walks through 'user' twice, once to compute length by
strlen() and then this patch specifies the buffer size of 'user' instead.

Reported-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Reviewed-By: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdds cgcreate man page
Ivana Varekova [Wed, 3 Jun 2009 07:37:13 +0000 (09:37 +0200)] 
Adds cgcreate man page

This patch adds cgcreate man page - it includes Makefile.in changes

Signed-off-by: Ivana Varekova <varekova@redhat.com>
16 years agoThis patch adds cgcreate tool
Ivana Varekova [Wed, 3 Jun 2009 07:37:05 +0000 (09:37 +0200)] 
This patch adds cgcreate tool

This patch adds cgcreate tool, which creates cgroups based on input
    parameters - the syntax is:

    cgcreate -t <tuid>:<tgid> -a <agid>:<auid> -g <list of
controllers>:<relative path to cgroup>

    where:
    -a enables user to define admin gid and uid (implicit values are the
same values which are in the parent directory)
    -t enables user to define task gid and uid (implicit values are the
same values which are in parent directory)
    -g sets pairs list of controllers-relative path to cgroup

-------------------------------------------------
EXAMPLES:
* ../../libtool --mode=execute ./cgcreate -a :varekova  -g cpuacct:first

* ll /mnt/cgroups/cpuacct | grep first
drwxrwxr-x 2 root     varekova 0 2009-06-03 09:14 first

* ll /mnt/cgroups/cpuacct/first/*
-rwxrwxr-x 1 root varekova 0 2009-06-03 09:14 /mnt/cgroups/cpuacct/first/cpuacct.usage
-rwxrwxr-x 1 root varekova 0 2009-06-03 09:14 /mnt/cgroups/cpuacct/first/notify_on_release
-rwxrwxr-x 1 root varekova 0 2009-06-03 09:14 /mnt/cgroups/cpuacct/first/tasks

* ../../libtool --mode=execute ./cgcreate -a varekova:root -t varekova:varekova -g cpuacct:second

* ll /mnt/cgroups/cpuacct/ | grep second
drwxrwxr-x 2 varekova root     0 2009-06-03 09:13 second

* ll /mnt/cgroups/cpuacct/second
total 0
-rwxrwxr-x 1 varekova root     0 2009-06-03 09:13 cpuacct.usage
-rwxrwxr-x 1 varekova root     0 2009-06-03 09:13 notify_on_release
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:13 tasks

* ../../libtool --mode=execute ./cgcreate -a varekova:varekova  -g cpuacct:third -g cpuacct:fourth

* ll /mnt/cgroups/cpuacct | grep h
drwxrwxr-x 2 varekova varekova 0 2009-06-03 09:18 fourth
drwxrwxr-x 2 varekova varekova 0 2009-06-03 09:18 third

* ll /mnt/cgroups/cpuacct/*h*
/mnt/cgroups/cpuacct/fourth:
total 0
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 cpuacct.usage
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 notify_on_release
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 tasks

/mnt/cgroups/cpuacct/third:
total 0
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 cpuacct.usage
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 notify_on_release
-rwxrwxr-x 1 varekova varekova 0 2009-06-03 09:18 tasks

Signed-off-by: Ivana Varekova <varekova@redhat.com>
16 years agolibcgroup: Export cgroup_get_controller API
Dhaval Giani [Tue, 2 Jun 2009 10:51:12 +0000 (16:21 +0530)] 
libcgroup: Export cgroup_get_controller API

libcgroup: Export cgroup_get_controller API

This wrapper was not exposed for some reason earlier. Make it available
from the library.

Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd cgroup_free_group_spec procedure
Ivana Varekova [Thu, 21 May 2009 10:06:20 +0000 (12:06 +0200)] 
Add cgroup_free_group_spec procedure

Add cgroup_free_group_spec procedure which free cgroups_group_spec
variable.

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoparse_cgroup_spec function does not initializesd allocated memory
Ivana Varekova [Thu, 21 May 2009 10:05:42 +0000 (12:05 +0200)] 
parse_cgroup_spec function does not initializesd allocated memory

parse_cgroup_spec function does not initializesd allocated memory
this patch allocate it to zero so there is no problem with uninitialized
values.

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoMerge branch 'devel/automake-updates' of git://fedorapeople.org/~jsafrane/libcg
Dhaval Giani [Fri, 29 May 2009 10:14:57 +0000 (15:44 +0530)] 
Merge branch 'devel/automake-updates' of git://fedorapeople.org/~jsafrane/libcg

16 years agoCheck for PAM headers and libraries
Jan Safranek [Mon, 25 May 2009 07:48:58 +0000 (09:48 +0200)] 
Check for PAM headers and libraries

When PAM module is enabled, configure script should check if
necessary headers and libraries are available.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
16 years agoAdd options to enable/disable various build targets.
Jan Safranek [Mon, 25 May 2009 07:48:34 +0000 (09:48 +0200)] 
Add options to enable/disable various build targets.

By default, everything is compiled. I want to add options to ./configure,
which can selectively disable tools, daemon and pam module. The library
itself is mandatory component and cannot be disabled.

Usage:
./configure --help
./configure --disable-tools --disable-pam --disable-daemon

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
16 years agoRemove missing file
Jan Safranek [Mon, 25 May 2009 07:48:14 +0000 (09:48 +0200)] 
Remove missing file

File named 'missing' is generated by automake (or libtool?), it's not
necessary to have it in git.

Signed-off-by: Jan Safranek <jsafrane@redhat.com>
16 years agoconfigure.in problem with byacc and flex
Ivana Varekova [Fri, 22 May 2009 11:11:04 +0000 (13:11 +0200)] 
configure.in problem with byacc and flex

fix the problem - can be applied now :)

configure.in file wrongly handles YACC and LEX variables so ./configure
exit succesfully, but make fails.
The problems are:
* it enables configuration even if no yacc is installed (it is necessary
for make) - YACC is set to byacc in this case
* the configure.in enables configuration if no lex is installed (it is
again necessary for succesfull make) - in this case YAC is set to ":" i

Signed-off-by: Ivana Varekova <varekova@redhat.com>
Acked-by: Jan Safranek <jsafrane@redhat.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoFix the deadlock of rl_lock.
Ken'ichi Ohmichi [Tue, 19 May 2009 00:19:29 +0000 (09:19 +0900)] 
Fix the deadlock of rl_lock.

Hi,

Changelog of v2:
  - Add the description of the problematic call sequence.
  - There is not any change in the code.

[PATCH-v2] Fix the deadlock of rl_lock.

For avoiding the deadlock, protect cdgroup_change_cgroup_uid_gid_flags()
by blocking SIGUSR2 signal.

The problematic call sequence is the following:
----------------------------------------------------------------------
* CGRULESENGD DAEMON *
  << cgre_flash_rules() is the signal handler for SIGUSR2 signal >>
  cgre_create_netlink_socket_process_msg()
    << Receive a UID/GID event packet >>
    cgre_handle_msg()
      cgre_process_event()
        cgroup_change_cgroup_uid_gid_flags()
          cgroup_find_matching_rule_uid_gid()
            pthread_rwlock_wrlock(&rl_lock);  << Get the lock of rl_lock >>
            << Receive a SIGUSR2 signal, and switch to cgre_flash_rules() >>
  cgre_flash_rules()
    cgroup_reload_cached_rules()
      cgroup_parse_rules()
        pthread_rwlock_wrlock(&rl_lock);  << deadlock ! >>
----------------------------------------------------------------------

A cgrulesengd daemon needs a lock of rl_lock for referring configuration
buffer. On the other way, the daemon reloads configuration file when
receiving SIGUSR2 signal, and it needs the same lock in cgroup_parse_rules().
So cgroup_change_cgroup_uid_gid_flags() should be protected from SIGUSR2
signal for avoiding the deadlock.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoFix the deadlock of vsyslog() call.
Ken'ichi Ohmichi [Fri, 15 May 2009 08:30:24 +0000 (17:30 +0900)] 
Fix the deadlock of vsyslog() call.

Hi,

I found the deadlock problem that a cgrulesengd daemon stalls if
service "cgred" is reloaded while many UID events happen.
The following is the gdb output by attaching the stalling daemon:

 (gdb) bt
 #0  0x0000003b298dd918 in __lll_mutex_lock_wait () from /lib64/libc.so.6
 #1  0x0000003b298ce847 in _L_lock_646 () from /lib64/libc.so.6
 #2  0x0000003b298ce2da in __vsyslog_chk () from /lib64/libc.so.6
 #3  0x0000000000401533 in flog (level=5, format=0x402778 "Reloading rules configuration.") at cgrule sengd.c:130
 #4  0x00000000004015d1 in cgre_flash_rules (signum=<value optimized out>) at cgrulesengd.c:644
 #5  <signal handler called>
 #6  0x0000003b298d27b5 in send () from /lib64/libc.so.6
 #7  0x0000003b298ce3a0 in __vsyslog_chk () from /lib64/libc.so.6
 #8  0x0000000000401533 in flog (level=4, format=0x402b82 "Failed to open %s") at cgrulesengd.c:130
 #9  0x0000000000401cc7 in cgre_process_event (ev=0x7fff8ad11cc4, type=4) at cgrulesengd.c:161
 #10 0x0000000000401fd5 in cgre_create_netlink_socket_process_msg () at cgrulesengd.c:486
 #11 0x00000000004023ca in main (argc=1, argv=<value optimized out>) at cgrulesengd.c:878
 (gdb)

We can see __vsyslog_chk() is called twice, because the daemon
recieved a SIGUSR2 signal in __vsyslog_chk(). In __vsyslog_chk(),
"syslog_lock" is locked by __libc_lock_lock(syslog_lock).
So I think vsyslog() should be protected by blocking the signal,
and this patch fixes the problem by doing it.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup the infinite loop of cgrulesengddaemon.
Ken'ichi Ohmichi [Thu, 7 May 2009 04:08:40 +0000 (13:08 +0900)] 
Cleanup the infinite loop of cgrulesengddaemon.

Hi,

This patch clarifies the infinite loop.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Acked-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoCleanup: make the indent of cgroup_init()shallower.
Ken'ichi Ohmichi [Wed, 13 May 2009 04:27:57 +0000 (13:27 +0900)] 
Cleanup: make the indent of cgroup_init()shallower.

Hi,

This patch makes the indent of cgroup_init() shallower for the readability.

Thanks
Ken'ichi Ohmichi

Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Acked-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>
16 years agoAdd fclose() calls into egid_of_pid().
Ken'ichi Ohmichi [Mon, 18 May 2009 07:00:37 +0000 (16:00 +0900)] 
Add fclose() calls into egid_of_pid().

Hi,

This patch adds necessary fclose() calls into egid_of_pid().

Thanks
Ken'ichi Ohmichi

Reported-by: Masayuki Igawa <igawa@mxs.nes.nec.co.jp>
Signed-off-by: Ken'ichi Ohmichi <oomichi@mxs.nes.nec.co.jp>
Signed-off-by: Dhaval Giani <dhaval@linux.vnet.ibm.com>