Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 23423
b: refs/heads/master
c: 151a442
h: refs/heads/master
i:
  23421: e430b7c
  23419: 63341eb
  23415: 4e729c6
  23407: b4bcaaa
  23391: 931460a
  23359: 2e1d20d
  23295: 5aa4f19
v: v3
  • Loading branch information
Paul Jackson authored and Linus Torvalds committed Mar 24, 2006
1 parent 0ab495f commit ffd4903
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 9 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 8488bc359d674baf710992e4b641513ea5ebd212
refs/heads/master: 151a44202d097ae8b1bbaa6d8d2f97df30e3cd1e
19 changes: 11 additions & 8 deletions trunk/kernel/cpuset.c
Original file line number Diff line number Diff line change
Expand Up @@ -149,7 +149,7 @@ static inline int is_spread_slab(const struct cpuset *cs)
}

/*
* Increment this atomic integer everytime any cpuset changes its
* Increment this integer everytime any cpuset changes its
* mems_allowed value. Users of cpusets can track this generation
* number, and avoid having to lock and reload mems_allowed unless
* the cpuset they're using changes generation.
Expand All @@ -163,8 +163,11 @@ static inline int is_spread_slab(const struct cpuset *cs)
* on every visit to __alloc_pages(), to efficiently check whether
* its current->cpuset->mems_allowed has changed, requiring an update
* of its current->mems_allowed.
*
* Since cpuset_mems_generation is guarded by manage_mutex,
* there is no need to mark it atomic.
*/
static atomic_t cpuset_mems_generation = ATOMIC_INIT(1);
static int cpuset_mems_generation;

static struct cpuset top_cpuset = {
.flags = ((1 << CS_CPU_EXCLUSIVE) | (1 << CS_MEM_EXCLUSIVE)),
Expand Down Expand Up @@ -877,7 +880,7 @@ static int update_nodemask(struct cpuset *cs, char *buf)

mutex_lock(&callback_mutex);
cs->mems_allowed = trialcs.mems_allowed;
cs->mems_generation = atomic_inc_return(&cpuset_mems_generation);
cs->mems_generation = cpuset_mems_generation++;
mutex_unlock(&callback_mutex);

set_cpuset_being_rebound(cs); /* causes mpol_copy() rebind */
Expand Down Expand Up @@ -1270,11 +1273,11 @@ static ssize_t cpuset_common_file_write(struct file *file, const char __user *us
break;
case FILE_SPREAD_PAGE:
retval = update_flag(CS_SPREAD_PAGE, cs, buffer);
cs->mems_generation = atomic_inc_return(&cpuset_mems_generation);
cs->mems_generation = cpuset_mems_generation++;
break;
case FILE_SPREAD_SLAB:
retval = update_flag(CS_SPREAD_SLAB, cs, buffer);
cs->mems_generation = atomic_inc_return(&cpuset_mems_generation);
cs->mems_generation = cpuset_mems_generation++;
break;
case FILE_TASKLIST:
retval = attach_task(cs, buffer, &pathbuf);
Expand Down Expand Up @@ -1823,7 +1826,7 @@ static long cpuset_create(struct cpuset *parent, const char *name, int mode)
atomic_set(&cs->count, 0);
INIT_LIST_HEAD(&cs->sibling);
INIT_LIST_HEAD(&cs->children);
cs->mems_generation = atomic_inc_return(&cpuset_mems_generation);
cs->mems_generation = cpuset_mems_generation++;
fmeter_init(&cs->fmeter);

cs->parent = parent;
Expand Down Expand Up @@ -1913,7 +1916,7 @@ int __init cpuset_init_early(void)
struct task_struct *tsk = current;

tsk->cpuset = &top_cpuset;
tsk->cpuset->mems_generation = atomic_inc_return(&cpuset_mems_generation);
tsk->cpuset->mems_generation = cpuset_mems_generation++;
return 0;
}

Expand All @@ -1932,7 +1935,7 @@ int __init cpuset_init(void)
top_cpuset.mems_allowed = NODE_MASK_ALL;

fmeter_init(&top_cpuset.fmeter);
top_cpuset.mems_generation = atomic_inc_return(&cpuset_mems_generation);
top_cpuset.mems_generation = cpuset_mems_generation++;

init_task.cpuset = &top_cpuset;

Expand Down

0 comments on commit ffd4903

Please sign in to comment.