Linux 4.13 I/O Scheduler Mobile

Tests by Michael Larabel for a future article on Phoronix.

HTML result view exported from: https://openbenchmarking.org/result/1708198-TY-LINUX413I65&sor&grt.

Linux 4.13 I/O Scheduler MobileProcessorMotherboardChipsetMemoryDiskGraphicsAudioNetworkOSKernelDesktopDisplay ServerDisplay DriverOpenGLCompilerFile-SystemScreen ResolutionNoneKyber MQBFQ low_latencyBFQCFQDeadlineIntel Core i7-5600U @ 3.20GHz (4 Cores)LENOVO 20BSCTO1WWIntel Broadwell-U-OPI2 x 4096 MB DDR3-1600MHz128GB SAMSUNG MZNTE128Intel HD 5500 3072MB (950MHz)Intel Broadwell-U AudioIntel Connection + Intel Wireless 7265Ubuntu 17.044.13.0-999-generic (x86_64) 20170814Unity 7.5.0X Server 1.19.3modesetting 1.19.34.5 Mesa 17.0.7GCC 6.3.0 20170406ext41920x1080OpenBenchmarking.orgCompiler Details- --build=x86_64-linux-gnu --disable-browser-plugin --disable-vtable-verify --disable-werror --enable-checking=release --enable-clocale=gnu --enable-default-pie --enable-gnu-unique-object --enable-gtk-cairo --enable-java-awt=gtk --enable-java-home --enable-languages=c,ada,c++,java,go,d,fortran,objc,obj-c++ --enable-libmpx --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-multiarch --enable-multilib --enable-nls --enable-objc-gc=auto --enable-plugin --enable-shared --enable-threads=posix --host=x86_64-linux-gnu --program-prefix=x86_64-linux-gnu- --target=x86_64-linux-gnu --with-abi=m64 --with-arch-32=i686 --with-arch-directory=amd64 --with-default-libstdcxx-abi=new --with-multilib-list=m32,m64,mx32 --with-target-system-zlib --with-tune=generic -v Disk Details- None: NONE / data=ordered,errors=remount-ro,relatime,rw- Kyber MQ: KYBER / data=ordered,errors=remount-ro,relatime,rw- BFQ low_latency: BFQ / data=ordered,errors=remount-ro,relatime,rw- BFQ: BFQ / data=ordered,errors=remount-ro,relatime,rw- CFQ: CFQ / data=ordered,errors=remount-ro,relatime,rw- Deadline: DEADLINE / data=ordered,errors=remount-ro,relatime,rwProcessor Details- Scaling Governor: intel_pstate powersave

Linux 4.13 I/O Scheduler Mobilestartup-time: Seq - Reads and writes - xtermstartup-time: Rand - Only reads - LibreOffice Writerstartup-time: Seq - Only reads - Gnome terminalstartup-time: Rand - Reads and writes - Gnome terminalstartup-time: Seq - Only reads - LibreOffice Writerstartup-time: Rand - Reads and writes - LibreOffice Writerstartup-time: Seq - Reads and writes - Gnome terminalstartup-time: Seq - Reads and writes - LibreOffice Writerblogbench: Readblogbench: Writedbench: 1dbench: 6fio: Rand Read - Libaio - No - Yes - 4KB - Default Test Directoryfio: Rand Write - Libaio - No - Yes - 4KB - Default Test Directoryfio: Seq Read - Libaio - No - Yes - 4KB - Default Test Directoryfio: Seq Write - Libaio - No - Yes - 4KB - Default Test Directoryfs-mark: 1000 Files, 1MB Sizefs-mark: 5000 Files, 1MB Size, 4 Threadsiozone: 4Kb - 8GB - Write Performancepgbench: On-Disk - Normal Load - Read Writepgbench: On-Disk - Heavy Contention - Read Writesqlite: Default Test DirectoryNoneKyber MQBFQ low_latencyBFQCFQDeadline1.380.312.830.544.850.864.948.41502903357058.51118.25358.23125.80206.83135.1241.5073.87125.56653.121351.4589.853.320.312.010.771.165.24581410302753.3799.79362.73107.41347.11117.3034.0761.27110.47562.12977.6696.560.250.350.260.443.302.280.853.88532632288227.0244.75358.9889.92230.13104.9323.6347.20106.07502.57744.68137.054.700.313.80612103316245.7679.25347.0526.92218.5927.7217.8026.8789.60438.74790.57147.2641.220.312.740.164.810.29798053291845.7486.64359.3847.83459.44103.2325.6542.13104.22514.40743.33112.340.343.440.845.381.48648161311944.2783.06364.5070.84458.93103.6022.3735.6792.86481.64649.01113.64OpenBenchmarking.org

