gru: allow users to specify gru chiplet 1
Add table & user request infrastructure that is needed to allow users to specify the blade and chiplet for allocation of GRU contexts. Use of this information is in a subsequent patch. Signed-off-by: Jack Steiner <steiner@sgi.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
Родитель
9178052fda
Коммит
518e5cd4aa
|
@ -763,6 +763,16 @@ int gru_set_context_option(unsigned long arg)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
switch (req.op) {
|
switch (req.op) {
|
||||||
|
case sco_blade_chiplet:
|
||||||
|
/* Select blade/chiplet for GRU context */
|
||||||
|
if (req.val1 < -1 || req.val1 >= GRU_MAX_BLADES || !gru_base[req.val1] ||
|
||||||
|
req.val0 < -1 || req.val0 >= GRU_CHIPLETS_PER_HUB) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
} else {
|
||||||
|
gts->ts_user_blade_id = req.val1;
|
||||||
|
gts->ts_user_chiplet_id = req.val0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
case sco_gseg_owner:
|
case sco_gseg_owner:
|
||||||
/* Register the current task as the GSEG owner */
|
/* Register the current task as the GSEG owner */
|
||||||
gts->ts_tgid_owner = current->tgid;
|
gts->ts_tgid_owner = current->tgid;
|
||||||
|
|
|
@ -98,11 +98,12 @@ struct gru_unload_context_req {
|
||||||
/*
|
/*
|
||||||
* Structure used to set context options
|
* Structure used to set context options
|
||||||
*/
|
*/
|
||||||
enum {sco_gseg_owner, sco_cch_req_slice};
|
enum {sco_gseg_owner, sco_cch_req_slice, sco_blade_chiplet};
|
||||||
struct gru_set_context_option_req {
|
struct gru_set_context_option_req {
|
||||||
unsigned long gseg;
|
unsigned long gseg;
|
||||||
int op;
|
int op;
|
||||||
unsigned long val1;
|
int val0;
|
||||||
|
long val1;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -328,6 +328,8 @@ struct gru_thread_state *gru_alloc_gts(struct vm_area_struct *vma,
|
||||||
gts->ts_cbr_au_count = cbr_au_count;
|
gts->ts_cbr_au_count = cbr_au_count;
|
||||||
gts->ts_dsr_au_count = dsr_au_count;
|
gts->ts_dsr_au_count = dsr_au_count;
|
||||||
gts->ts_user_options = options;
|
gts->ts_user_options = options;
|
||||||
|
gts->ts_user_blade_id = -1;
|
||||||
|
gts->ts_user_chiplet_id = -1;
|
||||||
gts->ts_tsid = tsid;
|
gts->ts_tsid = tsid;
|
||||||
gts->ts_ctxnum = NULLCTX;
|
gts->ts_ctxnum = NULLCTX;
|
||||||
gts->ts_tlb_int_select = -1;
|
gts->ts_tlb_int_select = -1;
|
||||||
|
|
|
@ -369,6 +369,8 @@ struct gru_thread_state {
|
||||||
long ts_user_options;/* misc user option flags */
|
long ts_user_options;/* misc user option flags */
|
||||||
pid_t ts_tgid_owner; /* task that is using the
|
pid_t ts_tgid_owner; /* task that is using the
|
||||||
context - for migration */
|
context - for migration */
|
||||||
|
short ts_user_blade_id;/* user selected blade */
|
||||||
|
char ts_user_chiplet_id;/* user selected chiplet */
|
||||||
unsigned short ts_sizeavail; /* Pagesizes in use */
|
unsigned short ts_sizeavail; /* Pagesizes in use */
|
||||||
int ts_tsid; /* thread that owns the
|
int ts_tsid; /* thread that owns the
|
||||||
structure */
|
structure */
|
||||||
|
|
Загрузка…
Ссылка в новой задаче