Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b1b19fcf authored by Jack Steiner's avatar Jack Steiner Committed by Linus Torvalds
Browse files

gru: add user request to specify gru slice



Add a user request to specify the gru instruction slice parameter for user
contexts.

Signed-off-by: default avatarJack Steiner <steiner@sgi.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 92b39388
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -769,6 +769,10 @@ int gru_set_context_option(unsigned long arg)
 		/* Register the current task as the GSEG owner */
		gts->ts_tgid_owner = current->tgid;
		break;
	case sco_cch_req_slice:
 		/* Set the CCH slice option */
		gts->ts_cch_req_slice = req.val1 & 3;
		break;
	default:
		ret = -EINVAL;
	}
+1 −1
Original line number Diff line number Diff line
@@ -98,7 +98,7 @@ struct gru_unload_context_req {
/*
 * Structure used to set context options
 */
enum {sco_gseg_owner};
enum {sco_gseg_owner, sco_cch_req_slice};
struct gru_set_context_option_req {
	unsigned long	gseg;
	int		op;
+7 −0
Original line number Diff line number Diff line
@@ -321,6 +321,7 @@ struct gru_thread_state *gru_alloc_gts(struct vm_area_struct *vma,
	gts->ts_tsid = tsid;
	gts->ts_ctxnum = NULLCTX;
	gts->ts_tlb_int_select = -1;
	gts->ts_cch_req_slice = -1;
	gts->ts_sizeavail = GRU_SIZEAVAIL(PAGE_SHIFT);
	if (vma) {
		gts->ts_mm = current->mm;
@@ -566,6 +567,12 @@ void gru_load_context(struct gru_thread_state *gts)
		gts->ts_tlb_int_select = gru_cpu_fault_map_id();
		cch->tlb_int_select = gts->ts_tlb_int_select;
	}
	if (gts->ts_cch_req_slice >= 0) {
		cch->req_slice_set_enable = 1;
		cch->req_slice = gts->ts_cch_req_slice;
	} else {
		cch->req_slice_set_enable =0;
	}
	cch->tfm_done_bit_enable = 0;
	cch->dsr_allocation_map = gts->ts_dsr_map;
	cch->cbr_allocation_map = gts->ts_cbr_map;
+1 −0
Original line number Diff line number Diff line
@@ -380,6 +380,7 @@ struct gru_thread_state {
						   required for contest */
	unsigned char		ts_cbr_au_count;/* Number of CBR resources
						   required for contest */
	char			ts_cch_req_slice;/* CCH packet slice */
	char			ts_blade;	/* If >= 0, migrate context if
						   ref from diferent blade */
	char			ts_force_cch_reload;