Application Start-up Time

Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: xterm

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: xtermBFQ low_latencyNoneKyber MQBFQCFQ918273645SE +/- 0.04, N = 6SE +/- 0.00, N = 3SE +/- 1.96, N = 6SE +/- 1.21, N = 5SE +/- 2.30, N = 60.251.383.324.7041.22

Application Start-up Time

Background I/O Type: Random - Background I/O mix: Only reads - Application to start: LibreOffice Writer

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Random - Background I/O mix: Only reads - Application to start: LibreOffice WriterNoneKyber MQBFQCFQDeadlineBFQ low_latency0.07880.15760.23640.31520.394SE +/- 0.00, N = 6SE +/- 0.00, N = 6SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 6SE +/- 0.00, N = 30.310.310.310.310.340.35

Application Start-up Time

Background I/O Type: Sequential - Background I/O mix: Only reads - Application to start: Gnome terminal

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Sequential - Background I/O mix: Only reads - Application to start: Gnome terminalBFQ low_latencyKyber MQCFQNoneDeadlineBFQ0.8551.712.5653.424.275SE +/- 0.02, N = 6SE +/- 0.02, N = 3SE +/- 0.01, N = 3SE +/- 0.00, N = 3SE +/- 1.63, N = 50.262.012.742.833.443.80

Application Start-up Time

Background I/O Type: Random - Background I/O mix: Reads and writes - Application to start: Gnome terminal

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Random - Background I/O mix: Reads and writes - Application to start: Gnome terminalCFQBFQ low_latencyNoneKyber MQDeadline0.1890.3780.5670.7560.945SE +/- 0.00, N = 6SE +/- 0.10, N = 6SE +/- 0.01, N = 3SE +/- 0.03, N = 6SE +/- 0.05, N = 60.160.440.540.770.84

Application Start-up Time

Background I/O Type: Sequential - Background I/O mix: Only reads - Application to start: LibreOffice Writer

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Sequential - Background I/O mix: Only reads - Application to start: LibreOffice WriterBFQ low_latencyCFQNoneDeadline1.21052.4213.63154.8426.0525SE +/- 0.24, N = 6SE +/- 0.04, N = 3SE +/- 0.03, N = 3SE +/- 0.01, N = 33.304.814.855.38

Application Start-up Time

Background I/O Type: Random - Background I/O mix: Reads and writes - Application to start: LibreOffice Writer

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Random - Background I/O mix: Reads and writes - Application to start: LibreOffice WriterCFQNoneKyber MQDeadlineBFQ low_latency0.5131.0261.5392.0522.565SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.04, N = 6SE +/- 0.11, N = 6SE +/- 0.68, N = 60.290.861.161.482.28

Application Start-up Time

Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: Gnome terminal

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: Gnome terminalBFQ low_latencyNoneKyber MQ1.1792.3583.5374.7165.895SE +/- 0.08, N = 6SE +/- 0.03, N = 30.854.945.24

Application Start-up Time

Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: LibreOffice Writer

OpenBenchmarking.orgsec, Fewer Is BetterApplication Start-up Time 0.1.0Background I/O Type: Sequential - Background I/O mix: Reads and writes - Application to start: LibreOffice WriterBFQ low_latencyNone246810SE +/- 0.53, N = 6SE +/- 0.09, N = 33.888.41

BlogBench

Test: Read

OpenBenchmarking.orgFinal Score, More Is BetterBlogBench 1.0Test: ReadCFQDeadlineBFQKyber MQBFQ low_latencyNone200K400K600K800K1000KSE +/- 33226.93, N = 6SE +/- 21980.44, N = 6SE +/- 16219.64, N = 6SE +/- 8262.34, N = 3SE +/- 16411.27, N = 6SE +/- 2993.42, N = 37980536481616121035814105326325029031. (CC) gcc options: -O2 -pthread

BlogBench

Test: Write

OpenBenchmarking.orgFinal Score, More Is BetterBlogBench 1.0Test: WriteNoneBFQDeadlineKyber MQCFQBFQ low_latency8001600240032004000SE +/- 26.67, N = 3SE +/- 53.19, N = 3SE +/- 123.20, N = 3SE +/- 36.13, N = 3SE +/- 73.37, N = 3SE +/- 125.32, N = 33570316231193027291828821. (CC) gcc options: -O2 -pthread

