On Tue, Jun 05, 2012 at 02:48:53PM -0400, Vivek Goyal wrote: [..] > So sync_file_range() test keeps less in flight requests on on average > hence better latencies. It might not produce throughput drop on SATA > disks but might have some effect on storage array luns. Will give it > a try. Well, I ran dd and syn_file_range test on a storage array Lun. Wrote a file of size 4G on ext4. Got about 300MB/s write speed. In fact when I measured time using "time", sync_file_range test finished little faster. Then I started looking at blktrace output. sync_file_range() test initially (for about 8 seconds), drives shallow queue depth (about 16), but after 8 seconds somehow flusher gets involved and starts submitting lots of requests and we start driving much higher queue depth (upto more than 100). Not sure why flusher should get involved. Is everything working as expected. I thought that as we wait for last 8MB IO to finish before we start new one, we should have at max 16MB of IO in flight. Fengguang? Anyway, so this test of speed comparision is invalid as flusher gets involved after some time and we start driving higher in flight requests. I guess I should hard code the maximum number of requests in flight to see the effect of request queue depth on throughput. I am also attaching the sync_file_range() test linus mentioned. Did I write it right. Thanks Vivek #include <unistd.h> #include <stdlib.h> #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <time.h> #include <fcntl.h> #include <string.h> #define BUFSIZE (8*1024*1024) char buf [BUFSIZE]; int main() { int fd, index = 0; fd = open("sync-file-range-tester.tst-file", O_WRONLY|O_CREAT); if (fd < 0) { perror("open"); exit(1); } memset(buf, 'a', BUFSIZE); while (1) { if (write(fd, buf, BUFSIZE) != BUFSIZE) break; sync_file_range(fd, index*BUFSIZE, BUFSIZE, SYNC_FILE_RANGE_WRITE); if (index) { sync_file_range(fd, (index-1)*BUFSIZE, BUFSIZE, SYNC_FILE_RANGE_WAIT_BEFORE|SYNC_FILE_RANGE_WRITE|SYNC_FILE_RANGE_WAIT_AFTER); } index++; if (index >=512) break; } } -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/ Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>