Bug 180688

Summary: Fix possible out-of-bounds read in protocolIsInHTTPFamily
Product: WebKit Reporter: Alex Christensen <achristensen>
Component: New BugsAssignee: Alex Christensen <achristensen>
Status: RESOLVED FIXED    
Severity: Normal CC: darin, dbates, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch dbates: review+

Alex Christensen
Reported 2017-12-11 17:47:04 PST
Fix possible out-of-bounds read in protocolIsInHTTPFamily
Attachments
Patch (3.05 KB, patch)
2017-12-11 17:48 PST, Alex Christensen
no flags
Patch (3.05 KB, patch)
2017-12-11 18:06 PST, Alex Christensen
dbates: review+
Alex Christensen
Comment 1 2017-12-11 17:48:36 PST
Alex Christensen
Comment 2 2017-12-11 18:06:30 PST
Daniel Bates
Comment 3 2017-12-12 14:25:17 PST
Comment on attachment 329070 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=329070&action=review > Source/WebCore/platform/URL.cpp:877 > + return url.length() > 4 We could cache url.length() in a local to avoid dereferencing it twice. Maybe the compiler is smart enough? For your consideration I suggest using >= 5 as it tends to be easier to reason about when verifying bounds. The compiler should be smart enough to optimize this to > 4 if such a micro-optimization is considered a win on a particular ISA. > Source/WebCore/platform/URL.cpp:882 > + && (url[4] == ':' || (isASCIIAlphaCaselessEqual(url[4], 's') && url.length() > 5 && url[5] == ':')); For similar reasons I suggest changing > 5 to >= 6. > Tools/TestWebKitAPI/Tests/WebCore/URL.cpp:218 > + EXPECT_FALSE(protocolIsInHTTPFamily("abc")); I suggest that we also check the empty string, a null string, and a string with a single character.
Alex Christensen
Comment 4 2017-12-12 17:54:44 PST
Radar WebKit Bug Importer
Comment 5 2017-12-12 17:55:20 PST
Darin Adler
Comment 6 2017-12-12 18:26:57 PST
Comment on attachment 329070 [details] Patch This bug is based on false promise. The String subscript operate return zero for characters past the end of the string, This change would be needed if we change the argument type to something like StringView or if we change the behavior of the string class subscript operator. But otherwise it is unnecessary to make a change.
Darin Adler
Comment 7 2017-12-13 21:24:21 PST
(In reply to Darin Adler from comment #6) > false promise false premise(In reply to Darin Adler from comment #6) > subscript operate return zero subscript operator returns zero
Alex Christensen
Comment 8 2017-12-14 18:04:36 PST
Dan and I disagree about what to do here. This was safe before because of our implementation of WTF::String::operator[]. Dan thinks we should revert this change and encourage programmers to rely on String's bounds checks. I think that this was still a good change because it makes the code look safer and it probably doesn't change the optimized code generated. I don't think we should encourage dangerous-looking code in WebKit, and I think WTF::String::operator[] checks should be a fallback to make sure when we make a mistake it doesn't turn into a security issue.
Note You need to log in before you can comment on or make changes to this bug.