diff options
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/cpuset.c | 7 | ||||
| -rw-r--r-- | kernel/ptrace.c | 6 | ||||
| -rw-r--r-- | kernel/sched_rt.c | 14 | ||||
| -rw-r--r-- | kernel/sysctl.c | 15 |
4 files changed, 27 insertions, 15 deletions
diff --git a/kernel/cpuset.c b/kernel/cpuset.c index 4349935c2ad8..e92e98189032 100644 --- a/kernel/cpuset.c +++ b/kernel/cpuset.c | |||
| @@ -1575,8 +1575,10 @@ static int cpuset_write_resmask(struct cgroup *cgrp, struct cftype *cft, | |||
| 1575 | return -ENODEV; | 1575 | return -ENODEV; |
| 1576 | 1576 | ||
| 1577 | trialcs = alloc_trial_cpuset(cs); | 1577 | trialcs = alloc_trial_cpuset(cs); |
| 1578 | if (!trialcs) | 1578 | if (!trialcs) { |
| 1579 | return -ENOMEM; | 1579 | retval = -ENOMEM; |
| 1580 | goto out; | ||
| 1581 | } | ||
| 1580 | 1582 | ||
| 1581 | switch (cft->private) { | 1583 | switch (cft->private) { |
| 1582 | case FILE_CPULIST: | 1584 | case FILE_CPULIST: |
| @@ -1591,6 +1593,7 @@ static int cpuset_write_resmask(struct cgroup *cgrp, struct cftype *cft, | |||
| 1591 | } | 1593 | } |
| 1592 | 1594 | ||
| 1593 | free_trial_cpuset(trialcs); | 1595 | free_trial_cpuset(trialcs); |
| 1596 | out: | ||
| 1594 | cgroup_unlock(); | 1597 | cgroup_unlock(); |
| 1595 | return retval; | 1598 | return retval; |
| 1596 | } | 1599 | } |
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index 1708b1e2972d..e2302e40b360 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c | |||
| @@ -163,7 +163,7 @@ bool ptrace_may_access(struct task_struct *task, unsigned int mode) | |||
| 163 | return !err; | 163 | return !err; |
| 164 | } | 164 | } |
| 165 | 165 | ||
| 166 | int ptrace_attach(struct task_struct *task) | 166 | static int ptrace_attach(struct task_struct *task) |
| 167 | { | 167 | { |
| 168 | int retval; | 168 | int retval; |
| 169 | 169 | ||
| @@ -219,7 +219,7 @@ out: | |||
| 219 | * Performs checks and sets PT_PTRACED. | 219 | * Performs checks and sets PT_PTRACED. |
| 220 | * Should be used by all ptrace implementations for PTRACE_TRACEME. | 220 | * Should be used by all ptrace implementations for PTRACE_TRACEME. |
| 221 | */ | 221 | */ |
| 222 | int ptrace_traceme(void) | 222 | static int ptrace_traceme(void) |
| 223 | { | 223 | { |
| 224 | int ret = -EPERM; | 224 | int ret = -EPERM; |
| 225 | 225 | ||
| @@ -293,7 +293,7 @@ static bool __ptrace_detach(struct task_struct *tracer, struct task_struct *p) | |||
| 293 | return false; | 293 | return false; |
| 294 | } | 294 | } |
| 295 | 295 | ||
| 296 | int ptrace_detach(struct task_struct *child, unsigned int data) | 296 | static int ptrace_detach(struct task_struct *child, unsigned int data) |
| 297 | { | 297 | { |
| 298 | bool dead = false; | 298 | bool dead = false; |
| 299 | 299 | ||
diff --git a/kernel/sched_rt.c b/kernel/sched_rt.c index ad6267714c84..01f75a5f17af 100644 --- a/kernel/sched_rt.c +++ b/kernel/sched_rt.c | |||
| @@ -210,11 +210,12 @@ static void dequeue_rt_entity(struct sched_rt_entity *rt_se); | |||
| 210 | 210 | ||
| 211 | static void sched_rt_rq_enqueue(struct rt_rq *rt_rq) | 211 | static void sched_rt_rq_enqueue(struct rt_rq *rt_rq) |
| 212 | { | 212 | { |
| 213 | int this_cpu = smp_processor_id(); | ||
| 214 | struct task_struct *curr = rq_of_rt_rq(rt_rq)->curr; | 213 | struct task_struct *curr = rq_of_rt_rq(rt_rq)->curr; |
| 215 | struct sched_rt_entity *rt_se; | 214 | struct sched_rt_entity *rt_se; |
| 216 | 215 | ||
| 217 | rt_se = rt_rq->tg->rt_se[this_cpu]; | 216 | int cpu = cpu_of(rq_of_rt_rq(rt_rq)); |
| 217 | |||
| 218 | rt_se = rt_rq->tg->rt_se[cpu]; | ||
| 218 | 219 | ||
| 219 | if (rt_rq->rt_nr_running) { | 220 | if (rt_rq->rt_nr_running) { |
| 220 | if (rt_se && !on_rt_rq(rt_se)) | 221 | if (rt_se && !on_rt_rq(rt_se)) |
| @@ -226,10 +227,10 @@ static void sched_rt_rq_enqueue(struct rt_rq *rt_rq) | |||
| 226 | 227 | ||
| 227 | static void sched_rt_rq_dequeue(struct rt_rq *rt_rq) | 228 | static void sched_rt_rq_dequeue(struct rt_rq *rt_rq) |
| 228 | { | 229 | { |
| 229 | int this_cpu = smp_processor_id(); | ||
| 230 | struct sched_rt_entity *rt_se; | 230 | struct sched_rt_entity *rt_se; |
| 231 | int cpu = cpu_of(rq_of_rt_rq(rt_rq)); | ||
| 231 | 232 | ||
| 232 | rt_se = rt_rq->tg->rt_se[this_cpu]; | 233 | rt_se = rt_rq->tg->rt_se[cpu]; |
| 233 | 234 | ||
| 234 | if (rt_se && on_rt_rq(rt_se)) | 235 | if (rt_se && on_rt_rq(rt_se)) |
| 235 | dequeue_rt_entity(rt_se); | 236 | dequeue_rt_entity(rt_se); |
| @@ -565,8 +566,11 @@ static int do_sched_rt_period_timer(struct rt_bandwidth *rt_b, int overrun) | |||
| 565 | if (rt_rq->rt_time || rt_rq->rt_nr_running) | 566 | if (rt_rq->rt_time || rt_rq->rt_nr_running) |
| 566 | idle = 0; | 567 | idle = 0; |
| 567 | raw_spin_unlock(&rt_rq->rt_runtime_lock); | 568 | raw_spin_unlock(&rt_rq->rt_runtime_lock); |
| 568 | } else if (rt_rq->rt_nr_running) | 569 | } else if (rt_rq->rt_nr_running) { |
| 569 | idle = 0; | 570 | idle = 0; |
| 571 | if (!rt_rq_throttled(rt_rq)) | ||
| 572 | enqueue = 1; | ||
| 573 | } | ||
| 570 | 574 | ||
| 571 | if (enqueue) | 575 | if (enqueue) |
| 572 | sched_rt_rq_enqueue(rt_rq); | 576 | sched_rt_rq_enqueue(rt_rq); |
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index 0f1bd83db985..4eed0af5d144 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
| @@ -194,9 +194,9 @@ static int sysrq_sysctl_handler(ctl_table *table, int write, | |||
| 194 | static struct ctl_table root_table[]; | 194 | static struct ctl_table root_table[]; |
| 195 | static struct ctl_table_root sysctl_table_root; | 195 | static struct ctl_table_root sysctl_table_root; |
| 196 | static struct ctl_table_header root_table_header = { | 196 | static struct ctl_table_header root_table_header = { |
| 197 | .count = 1, | 197 | {{.count = 1, |
| 198 | .ctl_table = root_table, | 198 | .ctl_table = root_table, |
| 199 | .ctl_entry = LIST_HEAD_INIT(sysctl_table_root.default_set.list), | 199 | .ctl_entry = LIST_HEAD_INIT(sysctl_table_root.default_set.list),}}, |
| 200 | .root = &sysctl_table_root, | 200 | .root = &sysctl_table_root, |
| 201 | .set = &sysctl_table_root.default_set, | 201 | .set = &sysctl_table_root.default_set, |
| 202 | }; | 202 | }; |
| @@ -1567,11 +1567,16 @@ void sysctl_head_get(struct ctl_table_header *head) | |||
| 1567 | spin_unlock(&sysctl_lock); | 1567 | spin_unlock(&sysctl_lock); |
| 1568 | } | 1568 | } |
| 1569 | 1569 | ||
| 1570 | static void free_head(struct rcu_head *rcu) | ||
| 1571 | { | ||
| 1572 | kfree(container_of(rcu, struct ctl_table_header, rcu)); | ||
| 1573 | } | ||
| 1574 | |||
| 1570 | void sysctl_head_put(struct ctl_table_header *head) | 1575 | void sysctl_head_put(struct ctl_table_header *head) |
| 1571 | { | 1576 | { |
| 1572 | spin_lock(&sysctl_lock); | 1577 | spin_lock(&sysctl_lock); |
| 1573 | if (!--head->count) | 1578 | if (!--head->count) |
| 1574 | kfree(head); | 1579 | call_rcu(&head->rcu, free_head); |
| 1575 | spin_unlock(&sysctl_lock); | 1580 | spin_unlock(&sysctl_lock); |
| 1576 | } | 1581 | } |
| 1577 | 1582 | ||
| @@ -1948,10 +1953,10 @@ void unregister_sysctl_table(struct ctl_table_header * header) | |||
| 1948 | start_unregistering(header); | 1953 | start_unregistering(header); |
| 1949 | if (!--header->parent->count) { | 1954 | if (!--header->parent->count) { |
| 1950 | WARN_ON(1); | 1955 | WARN_ON(1); |
| 1951 | kfree(header->parent); | 1956 | call_rcu(&header->parent->rcu, free_head); |
| 1952 | } | 1957 | } |
| 1953 | if (!--header->count) | 1958 | if (!--header->count) |
| 1954 | kfree(header); | 1959 | call_rcu(&header->rcu, free_head); |
| 1955 | spin_unlock(&sysctl_lock); | 1960 | spin_unlock(&sysctl_lock); |
| 1956 | } | 1961 | } |
| 1957 | 1962 | ||
