Hi all! v2: 01: improve documentation 02: add Hanna's and Eric's r-bs, add tiny grammar fix 03: fix test by filtering instead of reducing number of writes
Parallel small writes to unallocated cluster works bad when subclusters enabled. Look, without subclusters, one of write requests will allocate the whole cluster, and all other writes to this cluster will be independent of each other, they depend only on the first one that does allocation. With subclusters, each write to unallocated subcluster will block the whole cluster for parallel writing. So, assume we write 8 consecutive 4k chunks in parallel: Without subclusters, one of the chunks will block all the cluster and write L2 entry. The remaining 7 chunks are written in parallel. With subclusters, each of the chunks will allocate new subcluster and block the whole cluster. All the chunks are dependent on each other and queue depth becomes 1. That's not good. Let's improve the situation. Vladimir Sementsov-Ogievskiy (3): simplebench: add img_bench_templater.py qcow2: refactor handle_dependencies() loop body qcow2: handle_dependencies(): relax conflict detection block/qcow2-cluster.c | 60 +++++++++----- scripts/simplebench/img_bench_templater.py | 95 ++++++++++++++++++++++ scripts/simplebench/table_templater.py | 62 ++++++++++++++ tests/qemu-iotests/271 | 5 +- tests/qemu-iotests/271.out | 4 +- 5 files changed, 202 insertions(+), 24 deletions(-) create mode 100755 scripts/simplebench/img_bench_templater.py create mode 100644 scripts/simplebench/table_templater.py -- 2.29.2