Skip to content

Commit 88a0888

Browse files
Dimitri Sivanichgregkh
authored andcommitted
misc: sgi-gru: Don't disable preemption in GRU driver
[ Upstream commit b983b27 ] Disabling preemption in the GRU driver is unnecessary, and clashes with sleeping locks in several code paths. Remove preempt_disable and preempt_enable from the GRU driver. Signed-off-by: Dimitri Sivanich <sivanich@hpe.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
1 parent 34f2d99 commit 88a0888

3 files changed

Lines changed: 0 additions & 8 deletions

File tree

drivers/misc/sgi-gru/grukservices.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -270,7 +270,6 @@ static int gru_get_cpu_resources(int dsr_bytes, void **cb, void **dsr)
270270
int lcpu;
271271

272272
BUG_ON(dsr_bytes > GRU_NUM_KERNEL_DSR_BYTES);
273-
preempt_disable();
274273
bs = gru_lock_kernel_context(-1);
275274
lcpu = uv_blade_processor_id();
276275
*cb = bs->kernel_cb + lcpu * GRU_HANDLE_STRIDE;
@@ -284,7 +283,6 @@ static int gru_get_cpu_resources(int dsr_bytes, void **cb, void **dsr)
284283
static void gru_free_cpu_resources(void *cb, void *dsr)
285284
{
286285
gru_unlock_kernel_context(uv_numa_blade_id());
287-
preempt_enable();
288286
}
289287

290288
/*

drivers/misc/sgi-gru/grumain.c

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -954,10 +954,8 @@ vm_fault_t gru_fault(struct vm_fault *vmf)
954954

955955
again:
956956
mutex_lock(&gts->ts_ctxlock);
957-
preempt_disable();
958957

959958
if (gru_check_context_placement(gts)) {
960-
preempt_enable();
961959
mutex_unlock(&gts->ts_ctxlock);
962960
gru_unload_context(gts, 1);
963961
return VM_FAULT_NOPAGE;
@@ -966,7 +964,6 @@ vm_fault_t gru_fault(struct vm_fault *vmf)
966964
if (!gts->ts_gru) {
967965
STAT(load_user_context);
968966
if (!gru_assign_gru_context(gts)) {
969-
preempt_enable();
970967
mutex_unlock(&gts->ts_ctxlock);
971968
set_current_state(TASK_INTERRUPTIBLE);
972969
schedule_timeout(GRU_ASSIGN_DELAY); /* true hack ZZZ */
@@ -982,7 +979,6 @@ vm_fault_t gru_fault(struct vm_fault *vmf)
982979
vma->vm_page_prot);
983980
}
984981

985-
preempt_enable();
986982
mutex_unlock(&gts->ts_ctxlock);
987983

988984
return VM_FAULT_NOPAGE;

drivers/misc/sgi-gru/grutlbpurge.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -78,7 +78,6 @@ static struct gru_tlb_global_handle *get_lock_tgh_handle(struct gru_state
7878
struct gru_tlb_global_handle *tgh;
7979
int n;
8080

81-
preempt_disable();
8281
if (uv_numa_blade_id() == gru->gs_blade_id)
8382
n = get_on_blade_tgh(gru);
8483
else
@@ -92,7 +91,6 @@ static struct gru_tlb_global_handle *get_lock_tgh_handle(struct gru_state
9291
static void get_unlock_tgh_handle(struct gru_tlb_global_handle *tgh)
9392
{
9493
unlock_tgh_handle(tgh);
95-
preempt_enable();
9694
}
9795

9896
/*

0 commit comments

Comments
 (0)