From: Tim Murray Date: Wed, 20 Jan 2016 00:36:40 +0000 (-0800) Subject: ANDROID: mmc: core: move to a SCHED_FIFO thread X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=52678eeea37b1bc553a87cfd81c5dfc5a4966f8a;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git ANDROID: mmc: core: move to a SCHED_FIFO thread (cherry picked from commit 011e507b413393eab8279dac8b778ad9b6e9971b) Running mmcqd as a prio 120 thread forces it to compete with standard user processes for IO performance, especially when the system is under severe CPU load. Move it to a SCHED_FIFO thread to reduce the impact of load on IO performance. Signed-off-by: Tim Murray Bug: 25392275 Change-Id: I1edfe73baa25e181367c30c1f40fee886e92b60d [AmitP: Include for struct sched_param] Signed-off-by: Amit Pundir --- diff --git a/drivers/mmc/core/queue.c b/drivers/mmc/core/queue.c index 0a4e77a5ba33..8c4721f1b4bc 100644 --- a/drivers/mmc/core/queue.c +++ b/drivers/mmc/core/queue.c @@ -17,6 +17,8 @@ #include #include +#include +#include #include "queue.h" #include "block.h" @@ -43,6 +45,11 @@ static int mmc_queue_thread(void *d) struct mmc_queue *mq = d; struct request_queue *q = mq->queue; struct mmc_context_info *cntx = &mq->card->host->context_info; + struct sched_param scheduler_params = {0}; + + scheduler_params.sched_priority = 1; + + sched_setscheduler(current, SCHED_FIFO, &scheduler_params); current->flags |= PF_MEMALLOC;