Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(14)

Issue 502973005: [fsp] Buffer consecutive Write() calls. (Closed)

Created:
6 years, 3 months ago by mtomasz
Modified:
6 years, 2 months ago
Reviewers:
hashimoto, tzik
CC:
chromium-reviews, nkostylev+watch_chromium.org, nhiroki, oshima+watch_chromium.org, stevenjb+watch_chromium.org, kinuko+fileapi, davemoore+watch_chromium.org
Base URL:
https://chromium.googlesource.com/chromium/src.git@master
Project:
chromium
Visibility:
Public.

Description

[fsp] Buffer consecutive Write() calls. Similarly to BufferingFileStreamReader, this CL introduces a analogical BufferingFileStreamWriter class which groups consecutive Write() calls in order to limit number of IPC calls. TEST=browser_tests: *FileSystemProvider*BufferingFileStreamWriter* BUG=398338 Committed: https://crrev.com/b75566966d7efcbb5f544f4488bae12ec7aed7c1 Cr-Commit-Position: refs/heads/master@{#300043}

Patch Set 1 #

Total comments: 2

Patch Set 2 : Fixed. #

Total comments: 27

Patch Set 3 : Fixed. #

Patch Set 4 : Rebased. #

Patch Set 5 : Fixed. #

Patch Set 6 : Fixed compile issues. #

Patch Set 7 : Addressed comments. #

Patch Set 8 : Revert to the previous solution. #

Patch Set 9 : Added a comment. #

Total comments: 8

Patch Set 10 : Addressed comments. #

Unified diffs Side-by-side diffs Delta from patch set Stats (+713 lines, -5 lines) Patch
M chrome/browser/chromeos/file_system_provider/fileapi/backend_delegate.cc View 1 2 3 3 chunks +8 lines, -2 lines 0 comments Download
A chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h View 1 2 3 4 5 6 7 8 9 1 chunk +98 lines, -0 lines 0 comments Download
A chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc View 1 2 3 4 5 6 7 1 chunk +184 lines, -0 lines 0 comments Download
A chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer_unittest.cc View 1 2 3 4 5 6 7 8 9 1 chunk +411 lines, -0 lines 0 comments Download
M chrome/browser/chromeos/file_system_provider/fileapi/file_stream_writer.cc View 1 2 2 chunks +5 lines, -3 lines 0 comments Download
M chrome/chrome_browser_chromeos.gypi View 1 2 3 4 5 6 7 8 9 1 chunk +2 lines, -0 lines 0 comments Download
M chrome/chrome_tests_unit.gypi View 1 2 3 4 5 6 7 8 9 1 chunk +1 line, -0 lines 0 comments Download
M storage/browser/fileapi/file_stream_writer.h View 1 2 3 4 5 6 7 8 9 1 chunk +4 lines, -0 lines 0 comments Download

Messages

