svf-tools 1.0.1250 → 1.0.1252

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svf-tools",
3
- "version": "1.0.1250",
3
+ "version": "1.0.1252",
4
4
  "description": "* <b>[TypeClone](https://github.com/SVF-tools/SVF/wiki/TypeClone) published in our [ECOOP paper](https://yuleisui.github.io/publications/ecoop20.pdf) is now available in SVF </b> * <b>SVF now uses a single script for its build. Just type [`source ./build.sh`](https://github.com/SVF-tools/SVF/blob/master/build.sh) in your terminal, that's it!</b> * <b>SVF now supports LLVM-10.0.0! </b> * <b>We thank [bsauce](https://github.com/bsauce) for writing a user manual of SVF ([link1](https://www.jianshu.com/p/068a08ec749c) and [link2](https://www.jianshu.com/p/777c30d4240e)) in Chinese </b> * <b>SVF now supports LLVM-9.0.0 (Thank [Byoungyoung Lee](https://github.com/SVF-tools/SVF/issues/142) for his help!). </b> * <b>SVF now supports a set of [field-sensitive pointer analyses](https://yuleisui.github.io/publications/sas2019a.pdf). </b> * <b>[Use SVF as an external lib](https://github.com/SVF-tools/SVF/wiki/Using-SVF-as-a-lib-in-your-own-tool) for your own project (Contributed by [Hongxu Chen](https://github.com/HongxuChen)). </b> * <b>SVF now supports LLVM-7.0.0. </b> * <b>SVF now supports Docker. [Try SVF in Docker](https://github.com/SVF-tools/SVF/wiki/Try-SVF-in-Docker)! </b> * <b>SVF now supports [LLVM-6.0.0](https://github.com/svf-tools/SVF/pull/38) (Contributed by [Jack Anthony](https://github.com/jackanth)). </b> * <b>SVF now supports [LLVM-4.0.0](https://github.com/svf-tools/SVF/pull/23) (Contributed by Jared Carlson. Thank [Jared](https://github.com/jcarlson23) and [Will](https://github.com/dtzWill) for their in-depth [discussions](https://github.com/svf-tools/SVF/pull/18) about updating SVF!) </b> * <b>SVF now supports analysis for C++ programs.</b> <br />",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -76,21 +76,33 @@ AbstractInterpretation::AbstractInterpretation()
76
76
  /// Must only be called after the option parser has populated AESparsity.
77
77
  AbstractInterpretation& AbstractInterpretation::getAEInstance()
78
78
  {
79
- static std::unique_ptr<AbstractInterpretation> instance = []()
80
- -> std::unique_ptr<AbstractInterpretation>
79
+ // Leak the singleton on purpose. AbstractInterpretation owns a
80
+ // Map<std::string, std::function<void(const CallICFGNode*)>> func_map
81
+ // whose lambda closures back-reference state owned by other globals
82
+ // (preAnalysis's WTO, the call graph, ...). Letting the static
83
+ // unique_ptr's atexit-time destructor run hits a static-destruction-
84
+ // order issue: the func_map hashtable's destructor calls into
85
+ // std::function destroyers whose closures touch already-destroyed
86
+ // state, and ~_Hashtable() segfaults during normal program shutdown.
87
+ //
88
+ // Reliably reproducible from any downstream tool that drives a full
89
+ // AE analysis to completion and then exits normally:
90
+ // - SSA's ass3 binary (Software-Security-Analysis/Assignment-3)
91
+ // - pysvf via Python interpreter shutdown
92
+ //
93
+ // A process-lifetime singleton has no observable lifecycle past
94
+ // program exit, so leaking is benign and avoids the use-after-destroy.
95
+ static AbstractInterpretation* instance = []() -> AbstractInterpretation*
81
96
  {
82
97
  switch (Options::AESparsity())
83
98
  {
84
99
  case AESparsity::SemiSparse:
85
- return std::unique_ptr<AbstractInterpretation>(
86
- new SemiSparseAbstractInterpretation());
100
+ return new SemiSparseAbstractInterpretation();
87
101
  case AESparsity::Sparse:
88
- return std::unique_ptr<AbstractInterpretation>(
89
- new FullSparseAbstractInterpretation());
102
+ return new FullSparseAbstractInterpretation();
90
103
  case AESparsity::Dense:
91
104
  default:
92
- return std::unique_ptr<AbstractInterpretation>(
93
- new AbstractInterpretation());
105
+ return new AbstractInterpretation();
94
106
  }
95
107
  }();
96
108
  return *instance;