[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v1 2/3] sched_credit2.c : runqueue_per_core code
This patch do the following things: -Insertion of runqueue_per_core code -Boot paarmeter creation to select runqueue Signed-off-by : Uma Sharma <uma.sharma523@xxxxxxxxx> --- xen/common/sched_credit2.c | 39 ++++++++++++++++++++++++++++++++------- 1 file changed, 32 insertions(+), 7 deletions(-) diff --git a/xen/common/sched_credit2.c b/xen/common/sched_credit2.c index ad0a5d4..c45df87 100644 --- a/xen/common/sched_credit2.c +++ b/xen/common/sched_credit2.c @@ -85,8 +85,8 @@ * to a small value, and a fixed credit is added to everyone. * * The plan is for all cores that share an L2 will share the same - * runqueue. At the moment, there is one global runqueue for all - * cores. + * runqueue. At the moment, the code allows the user to choose runqueue + * to be used. Default used core runqueue. */ /* @@ -161,10 +161,16 @@ */ #define __CSFLAG_runq_migrate_request 3 #define CSFLAG_runq_migrate_request (1<<__CSFLAG_runq_migrate_request) - +/* CREDIT2_OPT_RUNQUEUE: Used to define the runqueue used + */ +#define CREDIT2_OPT_RUNQUEUE_CORE 1 +#define CREDIT2_OPT_RUNQUEUE_SOCKET 2 int opt_migrate_resist=500; integer_param("sched_credit2_migrate_resist", opt_migrate_resist); +static char __initdata opt_credit2_runqueue_string[10] = "core"; +string_param("credit2_runqueue", opt_credit2_runqueue_string); +int opt_credit2_runqueue=CREDIT2_OPT_RUNQUEUE_CORE; /* * Useful macros @@ -1940,10 +1946,14 @@ static void init_pcpu(const struct scheduler *ops, int cpu) /* Figure out which runqueue to put it in */ /* NB: cpu 0 doesn't get a STARTING callback, so we hard-code it to runqueue 0. */ - if ( cpu == 0 ) - rqi = 0; + if ( opt_credit2_runqueue == CREDIT2_OPT_RUNQUEUE_SOCKET ) + { + rqi = (cpu) ? cpu_to_socket(cpu) : boot_cpu_to_socket(); + } else - rqi = cpu_to_socket(cpu); + { + rqi = (cpu) ? cpu_to_core(cpu) : boot_cpu_to_core(); + } if ( rqi < 0 ) { @@ -1988,7 +1998,7 @@ csched2_alloc_pdata(const struct scheduler *ops, int cpu) { /* Check to see if the cpu is online yet */ /* Note: cpu 0 doesn't get a STARTING callback */ - if ( cpu == 0 || cpu_to_socket(cpu) >= 0 ) + if ( cpu == 0 || cpu_to_socket(cpu) >= 0 || cpu_to_core(cpu) >= 0 ) init_pcpu(ops, cpu); else printk("%s: cpu %d not online yet, deferring initializatgion\n", @@ -2109,6 +2119,21 @@ csched2_init(struct scheduler *ops) opt_load_window_shift = LOADAVG_WINDOW_SHIFT_MIN; } + /* Defines the runqueue used. */ + if ( !strcmp(opt_credit2_runqueue_string, "socket") ) + { + opt_credit2_runqueue=CREDIT2_OPT_RUNQUEUE_SOCKET; + printk("Runqueue : runqueue_per_socket\n"); + } + else if ( !strcmp(opt_credit2_runqueue_string, "core") ) + { + opt_credit2_runqueue=CREDIT2_OPT_RUNQUEUE_CORE; + printk("Runqueue : runqueue_per_core\n"); + } + else { + printk("Runqueue: credit2_runqueue entered incorrect Continuing with core\n"); + } + /* Basically no CPU information is available at this point; just * set up basic structures, and a callback when the CPU info is * available. */ -- 1.9.1 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |