Page MenuHomeFreeBSD

libcxx: use __SIZEOF_LONG__ == 8 instead of __LP64__
ClosedPublic

Authored by kib on Jan 24 2023, 10:06 AM.
Tags
None
Referenced Files
F107861995: D38178.diff
Sat, Jan 18, 7:34 PM
F107747130: D38178.diff
Fri, Jan 17, 10:47 PM
Unknown Object (File)
Dec 17 2024, 11:52 PM
Unknown Object (File)
Nov 27 2024, 12:57 AM
Unknown Object (File)
Nov 15 2024, 9:19 AM
Unknown Object (File)
Oct 26 2024, 11:40 AM
Unknown Object (File)
Oct 26 2024, 11:40 AM
Unknown Object (File)
Oct 26 2024, 11:40 AM
Subscribers

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

kib requested review of this revision.Jan 24 2023, 10:06 AM

We should perhaps put a comment about this (__SIZEOF_LONG__ == 8) idiom in arch.7. @arichardson?

This revision is now accepted and ready to land.Jan 24 2023, 3:10 PM

We should perhaps put a comment about this (__SIZEOF_LONG__ == 8) idiom in arch.7. @arichardson?

I think that would be good in general.

I also think that the commit message comment of

Only 64bit architectures can be supported this way, because libcxx
defines __cxx_contention_t to be int64_t for FreeBSD.

or similar, perhaps terser, should be included in this section of code. I puzzled over why 64-bit was special here and while I could find it in the commit logs, it struck me as being important enough to include:

/* libcxx defines __cxx_contention_t as int64_t, so this only works on 64-bit pointers */

maybe?

This revision now requires review to proceed.Jan 24 2023, 3:38 PM
emaste added inline comments.
contrib/llvm-project/libcxx/src/atomic.cpp
84

sp: synonyms

This revision is now accepted and ready to land.Jan 24 2023, 3:51 PM
kib marked an inline comment as done.Jan 24 2023, 5:10 PM

This still isn't quite right if you're MFC'ing it; MIPS is "special" in-tree and uses int32_t, both for 32-bit and 64-bit... see D26774 which broke ABI on both to make it 32-bit and deviated from upstream's ABI

This still isn't quite right if you're MFC'ing it; MIPS is "special" in-tree and uses int32_t, both for 32-bit and 64-bit... see D26774 which broke ABI on both to make it 32-bit and deviated from upstream's ABI

But it will work, just causing more spurious wakeups?

Anyway, I can add !defined(__mips__) to the MFC. Are you fine with that?