/* * Created by: Jason Wessel * * Copyright (c) 2010 Wind River Systems, Inc. All Rights Reserved. * * This file is licensed under the terms of the GNU General Public * License version 2. This program is licensed "as is" without any * warranty of any kind, whether express or implied. */ #include #include /* * All kdb shell command call backs receive argc and argv, where * argv[0] is the command the end user typed */ static int kdb_hello_cmd(int argc, const char **argv) { if (argc > 1) return KDB_ARGCOUNT; if (argc) kdb_printf("Hello %s.\n", argv[1]); else kdb_printf("Hello world!\n"); return 0; } static int __init kdb_hello_cmd_init(void) { /* * Registration of a dynamically added kdb command is done with * kdb_register() with the arguments being: * 1: The name of the shell command * 2: The function that processes the command * 3: Description of the usage of any arguments * 4: Descriptive text when you run help * 5: Number of characters to complete the command * 0 == type the whole command * 1 == match both "g" and "go" for example */ kdb_register("hello", kdb_hello_cmd, "[string]", "Say Hello World or Hello [string]", 0); return 0; } static void __exit kdb_hello_cmd_exit(void) { kdb_unregister("hello"); } module_init(kdb_hello_cmd_init); module_exit(kdb_hello_cmd_exit); MODULE_AUTHOR("WindRiver"); MODULE_DESCRIPTION("KDB example to add a hello command"); MODULE_LICENSE("GPL"); href='/cgit.cgi/linux/net-next.git/'>summaryrefslogtreecommitdiff
path: root/net/wimax
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2017-01-26 16:47:28 -0500
committerTejun Heo <tj@kernel.org>2017-01-26 16:47:28 -0500
commit07cd12945551b63ecb1a349d50a6d69d1d6feb4a (patch)
tree75f65eba7eac9277971082a2d5a4cf1370562c0c /net/wimax
parent7ce7d89f48834cefece7804d38fc5d85382edf77 (diff)
cgroup: don't online subsystems before cgroup_name/path() are operational
While refactoring cgroup creation, a5bca2152036 ("cgroup: factor out cgroup_create() out of cgroup_mkdir()") incorrectly onlined subsystems before the new cgroup is associated with it kernfs_node. This is fine for cgroup proper but cgroup_name/path() depend on the associated kernfs_node and if a subsystem makes the new cgroup_subsys_state visible, which they're allowed to after onlining, it can lead to NULL dereference. The current code performs cgroup creation and subsystem onlining in cgroup_create() and cgroup_mkdir() makes the cgroup and subsystems visible afterwards. There's no reason to online the subsystems early and we can simply drop cgroup_apply_control_enable() call from cgroup_create() so that the subsystems are onlined and made visible at the same time. Signed-off-by: Tejun Heo <tj@kernel.org> Reported-by: Konstantin Khlebnikov <khlebnikov@yandex-team.ru> Fixes: a5bca2152036 ("cgroup: factor out cgroup_create() out of cgroup_mkdir()") Cc: stable@vger.kernel.org # v4.6+
Diffstat (limited to 'net/wimax')