-
-
Notifications
You must be signed in to change notification settings - Fork 5.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
clean up and export crc32c function #22274
Merged
Merged
Changes from 1 commit
Commits
Show all changes
14 commits
Select commit
Hold shift + click to select a range
643b1e3
clean up and export crc32c function
stevengj 721bbf5
added PR to NEWS
stevengj 184acd1
use read, not mmap, for crc
stevengj c3f5d91
slight optimization (don't open cachefile twice for checksum)
stevengj bd64651
avoid resizing buffer in readbytes
stevengj 62d7dc4
add an assertion
stevengj ceda720
more crc32c tests
stevengj 67ef143
docs typo
stevengj f34d08c
crc32c(IOBuffer) bugfix and test
stevengj 38f6fc0
restore crc32 of String, add crc32c(io) to read all of a stream, add …
stevengj 1126d0f
use crc32c block size of 8192*3, matching the underling C library
stevengj da2fba1
optimized IOBuffer crc32c
stevengj a1b0431
slight simplification/generalization
stevengj 8e058f3
eliminate theoretical race condition in crc32c if file is being writt…
stevengj File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
restore crc32 of String, add crc32c(io) to read all of a stream, add …
…optimized open(crc32c, filename), make IOBuffer checksums consistent with other streams
- Loading branch information
commit 38f6fc04c0fd932b0cfd8f575b0ef02b810e4368
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should this be
8192 * 3
? That's theLONG
block size used in the sse4.2 version (and also on ARM in one of my up coming change)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That makes sense. I tried 16384 and 32768 and the latter wasn't any faster on my machine, but 8192 * 3 is fine too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It'll be catched by the short version so it won't matter too much but in principle 8192 * 2 and 8192 * 4 are equally bad since neither of them makes full use of the LONG loop.