Page MenuHomeFreeBSD

include: ssp: fortify <wchar.h>
ClosedPublic

Authored by kevans on Jun 21 2024, 4:59 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Sep 8, 7:12 AM
Unknown Object (File)
Sat, Sep 7, 6:34 PM
Unknown Object (File)
Sat, Sep 7, 4:40 PM
Unknown Object (File)
Fri, Sep 6, 3:39 AM
Unknown Object (File)
Sun, Aug 25, 5:29 PM
Unknown Object (File)
Aug 11 2024, 10:14 PM
Unknown Object (File)
Aug 11 2024, 10:14 PM
Unknown Object (File)
Aug 11 2024, 10:14 PM
Subscribers

Details

Summary

This includes all of the w*() equivalents to str*()/mem*() implemented
in more or less the same way. For these ones, we'll just use
header-only implementations from the start to stop further cluttering
the libc symbol table.

Sponsored by: Stormshield
Sponsored by: Klara, Inc.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 58291
Build 55179: arc lint + arc unit

Event Timeline

include/ssp/wchar.h
50

Do you need __BEGIN_DECLS for these inline functions?

58

Do you need to multiply len by sizeof(wchar_t) here? I think __ssp_overlap takes a bytecount.

include/ssp/wchar.h
58

Oh, I guess that's ok, it uses pointer arithmetic. That's a bit subtle.

kevans added inline comments.
include/ssp/wchar.h
50

Not for the inlines, but __ssp_redirect_raw_impl also adds a couple of declarations with the symbol renaming bits before the function signature

58

Based on these and some other discussion, see D45940 for another take. I'll likely reorder that one to before this and just make these use the __ssp_wchar_overlap() helper from the start if that seems reasonable.

This revision is now accepted and ready to land.Jul 11 2024, 7:06 PM
This revision was automatically updated to reflect the committed changes.
kevans marked an inline comment as done.