[llvm-dev] Coverity Scan Needs to be Updated after GitHub Migration

Tom Honermann via llvm-dev llvm-dev at lists.llvm.org
Fri Jun 11 08:15:41 PDT 2021


On 6/11/2021 9:58 AM, Tom Honermann via llvm-dev wrote:
On 6/10/2021 2:54 PM, David Blaikie via llvm-dev wrote:
On Thu, Jun 10, 2021 at 10:42 AM Mehdi AMINI <joker.eph at gmail.com<mailto:joker.eph at gmail.com>> wrote:



On Thu, Jun 10, 2021 at 10:20 AM David Blaikie via llvm-dev <llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>> wrote:

From Coverity:

Please find the latest report on new defect(s) introduced to llvm found with Coverity Scan.

8 new defect(s) introduced to llvm found with Coverity Scan.
19 defect(s), reported by Coverity Scan earlier, were marked fixed in the recent build analyzed by Coverity Scan.

New defect(s) Reported-by: Coverity Scan
Showing 8 of 8 defect(s)


** CID 1457502:  Uninitialized members  (UNINIT_CTOR)
/lld/MachO/InputSection.h: 109 in lld::macho::StringPiece::StringPiece(unsigned long, unsigned int)()

Is it easy for us to disable low-value findings (both on a per-instance, but also per-check-tye) basis in source (ie: without having to modify an external config)?

Source annotations are available for suppressing per-instance issues, but no source annotations are available to disable checkers entirely.

I don't see an option for disabling specific checkers in Coverity Scan.  Checker enable/disable and tuning options are available when using a Coverity installation.  I don't know why those capabilities wouldn't be exposed to Coverity Scan users.

I confirmed with internal Coverity support that such options are not currently exposed to Coverity Scan users.  Enhancement requests sent to scan-admin at coverity.com<mailto:scan-admin at coverity.com> will be considered for future Coverity Scan updates (I encourage sending an enhancement request).

For instance, I'm not sure it's valuable for us to get notification on any member not initialized by a ctor. That could readily be detected by clang-tidy or clang warnings and we don't implement such checks in those places (which would be higher value because they can find the issue sooner rather than waiting for a long-running static analysis to come back with results).

I'm going to push back on this a bit.  I've had to debug problems in Clang that turned out to be due to failure to initialize a data member.  I find the number of uninitialized data member issues that Coverity reports on LLVM to be out of line with respect to other projects I've seen scanned.  I'm skeptical that omitting initializers has a significant impact on performance.

Coverity doesn't report every data member that isn't initialized by a member init; it looks for evidence that the data member is not initialized by any functions invoked by the constructor as well (whether in the same TU or not).  It will therefore report fewer FPs than either clang-tidy or clang warnings.

Tom.

Keeping the warnings low-noise would be really important (so whoever set this up or requested it I hope is really pushing to reduce the noise until nearly all results have pretty broad agreement that they should be fixed).

Yes, the general deployment recommendation is to tune to minimize FPs and low value results and then relax such tuning as issues are addressed.

Tom.




________________________________________________________________________________________________________
*** CID 1457502:  Uninitialized members  (UNINIT_CTOR)
/lld/MachO/InputSection.h: 109 in lld::macho::StringPiece::StringPiece(unsigned long, unsigned int)()
103       // Offset from the start of the containing input section.
104       uint32_t inSecOff;
105       uint32_t hash;
106       // Offset from the start of the containing output section.
107       uint64_t outSecOff;
108
>>>     CID 1457502:  Uninitialized members  (UNINIT_CTOR)
>>>     Non-static class member "outSecOff" is not initialized in this constructor nor in any functions that it calls.
109       StringPiece(uint64_t off, uint32_t hash) : inSecOff(off), hash(hash) {}
110     };
111
112     // CStringInputSections are composed of multiple null-terminated string
113     // literals, which we represent using StringPieces. These literals can be
114     // deduplicated and tail-merged, so translating offsets between the input and

