Re: git: 3d8ef251aa9d - main - lib/libc/amd64/string/strchrnul.S: fix edge case in scalar code
- Reply: Robert Clausecker : "Re: git: 3d8ef251aa9d - main - lib/libc/amd64/string/strchrnul.S: fix edge case in scalar code"
- In reply to: Robert Clausecker : "git: 3d8ef251aa9d - main - lib/libc/amd64/string/strchrnul.S: fix edge case in scalar code"
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Fri, 25 Aug 2023 19:37:28 UTC
On 25 Aug 2023, at 20:23, Robert Clausecker <fuz@FreeBSD.org> wrote: > > The branch main has been updated by fuz: > > URL: https://cgit.FreeBSD.org/src/commit/?id=3d8ef251aa9dceabd57f7821a0e6749d35317db3 > > commit 3d8ef251aa9dceabd57f7821a0e6749d35317db3 > Author: Robert Clausecker <fuz@FreeBSD.org> > AuthorDate: 2023-08-25 16:22:22 +0000 > Commit: Robert Clausecker <fuz@FreeBSD.org> > CommitDate: 2023-08-25 19:21:54 +0000 > > lib/libc/amd64/string/strchrnul.S: fix edge case in scalar code > > When the buffer is immediately preceeded by the character we > are looking for and begins with one higher than that character, > and the buffer is misaligned, a match was errorneously detected > in the first character. Fix this by changing the way we prevent > matches before the buffer from being detected: instead of > removing the corresponding bit from the 0x80..80 mask, set the > LSB of bytes before the buffer after xoring with the character we > look for. > > The bug only affects amd64 with ARCHLEVEL=scalar (cf. simd(7)). > The change comes at a 2% performance impact for short strings > if ARCHLEVEL is set to scalar. The default configuration is not > affected. That such bugs are being found in even the *scalar* code is concerning. How confident are we that all the various implementations have in fact been adequately tested if this slipped through? We have the 14 release coming up, and this makes me nervous about whether all this code is really ready for prime time yet. This seems like the kind of thing that needs a long time to bake in -CURRENT so that it can be used in anger and, hopefully, have all the edge cases hit. What have they been tested against, anyway? Can we borrow test suites from other projects? Jess