Dbench

Client Count: 1

OpenBenchmarking.orgMB/s, More Is BetterDbench 4.0Client Count: 1NoneKyber MQBFQCFQDeadlineBFQ low_latency1326395265SE +/- 0.04, N = 3SE +/- 0.44, N = 3SE +/- 0.38, N = 3SE +/- 0.43, N = 3SE +/- 0.23, N = 3SE +/- 0.46, N = 358.5153.3745.7645.7444.2727.021. (CC) gcc options: -lpopt -O2

Dbench

Client Count: 6

OpenBenchmarking.orgMB/s, More Is BetterDbench 4.0Client Count: 6NoneKyber MQCFQDeadlineBFQBFQ low_latency306090120150SE +/- 0.05, N = 3SE +/- 0.38, N = 3SE +/- 0.87, N = 3SE +/- 1.46, N = 3SE +/- 0.22, N = 3SE +/- 0.26, N = 3118.2599.7986.6483.0679.2544.751. (CC) gcc options: -lpopt -O2

Flexible IO Tester

Type: Random Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 2.1.13Type: Random Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryDeadlineKyber MQCFQBFQ low_latencyNoneBFQ80160240320400SE +/- 0.05, N = 3SE +/- 0.84, N = 3SE +/- 1.95, N = 3SE +/- 1.00, N = 3SE +/- 0.04, N = 3SE +/- 0.42, N = 3364.50362.73359.38358.98358.23347.051. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Random Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 2.1.13Type: Random Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryDeadlineKyber MQCFQBFQ low_latencyNoneBFQ20K40K60K80K100KSE +/- 11.89, N = 3SE +/- 211.01, N = 3SE +/- 487.32, N = 3SE +/- 251.00, N = 3SE +/- 9.13, N = 3SE +/- 104.86, N = 39112190678898428974289553867601. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Random Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 2.1.13Type: Random Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryNoneKyber MQBFQ low_latencyDeadlineCFQBFQ306090120150SE +/- 0.01, N = 3SE +/- 14.42, N = 6SE +/- 16.21, N = 6SE +/- 14.88, N = 6SE +/- 10.58, N = 6SE +/- 1.99, N = 6125.80107.4189.9270.8447.8326.921. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Random Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 2.1.13Type: Random Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryNoneKyber MQBFQ low_latencyDeadlineCFQBFQ7K14K21K28K35KSE +/- 3.51, N = 3SE +/- 3604.38, N = 6SE +/- 4052.87, N = 6SE +/- 3720.68, N = 6SE +/- 2644.91, N = 6SE +/- 497.58, N = 6314462684922477177061195367271. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Sequential Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 2.1.13Type: Sequential Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryCFQDeadlineKyber MQBFQ low_latencyBFQNone100200300400500SE +/- 0.44, N = 3SE +/- 0.13, N = 3SE +/- 3.67, N = 3SE +/- 4.46, N = 3SE +/- 3.19, N = 4SE +/- 0.46, N = 3459.44458.93347.11230.13218.59206.831. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Sequential Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 2.1.13Type: Sequential Read - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryCFQDeadlineKyber MQBFQ low_latencyBFQNone20K40K60K80K100KSE +/- 109.53, N = 3SE +/- 33.60, N = 3SE +/- 917.10, N = 3SE +/- 1114.46, N = 3SE +/- 797.79, N = 4SE +/- 113.77, N = 3114857114729867735752954644517031. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Sequential Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgMB/s, More Is BetterFlexible IO Tester 2.1.13Type: Sequential Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryNoneKyber MQBFQ low_latencyDeadlineCFQBFQ306090120150SE +/- 0.08, N = 3SE +/- 12.15, N = 6SE +/- 14.79, N = 6SE +/- 15.12, N = 6SE +/- 14.50, N = 6SE +/- 1.89, N = 6135.12117.30104.93103.60103.2327.721. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

Flexible IO Tester

Type: Sequential Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test Directory

