diff options
author | Jens Axboe <axboe@suse.de> | 2006-06-13 02:26:10 -0400 |
---|---|---|
committer | Jens Axboe <axboe@nelson.home.kernel.dk> | 2006-06-23 11:10:39 -0400 |
commit | b31dc66a54ad986b6b73bdc49c8efc17cbad1833 (patch) | |
tree | 5591383c1cbffe11512da889c971f899333f1a44 /block/cfq-iosched.c | |
parent | 271f18f102c789f59644bb6c53a69da1df72b2f4 (diff) |
[PATCH] Kill PF_SYNCWRITE flag
A process flag to indicate whether we are doing sync io is incredibly
ugly. It also causes performance problems when one does a lot of async
io and then proceeds to sync it. Part of the io will go out as async,
and the other part as sync. This causes a disconnect between the
previously submitted io and the synced io. For io schedulers such as CFQ,
this will cause us lost merges and suboptimal behaviour in scheduling.
Remove PF_SYNCWRITE completely from the fsync/msync paths, and let
the O_DIRECT path just directly indicate that the writes are sync
by using WRITE_SYNC instead.
Signed-off-by: Jens Axboe <axboe@suse.de>
Diffstat (limited to 'block/cfq-iosched.c')
-rw-r--r-- | block/cfq-iosched.c | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index c88f161d3fb3..4c4e9cc3ae26 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
@@ -277,8 +277,6 @@ static struct cfq_queue *cfq_find_cfq_hash(struct cfq_data *, unsigned int, unsi | |||
277 | static void cfq_dispatch_insert(request_queue_t *, struct cfq_rq *); | 277 | static void cfq_dispatch_insert(request_queue_t *, struct cfq_rq *); |
278 | static struct cfq_queue *cfq_get_queue(struct cfq_data *cfqd, unsigned int key, struct task_struct *tsk, gfp_t gfp_mask); | 278 | static struct cfq_queue *cfq_get_queue(struct cfq_data *cfqd, unsigned int key, struct task_struct *tsk, gfp_t gfp_mask); |
279 | 279 | ||
280 | #define process_sync(tsk) ((tsk)->flags & PF_SYNCWRITE) | ||
281 | |||
282 | /* | 280 | /* |
283 | * lots of deadline iosched dupes, can be abstracted later... | 281 | * lots of deadline iosched dupes, can be abstracted later... |
284 | */ | 282 | */ |
@@ -334,7 +332,7 @@ static int cfq_queue_empty(request_queue_t *q) | |||
334 | 332 | ||
335 | static inline pid_t cfq_queue_pid(struct task_struct *task, int rw) | 333 | static inline pid_t cfq_queue_pid(struct task_struct *task, int rw) |
336 | { | 334 | { |
337 | if (rw == READ || process_sync(task)) | 335 | if (rw == READ || rw == WRITE_SYNC) |
338 | return task->pid; | 336 | return task->pid; |
339 | 337 | ||
340 | return CFQ_KEY_ASYNC; | 338 | return CFQ_KEY_ASYNC; |