Total messages: 36 (2 generated)
mtomasz
mtomasz@chromium.org changed reviewers: + hashimoto@chromium.org
6 years, 3 months ago (2014-08-26 09:54:06 UTC) #1
mtomasz
@hashimoto: PTAL. Thanks.
6 years, 3 months ago (2014-08-26 09:54:14 UTC) #2
hashimoto
q1: How much performance improvement can be expected from this mechanism? This is not needed ...
6 years, 3 months ago (2014-08-28 08:32:17 UTC) #3
mtomasz
https://codereview.chromium.org/502973005/diff/1/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc (right): https://codereview.chromium.org/502973005/diff/1/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc#newcode174 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc:174: DCHECK_EQ(net::ERR_IO_PENDING, flush_result); On 2014/08/28 08:32:17, hashimoto wrote: > It ...
6 years, 3 months ago (2014-08-29 02:49:00 UTC) #4
mtomasz
> q1: How much performance improvement can be expected from this mechanism? 25x faster for ...
6 years, 3 months ago (2014-08-29 02:49:37 UTC) #5
mtomasz
On 2014/08/29 02:49:37, mtomasz wrote: > > q1: How much performance improvement can be expected ...
6 years, 3 months ago (2014-09-01 09:45:41 UTC) #6
hashimoto
On 2014/08/29 02:49:37, mtomasz wrote: > > q1: How much performance improvement can be expected ...
6 years, 3 months ago (2014-09-01 10:52:27 UTC) #7
mtomasz
On 2014/09/01 10:52:27, hashimoto wrote: > On 2014/08/29 02:49:37, mtomasz wrote: > > > q1: ...
6 years, 3 months ago (2014-09-02 00:30:18 UTC) #8
hashimoto
On 2014/09/02 00:30:18, mtomasz wrote: > On 2014/09/01 10:52:27, hashimoto wrote: > > On 2014/08/29 ...
6 years, 3 months ago (2014-09-03 11:38:30 UTC) #9
mtomasz
> > ShouldFlushOnWriteCompletion() disables flushing on completion for sandboxed > > backends only. By default ...
6 years, 3 months ago (2014-09-03 14:06:30 UTC) #10
hashimoto
On 2014/09/03 14:06:30, mtomasz wrote: > > > ShouldFlushOnWriteCompletion() disables flushing on completion for sandboxed ...
6 years, 3 months ago (2014-09-04 11:34:36 UTC) #11
mtomasz
On 2014/09/04 11:34:36, hashimoto wrote: > On 2014/09/03 14:06:30, mtomasz wrote: > > > > ...
6 years, 3 months ago (2014-09-04 12:12:42 UTC) #12
hashimoto
On 2014/09/04 12:12:42, mtomasz wrote: > On 2014/09/04 11:34:36, hashimoto wrote: > > On 2014/09/03 ...
6 years, 3 months ago (2014-09-09 05:22:30 UTC) #13
mtomasz
(cut) > Why anyone wants to implement buffering/flush logic in two places (FSW::Flush > and ...
6 years, 3 months ago (2014-09-09 05:48:59 UTC) #14
hashimoto
Regarding the flush in the dtor, I thought it would work but now I think ...
6 years, 3 months ago (2014-09-10 07:56:15 UTC) #15
mtomasz
On 2014/09/10 07:56:15, hashimoto wrote: (cut) > Regarding the flush in the dtor, > I ...
6 years, 3 months ago (2014-09-10 10:14:53 UTC) #16
hashimoto
Where did you put the CHECK to detect data loss? https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc (right): https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc#newcode76 ...
6 years, 3 months ago (2014-09-11 07:52:17 UTC) #17
mtomasz
PTAL. Thanks. https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc (right): https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc#newcode76 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc:76: return file_stream_writer_->Cancel(callback); On 2014/09/11 07:52:16, hashimoto wrote: ...
6 years, 3 months ago (2014-09-17 04:59:41 UTC) #18
mtomasz
On 2014/09/17 04:59:41, mtomasz wrote: > PTAL. Thanks. > > https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc > File > chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc ...
6 years, 3 months ago (2014-09-22 01:43:57 UTC) #19
hashimoto
https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc (right): https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc#newcode93 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc:93: DCHECK_GE(intermediate_buffer_length_, offset + length + buffered_bytes_); On 2014/09/17 04:59:40, ...
6 years, 3 months ago (2014-09-22 12:10:31 UTC) #20
mtomasz
https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc (right): https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc#newcode93 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.cc:93: DCHECK_GE(intermediate_buffer_length_, offset + length + buffered_bytes_); On 2014/09/22 12:10:31, ...
6 years, 3 months ago (2014-09-24 01:45:31 UTC) #21
hashimoto
https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h (right): https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h#newcode31 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h:31: // Flush() must be called on completion to ensure ...
6 years, 2 months ago (2014-09-26 07:05:55 UTC) #22
mtomasz
On 2014/09/26 07:05:55, hashimoto wrote: > https://codereview.chromium.org/502973005/diff/20001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h > File > chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h > (right): > > ...
6 years, 2 months ago (2014-09-26 08:19:42 UTC) #23
mtomasz
@hashimoto: I reverted to the previous solution. PTAL. @tzik: PTAL at storage/browser/fileapi/file_stream_writer.h. Thanks.
6 years, 2 months ago (2014-10-07 03:12:14 UTC) #25
tzik
On 2014/10/07 03:12:14, mtomasz wrote: > @hashimoto: I reverted to the previous solution. PTAL. > ...
6 years, 2 months ago (2014-10-07 05:11:42 UTC) #26
mtomasz
On 2014/10/07 05:11:42, tzik wrote: > On 2014/10/07 03:12:14, mtomasz wrote: > > @hashimoto: I ...
6 years, 2 months ago (2014-10-07 05:29:28 UTC) #27
tzik
lgtm
6 years, 2 months ago (2014-10-07 07:55:40 UTC) #28
mtomasz
On 2014/10/07 07:55:40, tzik wrote: > lgtm @hashimoto: Ping.
6 years, 2 months ago (2014-10-10 06:18:41 UTC) #29
mtomasz
On 2014/10/10 06:18:41, mtomasz wrote: > On 2014/10/07 07:55:40, tzik wrote: > > lgtm > ...
6 years, 2 months ago (2014-10-15 00:18:05 UTC) #30
hashimoto
lgtm please align to the latest coding style. https://codereview.chromium.org/502973005/diff/160001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h (right): https://codereview.chromium.org/502973005/diff/160001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h#newcode42 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h:42: virtual ...
6 years, 2 months ago (2014-10-16 21:39:04 UTC) #31
mtomasz
https://codereview.chromium.org/502973005/diff/160001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h File chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h (right): https://codereview.chromium.org/502973005/diff/160001/chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h#newcode42 chrome/browser/chromeos/file_system_provider/fileapi/buffering_file_stream_writer.h:42: virtual int Flush(const net::CompletionCallback& callback) OVERRIDE; On 2014/10/16 21:39:03, ...
6 years, 2 months ago (2014-10-17 00:26:07 UTC) #32
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/502973005/190001
6 years, 2 months ago (2014-10-17 00:27:11 UTC) #34
commit-bot: I haz the power
Committed patchset #10 (id:190001)
6 years, 2 months ago (2014-10-17 02:06:52 UTC) #35
commit-bot: I haz the power
6 years, 2 months ago (2014-10-17 02:07:47 UTC) #36
Message was sent while issue was closed.
Patchset 10 (id:??) landed as
https://crrev.com/b75566966d7efcbb5f544f4488bae12ec7aed7c1
Cr-Commit-Position: refs/heads/master@{#300043}

Powered by Google App Engine
This is Rietveld 408576698