diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c
index 3ecbfd0902d88..410b77aea216f 100644
--- a/kernel/sched_fair.c
+++ b/kernel/sched_fair.c
@@ -485,7 +485,9 @@ place_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int initial)
 		vruntime += sched_vslice_add(cfs_rq, se);
 
 	if (!initial) {
-		if (sched_feat(NEW_FAIR_SLEEPERS))
+		struct task_struct *p = container_of(se, struct task_struct, se);
+
+		if (sched_feat(NEW_FAIR_SLEEPERS) && p->policy != SCHED_BATCH)
 			vruntime -= sysctl_sched_latency;
 
 		vruntime = max_t(s64, vruntime, se->vruntime);