Bug 265756 - clang crashes on devel/py-awscrt on amd64 on 14
Summary: clang crashes on devel/py-awscrt on amd64 on 14
Status: Closed Overcome By Events
Alias: None
Product: Base System
Classification: Unclassified
Component: misc (show other bugs)
Version: CURRENT
Hardware: Any Any
: --- Affects Only Me
Assignee: freebsd-toolchain (Nobody)
URL: http://beefy18.nyi.freebsd.org/data/m...
Keywords:
Depends on:
Blocks: 265723
  Show dependency treegraph
 
Reported: 2022-08-10 15:59 UTC by Yuri Victorovich
Modified: 2023-08-31 18:53 UTC (History)
4 users (show)

See Also:


Attachments
Test case generated by LLVM (46.43 KB, application/x-gzip)
2022-08-16 19:35 UTC, John F. Carr
no flags Details
LLVM bitcode file to reproduce crash (43.34 KB, text/plain)
2022-08-16 19:49 UTC, John F. Carr
no flags Details
Much smaller test case for backend (3.90 KB, text/plain)
2022-08-16 20:27 UTC, John F. Carr
no flags Details

Note You need to log in before you can comment on or make changes to this bug.
Description Yuri Victorovich freebsd_committer freebsd_triage 2022-08-10 15:59:54 UTC

    
Comment 1 John F. Carr 2022-08-16 19:35:21 UTC
Created attachment 235946 [details]
Test case generated by LLVM
Comment 2 John F. Carr 2022-08-16 19:49:04 UTC
Created attachment 235947 [details]
LLVM bitcode file to reproduce crash

It turns out to be a back end bug, possibly triggered by a second front end bug generating bad code for an inline assembly statement.  I added the bitcode file (cc -emit-llvm) that crashes llc from LLVM 14 or 15.
Comment 3 John F. Carr 2022-08-16 20:27:37 UTC
Created attachment 235950 [details]
Much smaller test case for backend
Comment 4 John F. Carr 2022-08-16 20:41:05 UTC
https://github.com/llvm/llvm-project/issues/57183
Comment 5 John F. Carr 2022-09-21 20:34:24 UTC
The source code has invalid inline assembly constraints.  As far as LLVM is concerned, the fix is to report an error instead of crashing.  There are many things you can do with inline assembly that crash the compiler and these bugs seem to be a low priority.

We can
1. Find a volunteer to fix clang to report an error.
2. Close this bug as uninteresting.
3. Hold this bug open and test each new LLVM release until it is fixed.
4. Move this bug to the specific port involved and send a bug report upstream.

Same for bug 265757 which is the same code in a different package.
Comment 6 Bob Bishop 2022-09-21 21:21:58 UTC
(In reply to John F. Carr from comment #5)
I don't have a dog in this fight, but I'd vote for option 4 because:
- The source code is buggy, port maintainer coould fix it; and
- It's on the radar upstream and it's their decision what priority they give it.
Comment 7 Yuri Victorovich freebsd_committer freebsd_triage 2022-09-21 22:16:55 UTC
Upstream bug report: https://github.com/llvm/llvm-project/issues/57888
Comment 8 Yuri Victorovich freebsd_committer freebsd_triage 2022-09-21 22:18:41 UTC
(In reply to Bob Bishop from comment #6)

I think it should stay assigned to toolchain@ because once clang's upstream would fix it they should probably backport the fix.
Comment 9 Yuri Victorovich freebsd_committer freebsd_triage 2022-09-21 22:21:33 UTC
Upstream project's bug report: https://github.com/awslabs/aws-crt-python/issues/395
Comment 10 John F. Carr 2023-07-11 12:50:02 UTC
This is essentially a duplicate of 265756 related to port devel/aws-checksums.  Same code, different package.  A comment there says the code has been fixed upstream.
Comment 11 Mark Linimon freebsd_committer freebsd_triage 2023-08-31 18:23:58 UTC
(In reply to John F. Carr from comment #10)

I'm confused.  This *is* Ceti Alph^W^W 265756.

And I don't see which PR was about aws-checksums?

mcl
Comment 12 Dimitry Andric freebsd_committer freebsd_triage 2023-08-31 18:49:02 UTC
(In reply to Mark Linimon from comment #11)
I think the confusion is that the same Amazon code that calculates checksums, and that was causing a clang assertion, has been copy/pasted between several pieces of software that try to do something with AWS.

Specifically, in bug 234232 the issue was first reported for devel/aws-checksums, after which I reported it upstream at https://bugs.llvm.org/show_bug.cgi?id=40985 (which is now https://github.com/llvm/llvm-project/issues/40330), which is _still_ open as of today, 2023-08-31.

Meanwhile somebody else also reported it directly to the aws-checksums developers in https://github.com/awslabs/aws-checksums/issues/49, and eventually it was fixed there in https://github.com/awslabs/aws-checksums/commit/ad53be196a25bbefa3700a01187fdce573a7d2d0, by adjusting the inline assembly to have less-impossible constraints.

However, at the time *this* bug was created, the devel/py-awscrt port still had an old copy of the awscrt files, including the crash-prone crc32c_sse42_asm.c file with inline assembly. And in the mean time, the py-awscrt people seem to have updated their vendor copy of awscrt to a newer version, which no longer provokes any assertion or "impossible constraint" errors.

Therefore, I think this bug can be closed now?