From: Balbir Singh <balbir@in.ibm.com>
To: Linux MM <linux-mm@kvack.org>
Cc: dev@openvz.org, ckrm-tech@lists.sourceforge.net,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
haveblue@us.ibm.com, rohitseth@google.com,
Balbir Singh <balbir@in.ibm.com>
Subject: [RFC][PATCH 6/8] RSS controller shares allocation
Date: Fri, 10 Nov 2006 01:06:19 +0530 [thread overview]
Message-ID: <20061109193619.21437.84173.sendpatchset@balbir.in.ibm.com> (raw)
In-Reply-To: <20061109193523.21437.86224.sendpatchset@balbir.in.ibm.com>
Support shares assignment and propagation.
Signed-off-by: Balbir Singh <balbir@in.ibm.com>
---
kernel/res_group/memctlr.c | 59 ++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 58 insertions(+), 1 deletion(-)
diff -puN kernel/res_group/memctlr.c~container-memctlr-shares kernel/res_group/memctlr.c
--- linux-2.6.19-rc2/kernel/res_group/memctlr.c~container-memctlr-shares 2006-11-09 22:20:28.000000000 +0530
+++ linux-2.6.19-rc2-balbir/kernel/res_group/memctlr.c 2006-11-09 22:20:28.000000000 +0530
@@ -32,6 +32,7 @@
#include <linux/res_group_rc.h>
#include <linux/memctlr.h>
#include <linux/mm.h>
+#include <linux/swap.h>
#include <asm/pgtable.h>
static const char res_ctlr_name[] = "memctlr";
@@ -55,6 +56,7 @@ struct memctlr {
int failures;
int magic;
spinlock_t lock;
+ long nr_pages;
};
struct res_controller memctlr_rg;
@@ -180,6 +182,7 @@ static void memctlr_init_new(struct memc
res->shares.unused_min_shares = SHARE_DEFAULT_DIVISOR;
memctlr_init_mem_counter(&res->counter);
+ res->nr_pages = SHARE_DONT_CARE;
spin_lock_init(&res->lock);
}
@@ -196,6 +199,7 @@ static struct res_shares *memctlr_alloc_
if (is_res_group_root(rgroup)) {
root_rgroup = rgroup;
memctlr_root = res;
+ res->nr_pages = nr_free_pages();
printk("Memory Controller version %s\n", version);
}
return &res->shares;
@@ -346,6 +350,11 @@ static ssize_t memctlr_show_stats(struct
len -= i;
j += i;
+ i = snprintf(buf, len, "Max Allowed Pages %ld\n", res->nr_pages);
+
+ buf += i;
+ len -= i;
+ j += i;
return j;
}
@@ -406,13 +415,61 @@ static void memctlr_move_task(struct tas
double_res_unlock(oldres, newres);
}
+static void recalc_and_propagate(struct memctlr *res, struct memctlr *parres)
+{
+ struct resource_group *child = NULL;
+ int child_divisor;
+ u64 numerator;
+ struct memctlr *child_res;
+
+ if (parres) {
+ if (res->shares.max_shares == SHARE_DONT_CARE ||
+ parres->shares.max_shares == SHARE_DONT_CARE)
+ return;
+
+ child_divisor = parres->shares.child_shares_divisor;
+ if (child_divisor == 0)
+ return;
+
+ numerator = (u64)(parres->shares.unused_min_shares *
+ res->shares.max_shares);
+ do_div(numerator, child_divisor);
+ numerator = (u64)(parres->nr_pages * numerator);
+ do_div(numerator, SHARE_DEFAULT_DIVISOR);
+ res->nr_pages = numerator;
+ }
+
+ for_each_child(child, res->rgroup) {
+ child_res = get_memctlr(child);
+ BUG_ON(!child_res);
+ recalc_and_propagate(child_res, res);
+ }
+
+}
+
+static void memctlr_shares_changed(struct res_shares *shares)
+{
+ struct memctlr *res, *parres;
+
+ res = get_memctlr_from_shares(shares);
+ if (!res)
+ return;
+
+ if (is_res_group_root(res->rgroup))
+ parres = NULL;
+ else
+ parres = get_memctlr((struct container *)res->rgroup->parent);
+
+ recalc_and_propagate(res, parres);
+}
+
struct res_controller memctlr_rg = {
.name = res_ctlr_name,
.ctlr_id = NO_RES_ID,
.alloc_shares_struct = memctlr_alloc_instance,
.free_shares_struct = memctlr_free_instance,
.move_task = memctlr_move_task,
- .shares_changed = NULL,
+ .shares_changed = memctlr_shares_changed,
.show_stats = memctlr_show_stats,
};
_
--
Balbir Singh,
Linux Technology Center,
IBM Software Labs
--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org. For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>
next prev parent reply other threads:[~2006-11-09 19:47 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-09 19:35 [RFC][PATCH 0/8] RSS controller for containers Balbir Singh
2006-11-09 19:35 ` [RFC][PATCH 1/8] Fix resource groups parsing, while assigning shares Balbir Singh
2006-11-09 19:35 ` [RFC][PATCH 2/8] RSS controller setup Balbir Singh
2006-11-09 19:35 ` [RFC][PATCH 3/8] RSS controller add callbacks Balbir Singh
2006-11-09 19:36 ` [RFC][PATCH 4/8] RSS controller accounting Balbir Singh
2006-11-10 9:06 ` Pavel Emelianov
2006-11-10 9:29 ` Balbir Singh
2006-11-09 19:36 ` [RFC][PATCH 5/8] RSS controller task migration support Balbir Singh
2006-11-09 19:36 ` Balbir Singh [this message]
2006-11-10 9:11 ` [RFC][PATCH 6/8] RSS controller shares allocation Pavel Emelianov
2006-11-10 10:27 ` [ckrm-tech] " Balbir Singh
2006-11-10 10:32 ` Pavel Emelianov
2006-11-10 12:55 ` Balbir Singh
2006-11-09 19:36 ` [RFC][PATCH 7/8] RSS controller fix resource groups parsing Balbir Singh
2006-11-10 9:13 ` Pavel Emelianov
2006-11-10 9:32 ` Balbir Singh
2006-11-09 19:36 ` [RFC][PATCH 8/8] RSS controller support reclamation Balbir Singh
2006-11-09 19:45 ` Arjan van de Ven
2006-11-10 1:56 ` [ckrm-tech] " Balbir Singh
2006-11-10 8:54 ` Pavel Emelianov
2006-11-10 9:16 ` Balbir Singh
2006-11-10 9:29 ` Pavel Emelianov
2006-11-10 12:42 ` Balbir Singh
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20061109193619.21437.84173.sendpatchset@balbir.in.ibm.com \
--to=balbir@in.ibm.com \
--cc=ckrm-tech@lists.sourceforge.net \
--cc=dev@openvz.org \
--cc=haveblue@us.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=rohitseth@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox