android_kernel_oneplus_msm8998/block
Ritesh Harjani 8c7501882b cfq: Give a chance to arm slice idle timer in case of group_idle
In below scenario blkio cgroup does not work as per their assigned
weights :-
1. When the underlying device is nonrotational with a single HW queue
with depth of > 5
2. When the use case is forming two blkio cgroups cg1(weight 1000) &
cg2(wight 100) and two processes(file1 and file2) doing sync IO in
their respective blkio cgroups.

For above usecase result of fio (without this patch):-
file1: (groupid=0, jobs=1): err= 0: pid=685: Thu Jan  1 19:41:49 1970
  write: IOPS=1315, BW=41.1MiB/s (43.1MB/s)(1024MiB/24906msec)
<...>
file2: (groupid=0, jobs=1): err= 0: pid=686: Thu Jan  1 19:41:49 1970
  write: IOPS=1295, BW=40.5MiB/s (42.5MB/s)(1024MiB/25293msec)
<...>
// both the process BW is equal even though they belong to different
cgroups with weight of 1000(cg1) and 100(cg2)

In above case as soon as the request from cg1 is completed and even
though it is provided with higher slice_idle=10, because of CFQ
algorithm when the driver tries to fetch the request, CFQ expires
this group without providing any idle time nor weight priority
and schedules another cfq group (in this case cg2).
And thus both cfq groups(cg1 & cg2) keep alternating to get the
disk time and hence loses the cgroup weight based scheduling.

Below patch gives a chance to cfq algorithm (cfq_arm_slice_timer)
to arm the slice timer in case group_idle is enabled.

With this patch result of fio(for above usecase) :-
file1: (groupid=0, jobs=1): err= 0: pid=690: Thu Jan  1 00:06:08 1970
  write: IOPS=1706, BW=53.3MiB/s (55.9MB/s)(1024MiB/19197msec)
<..>
file2: (groupid=0, jobs=1): err= 0: pid=691: Thu Jan  1 00:06:08 1970
  write: IOPS=1043, BW=32.6MiB/s (34.2MB/s)(1024MiB/31401msec)
<..>
// In this processes BW is as per their respective cgroups weight.

Change-Id: I2eb20e48d6fd8ee48e01f00c514a1ee1476fd19c
Signed-off-by: Ritesh Harjani <riteshh@codeaurora.org>
2020-11-03 21:30:28 +01:00
..
partitions partitions/aix: fix usage of uninitialized lv_info and lvname structures 2018-09-19 22:48:59 +02:00
bfq-cgroup.c block, bfq: update to latest bfq-v8-v4.4 state 2020-11-03 21:30:16 +01:00
bfq-ioc.c block: introduce the BFQ-v7r11 I/O sched for 4.4.0 2020-11-03 21:30:16 +01:00
bfq-iosched.c block, bfq: fix build breakage 2020-11-03 21:30:17 +01:00
bfq-sched.c block, bfq: update to latest bfq-v8-v4.4 state 2020-11-03 21:30:16 +01:00
bfq.h block, bfq: update to latest bfq-v8-v4.4 state 2020-11-03 21:30:16 +01:00
bio-integrity.c bio-integrity: Do not allocate integrity context for bio w/o data 2018-04-13 19:50:17 +02:00
bio.c Merge android-4.4.179 (aab9adb) into msm-4.4 2019-05-02 10:52:27 +05:30
blk-cgroup.c Merge android-4.4.157 (c139ea66) into msm-4.4 2018-09-28 12:12:40 +05:30
blk-core.c Merge android-4.4.189 (74c8219) into msm-4.4 2019-08-12 10:43:48 +05:30
blk-exec.c
blk-flush.c
blk-integrity.c
blk-ioc.c
blk-iopoll.c
blk-lib.c
blk-map.c
blk-merge.c
blk-mq-cpu.c
blk-mq-cpumap.c
blk-mq-sysfs.c
blk-mq-tag.c
blk-mq-tag.h
blk-mq.c Merge android-4.4.128 (89904cc) into msm-4.4 2018-04-20 13:05:36 +05:30
blk-mq.h
blk-settings.c Merge android-4.4.172 (b3e9e81) into msm-4.4 2019-01-29 16:37:33 +05:30
blk-softirq.c
blk-sysfs.c Merge android-4.4.172 (b3e9e81) into msm-4.4 2019-01-29 16:37:33 +05:30
blk-tag.c
blk-throttle.c blk-throttle: make sure expire time isn't too big 2018-03-22 09:23:22 +01:00
blk-timeout.c
blk.h
bounce.c
bsg-lib.c
bsg.c
cfq-iosched.c cfq: Give a chance to arm slice idle timer in case of group_idle 2020-11-03 21:30:28 +01:00
cmdline-parser.c
compat_ioctl.c take floppy compat ioctls to sodding floppy.c 2019-08-04 09:34:51 +02:00
deadline-iosched.c
elevator.c
genhd.c
ioctl.c
ioprio.c
Kconfig
Kconfig.iosched block: cgroups, kconfig, build bits for BFQ-v7r11-4.4.0 2020-11-03 21:30:24 +01:00
Makefile block: cgroups, kconfig, build bits for BFQ-v7r11-4.4.0 2020-11-03 21:30:24 +01:00
noop-iosched.c
partition-generic.c This is the 4.4.128 stable release 2018-04-14 15:35:32 +02:00
scsi_ioctl.c
t10-pi.c
test-iosched.c