Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

False warnings from clang's scan-build #330

Open
gperciva opened this issue Dec 3, 2021 · 0 comments
Open

False warnings from clang's scan-build #330

gperciva opened this issue Dec 3, 2021 · 0 comments
Labels
Not a problem False warnings from compilers or analysis tools

Comments

@gperciva
Copy link
Member

gperciva commented Dec 3, 2021

clang 13.0.0's scan-build reports:

  • Logic error "Result of operation is garbage or undefined" in crypto_aesctr_stream_cipherblock_use.

    This is discussed in False clang-scan warning, likely from be64enc libcperciva#372.

    TL;DR: clang doesn't realize that writing a 32-bit integer will initialize all 4 bytes.

  • Logic error "Assigned value is garbage or undefined" in _mm_loadu_si64 (called from cpusupport-X86-AESNI.c)

    This is discussed in False clang-scan warning in _mm_loadu_si64 libcperciva#423.

    TL;DR: clang-scan doesn't like its own <emmintrin.h> header.

  • Memory error "Potential leak of memory pointed to by 'R'" in dnsthread_resolve() in lib/dnsthread/dnsthread.c. That's the struct resolve_cookie * R.

    This is because R is freed in callback_resolve(). We can see from the valgrind memory test of 07-dnsthread-resolve.sh that this value is freed.

@gperciva gperciva added the Not a problem False warnings from compilers or analysis tools label Jan 25, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Not a problem False warnings from compilers or analysis tools
Development

No branches or pull requests

1 participant