OpenBenchmarking.orgIOPS, More Is BetterFlexible IO Tester 2.1.13Type: Sequential Write - IO Engine: Libaio - Buffered: No - Direct: Yes - Block Size: 4KB - Disk Target: Default Test DirectoryNoneKyber MQBFQ low_latencyDeadlineCFQBFQ7K14K21K28K35KSE +/- 19.22, N = 3SE +/- 3036.98, N = 6SE +/- 3698.82, N = 6SE +/- 3780.94, N = 6SE +/- 3624.05, N = 6SE +/- 472.97, N = 6337772932226228258972580369261. (CC) gcc options: -rdynamic -std=gnu99 -O3 -ffast-math -include -lrt -laio -lm -lpthread -ldl

FS-Mark

Test: 1000 Files, 1MB Size

OpenBenchmarking.orgFiles/s, More Is BetterFS-Mark 3.3Test: 1000 Files, 1MB SizeNoneKyber MQCFQBFQ low_latencyDeadlineBFQ918273645SE +/- 0.15, N = 3SE +/- 1.63, N = 6SE +/- 0.75, N = 6SE +/- 2.16, N = 6SE +/- 0.38, N = 6SE +/- 0.29, N = 341.5034.0725.6523.6322.3717.801. (CC) gcc options: -static

FS-Mark

Test: 5000 Files, 1MB Size, 4 Threads

OpenBenchmarking.orgFiles/s, More Is BetterFS-Mark 3.3Test: 5000 Files, 1MB Size, 4 ThreadsNoneKyber MQBFQ low_latencyCFQDeadlineBFQ1632486480SE +/- 1.09, N = 3SE +/- 4.24, N = 6SE +/- 7.20, N = 6SE +/- 5.65, N = 6SE +/- 5.13, N = 6SE +/- 5.39, N = 673.8761.2747.2042.1335.6726.871. (CC) gcc options: -static

IOzone

Record Size: 4Kb - File Size: 8GB - Disk Test: Write Performance

OpenBenchmarking.orgMB/s, More Is BetterIOzone 3.465Record Size: 4Kb - File Size: 8GB - Disk Test: Write PerformanceNoneKyber MQBFQ low_latencyCFQDeadlineBFQ306090120150SE +/- 2.93, N = 6SE +/- 3.80, N = 6SE +/- 1.28, N = 3SE +/- 5.23, N = 6SE +/- 6.52, N = 6SE +/- 1.78, N = 6125.56110.47106.07104.2292.8689.601. (CC) gcc options: -O3

PostgreSQL pgbench

Scaling: On-Disk - Test: Normal Load - Mode: Read Write

OpenBenchmarking.orgTPS, More Is BetterPostgreSQL pgbench 9.6.3Scaling: On-Disk - Test: Normal Load - Mode: Read WriteNoneKyber MQCFQBFQ low_latencyDeadlineBFQ140280420560700SE +/- 15.85, N = 6SE +/- 22.48, N = 6SE +/- 13.09, N = 6SE +/- 28.10, N = 6SE +/- 30.07, N = 6SE +/- 10.63, N = 6653.12562.12514.40502.57481.64438.741. (CC) gcc options: -fno-strict-aliasing -fwrapv -O2 -fpic -lpgcommon -lpgport -lrt -lcrypt -ldl -lm

PostgreSQL pgbench

Scaling: On-Disk - Test: Heavy Contention - Mode: Read Write

OpenBenchmarking.orgTPS, More Is BetterPostgreSQL pgbench 9.6.3Scaling: On-Disk - Test: Heavy Contention - Mode: Read WriteNoneKyber MQBFQBFQ low_latencyCFQDeadline30060090012001500SE +/- 8.96, N = 3SE +/- 45.49, N = 6SE +/- 43.96, N = 6SE +/- 38.33, N = 6SE +/- 9.04, N = 3SE +/- 10.20, N = 61351.45977.66790.57744.68743.33649.011. (CC) gcc options: -fno-strict-aliasing -fwrapv -O2 -fpic -lpgcommon -lpgport -lrt -lcrypt -ldl -lm

SQLite

Test Target: Default Test Directory

OpenBenchmarking.orgSeconds, Fewer Is BetterSQLite 3.8.10.2Test Target: Default Test DirectoryNoneKyber MQCFQDeadlineBFQ low_latencyBFQ306090120150SE +/- 0.13, N = 3SE +/- 0.60, N = 3SE +/- 4.87, N = 6SE +/- 3.91, N = 6SE +/- 3.38, N = 6SE +/- 4.84, N = 689.8596.56112.34113.64137.05147.261. (CC) gcc options: -O2 -ldl -lpthread


Phoronix Test Suite v10.8.4