** CID 1457501:  Uninitialized members  (UNINIT_CTOR)
/llvm/lib/ObjectYAML/XCOFFEmitter.cpp: 36 in <unnamed>::XCOFFWriter::XCOFFWriter(llvm::XCOFFYAML::Object &, llvm::raw_ostream &, llvm::function_ref<void (const llvm::Twine &)>)()


________________________________________________________________________________________________________
*** CID 1457501:  Uninitialized members  (UNINIT_CTOR)
/llvm/lib/ObjectYAML/XCOFFEmitter.cpp: 36 in <unnamed>::XCOFFWriter::XCOFFWriter(llvm::XCOFFYAML::Object &, llvm::raw_ostream &, llvm::function_ref<void (const llvm::Twine &)>)()
30
31     class XCOFFWriter {
32     public:
33       XCOFFWriter(XCOFFYAML::Object &Obj, raw_ostream &OS, yaml::ErrorHandler EH)
34           : Obj(Obj), W(OS, support::big), ErrHandler(EH) {
35         Is64Bit = Obj.Header.Magic == (llvm::yaml::Hex16)XCOFF::XCOFF64;
>>>     CID 1457501:  Uninitialized members  (UNINIT_CTOR)
>>>     Non-static class member "StartOffset" is not initialized in this constructor nor in any functions that it calls.
36       }
37       bool writeXCOFF();
38
39     private:
40       bool initFileHeader(uint64_t CurrentOffset);
41       bool initSectionHeader(uint64_t &CurrentOffset);

** CID 1457500:  Incorrect expression  (SIZEOF_MISMATCH)
/compiler-rt/lib/dfsan/dfsan_custom.cpp: 2367 in format_buffer(char *, unsigned long, const char *, unsigned char *, unsigned char *, unsigned int *, unsigned int *, __va_list_tag *)()


________________________________________________________________________________________________________
*** CID 1457500:  Incorrect expression  (SIZEOF_MISMATCH)
/compiler-rt/lib/dfsan/dfsan_custom.cpp: 2367 in format_buffer(char *, unsigned long, const char *, unsigned char *, unsigned char *, unsigned int *, unsigned int *, __va_list_tag *)()
2361             case 'n': {
2362               int *ptr = va_arg(ap, int *);
2363               *ptr = (int)formatter.str_off;
2364               va_labels++;
2365               if (va_origins)
2366                 va_origins++;
>>>     CID 1457500:  Incorrect expression  (SIZEOF_MISMATCH)
>>>     Passing argument "ptr" of type "int *" and argument "8UL /* sizeof (ptr) */" to function "dfsan_set_label" is suspicious.
2367               dfsan_set_label(0, ptr, sizeof(ptr));

I think clang has a sizeof warning for things like memcpy, right? I wonder if this more broad warning provides a lot of value, or not?

2368               end_fmt = true;
2369               break;
2370             }
2371
2372             case '%':

** CID 1457499:  Incorrect expression  (DIVIDE_BY_ZERO)
/llvm/lib/Analysis/CFGPrinter.cpp: 308 in llvm::DOTGraphTraits<llvm::DOTFuncInfo *>::isNodeHidden(const llvm::BasicBlock *, const llvm::DOTFuncInfo *)()


________________________________________________________________________________________________________
*** CID 1457499:  Incorrect expression  (DIVIDE_BY_ZERO)
/llvm/lib/Analysis/CFGPrinter.cpp: 308 in llvm::DOTGraphTraits<llvm::DOTFuncInfo *>::isNodeHidden(const llvm::BasicBlock *, const llvm::DOTFuncInfo *)()
302                                                      const DOTFuncInfo *CFGInfo) {
303       if (HideColdPaths.getNumOccurrences() > 0)
304         if (auto *BFI = CFGInfo->getBFI()) {
305           uint64_t NodeFreq = BFI->getBlockFreq(Node).getFrequency();
306           uint64_t EntryFreq = BFI->getEntryFreq();
307           // Hide blocks with relative frequency below HideColdPaths threshold.
>>>     CID 1457499:  Incorrect expression  (DIVIDE_BY_ZERO)
>>>     In expression "(double)NodeFreq / EntryFreq", division by expression "EntryFreq" which may be zero has undefined behavior.
308           if ((double)NodeFreq / EntryFreq < HideColdPaths)
309             return true;
310         }
311       if (HideUnreachablePaths || HideDeoptimizePaths) {
312         if (isOnDeoptOrUnreachablePath.find(Node) ==
313             isOnDeoptOrUnreachablePath.end())

** CID 1457498:    (DEADCODE)
/clang/lib/Sema/SemaDeclCXX.cpp: 11843 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()
/clang/lib/Sema/SemaDeclCXX.cpp: 11789 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()


________________________________________________________________________________________________________
*** CID 1457498:    (DEADCODE)
/clang/lib/Sema/SemaDeclCXX.cpp: 11843 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()
11837         return true;
11838       }
11839
11840       // No conflict between a tag and a non-tag.
11841       if (!NonTag) return false;
11842
>>>     CID 1457498:    (DEADCODE)
>>>     Execution cannot reach this statement: "<temporary> = this->Diag(cl...".
11843       Diag(BUD->getLocation(), diag::err_using_decl_conflict);
11844       Diag(Target->getLocation(), diag::note_using_decl_target);
11845       Diag(NonTag->getLocation(), diag::note_using_decl_conflict);
11846       BUD->setInvalidDecl();
11847       return true;
11848     }
/clang/lib/Sema/SemaDeclCXX.cpp: 11789 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()
11783       // Always emit a diagnostic for a mismatch between an unresolved
11784       // using_if_exists and a resolved using declaration in either direction.
11785       if (isa<UnresolvedUsingIfExistsDecl>(Target) !=
11786           (isa_and_nonnull<UnresolvedUsingIfExistsDecl>(NonTag))) {
11787         if (!NonTag && !Tag)
11788           return false;
>>>     CID 1457498:    (DEADCODE)
>>>     Execution cannot reach this statement: "<temporary> = this->Diag(cl...".
11789         Diag(BUD->getLocation(), diag::err_using_decl_conflict);
11790         Diag(Target->getLocation(), diag::note_using_decl_target);
11791         Diag((NonTag ? NonTag : Tag)->getLocation(),
11792              diag::note_using_decl_conflict);
11793         BUD->setInvalidDecl();
11794         return true;

** CID 1457497:  Integer handling issues  (NEGATIVE_RETURNS)


________________________________________________________________________________________________________
*** CID 1457497:  Integer handling issues  (NEGATIVE_RETURNS)
/lld/MachO/InputSection.cpp: 117 in lld::macho::CStringInputSection::getStringPiece(unsigned long) const()
111     const StringPiece &CStringInputSection::getStringPiece(uint64_t off) const {
112       if (off >= data.size())
113         fatal(toString(this) + ": offset is outside the section");
114
115       auto it =
116           partition_point(pieces, [=](StringPiece p) { return p.inSecOff <= off; });
>>>     CID 1457497:  Integer handling issues  (NEGATIVE_RETURNS)
>>>     A negative constant "-1L" is passed as an argument to a parameter that cannot be negative.

Doesn't sound correct - negatively indexing from an iterator is valid, I believe? (though perhaps this check is using some info about the nature of `partition_point` being able to return the begin iterator)

117       return it[-1];
118     }
119
120     uint64_t CStringInputSection::getFileOffset(uint64_t off) const {
121       return parent->fileOff + getOffset(off);
122     }

** CID 1457496:  Possible Control flow issues  (DEADCODE)
/clang/lib/Sema/SemaDeclCXX.cpp: 11833 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()


________________________________________________________________________________________________________
*** CID 1457496:  Possible Control flow issues  (DEADCODE)
/clang/lib/Sema/SemaDeclCXX.cpp: 11833 in clang::Sema::CheckUsingShadowDecl(clang::BaseUsingDecl *, clang::NamedDecl *, const clang::LookupResult &, clang::UsingShadowDecl *&)()
11827       // Target is not a function.
11828
11829       if (isa<TagDecl>(Target)) {
11830         // No conflict between a tag and a non-tag.
11831         if (!Tag) return false;
11832
>>>     CID 1457496:  Possible Control flow issues  (DEADCODE)
>>>     Execution cannot reach this statement: "<temporary> = this->Diag(cl...".
11833         Diag(BUD->getLocation(), diag::err_using_decl_conflict);
11834         Diag(Target->getLocation(), diag::note_using_decl_target);
11835         Diag(Tag->getLocation(), diag::note_using_decl_conflict);
11836         BUD->setInvalidDecl();
11837         return true;
11838       }

** CID 1419078:  Resource leaks  (VIRTUAL_DTOR)
/llvm/lib/Transforms/Instrumentation/PGOInstrumentation.cpp: 541 in ()


________________________________________________________________________________________________________
*** CID 1419078:  Resource leaks  (VIRTUAL_DTOR)
/llvm/lib/Transforms/Instrumentation/PGOInstrumentation.cpp: 541 in ()
535         return (Twine(Removed ? "-" : " ") + (InMST ? " " : "*") +
536                 (IsCritical ? "c" : " ") + "  W=" + Twine(Weight)).str();
537       }
538     };
539
540     // This class stores the auxiliary information for each BB.
>>>     CID 1419078:  Resource leaks  (VIRTUAL_DTOR)
>>>     Class "<unnamed>::BBInfo" does not have a virtual destructor.
541     struct BBInfo {
542       BBInfo *Group;
543       uint32_t Index;
544       uint32_t Rank = 0;
545
546       BBInfo(unsigned IX) : Group(this), Index(IX) {}


________________________________________________________________________________________________________
To view the defects in Coverity Scan visit, https://u15810271.ct.sendgrid.net/ls/click?upn=HRESupC-2F2Czv4BOaCWWCy7my0P0qcxCbhZ31OYv50yqtGMuad6pPsL7inW23sAqZCWZD0rQ5FZsyk18zSjnBpg-3D-3Dqen7_nlj59xHPRAo5NMSpMZh-2B1UYnQ4IBJNE2FCxtFGv5-2FfRZ2ZNTfin-2BJg3vqHM-2BrKWO-2BwAgQVf1GGFXh4xVX9UzXjq3jPiI59xzjIzanRxv0XSIVZFqDyJd-2BdQm4cXqcdS7Dt0L1fNQpWyw15e-2BbU4YMt1YpKZVa4kbM7Bjl6hGDatG6tnUuz5zUAdmlq-2B7z2QmYSc2DTghseWofWoq-2Bn7ssA-3D-3D<https://urldefense.com/v3/__https://u15810271.ct.sendgrid.net/ls/click?upn=HRESupC-2F2Czv4BOaCWWCy7my0P0qcxCbhZ31OYv50yqtGMuad6pPsL7inW23sAqZCWZD0rQ5FZsyk18zSjnBpg-3D-3Dqen7_nlj59xHPRAo5NMSpMZh-2B1UYnQ4IBJNE2FCxtFGv5-2FfRZ2ZNTfin-2BJg3vqHM-2BrKWO-2BwAgQVf1GGFXh4xVX9UzXjq3jPiI59xzjIzanRxv0XSIVZFqDyJd-2BdQm4cXqcdS7Dt0L1fNQpWyw15e-2BbU4YMt1YpKZVa4kbM7Bjl6hGDatG6tnUuz5zUAdmlq-2B7z2QmYSc2DTghseWofWoq-2Bn7ssA-3D-3D__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy535GVbE$>

  To manage Coverity Scan email notifications for "joker.eph at gmail.com<mailto:joker.eph at gmail.com>", click https://u15810271.ct.sendgrid.net/ls/click?upn=HRESupC-2F2Czv4BOaCWWCy7my0P0qcxCbhZ31OYv50yped04pjJnmXOsUBtKYNIXxUrjVeIJ0Cfeziujhnhh3yxzc7w9MgExjQKEssnVrR9tYRoPYlaXXfdUjwRQLJCdFixsrT7mUhUA9ixc9DPUdquU2MMNgdrF247xaBicB0V4-3Dht-M_nlj59xHPRAo5NMSpMZh-2B1UYnQ4IBJNE2FCxtFGv5-2FfRZ2ZNTfin-2BJg3vqHM-2BrKWOP6G0-2FiydipnYxIKl-2Bk7AFFr9CcUjQXx7tq4qtWbpBdzz7-2Bib4DWeMAf-2Bv0hl9c0qiwYnDVi4C3uD0F0P9wRuATKCNq-2FJGcnjmQ51zJUZdom9QcwJ2QwYMBBjOk8G2ylW4oH3PujCpojyn5dsLN7qdQ-3D-3D<https://urldefense.com/v3/__https://u15810271.ct.sendgrid.net/ls/click?upn=HRESupC-2F2Czv4BOaCWWCy7my0P0qcxCbhZ31OYv50yped04pjJnmXOsUBtKYNIXxUrjVeIJ0Cfeziujhnhh3yxzc7w9MgExjQKEssnVrR9tYRoPYlaXXfdUjwRQLJCdFixsrT7mUhUA9ixc9DPUdquU2MMNgdrF247xaBicB0V4-3Dht-M_nlj59xHPRAo5NMSpMZh-2B1UYnQ4IBJNE2FCxtFGv5-2FfRZ2ZNTfin-2BJg3vqHM-2BrKWOP6G0-2FiydipnYxIKl-2Bk7AFFr9CcUjQXx7tq4qtWbpBdzz7-2Bib4DWeMAf-2Bv0hl9c0qiwYnDVi4C3uD0F0P9wRuATKCNq-2FJGcnjmQ51zJUZdom9QcwJ2QwYMBBjOk8G2ylW4oH3PujCpojyn5dsLN7qdQ-3D-3D__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy8RFYZYc$>


On Thu, Jun 10, 2021 at 7:37 AM Luke Benes via llvm-dev <llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>> wrote:
> https://scan.coverity.com/projects/llvm
> Should run once a day.

Sylvester,
The report seems to be working perfectly. Thank you for taking the time to get this up and running again!

My only concern is that there is no visibly on these reports. Without the new issues being reported here, it is highly unlikely that they will get addressed.

Since there was interest and no objections, could you please add the [llvm-dev] list to the email?

You can do this by going to the "Project Settings" page:
https://scan.coverity.com/projects/llvm?tab=project_settings

"Additional Emails for New Defect Notifications"
-> llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>

Then could you please lower the report frequency to once or twice a week? With that we will receive weekly reports like this:

http://document-foundation-mail-archive.969070.n3.nabble.com/New-Defects-reported-by-Coverity-Scan-for-LibreOffice-td4301203.html<https://urldefense.com/v3/__http://document-foundation-mail-archive.969070.n3.nabble.com/New-Defects-reported-by-Coverity-Scan-for-LibreOffice-td4301203.html__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy7OhpJPm$>

_______________________________________________
LLVM Developers mailing list
llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<https://urldefense.com/v3/__https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy7Im7VZf$>
_______________________________________________
LLVM Developers mailing list
llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<https://urldefense.com/v3/__https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy7Im7VZf$>



_______________________________________________
LLVM Developers mailing list
llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>
https://urldefense.com/v3/__https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev__;!!A4F2R9G_pg!PQwy8rAjiKMI_cBfDwnfPHyGD0k6TmR-QczpyNJJYgHISD-Qk1-6wPLjy7Im7VZf$




_______________________________________________
LLVM Developers mailing list
llvm-dev at lists.llvm.org<mailto:llvm-dev at lists.llvm.org>
https://urldefense.com/v3/__https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev__;!!A4F2R9G_pg!OqS--6HaZxcTx5Dt_tzjIpH37pYd3W0dBZqRxguX9IqfSIEm0LR2kmIPuSCtBYp1$

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20210611/e9e37fdf/attachment-0001.html>


More information about the llvm-dev mailing list