Software Tools for Source Code Analysis
Keywords:
Static, Dynamic, Analysis, Valgrind, Memory, Security, Source-Code, VulnerabilitiesAbstract
This article aims to look at the risks derived from vulnerabilities introduced by the source-code and present the means to detect them. The software tools that are often used in such situations are called analyzers and can be categorized in static and dynamic analyzers. This article will present the main advantages and disadvantages of each software tool used and subsequently show the results and a comparison between these utilities. Finally, conclusions will be drawn explaining how source code introduced vulnerabilities can be handled and avoided.References
Computer and internet penetration statistics: http://www.itu.int/en/ITU-D/Statistics/Pages/default.aspx http://www.internetworldstats.com/emarketing.htm
“The Evolution of Cyber Attacks and Next Generation Threat Protection Presentation” by Ashar Aziz, RSA Conference 2013
“History of attacks”, Lewis University, http://online.lewisu.edu/the-history-of-cyber-warfare.asp
“Software Vulnerabilities, Prevention and Detection Methods: A Review”, Willy Jimenez, Amel Mammar, Ana Cavalli,Telecom SudParis
Stack and Heap Overrun http://drdeath.myftp.org:881/books/Exploiting/Stack.and.Heap.Overflow.pdf
“Source Code Security” presentation, I. Smeureanu, University of Academic Studies of Bucharest, 2014
“Program Analysis presentation”, by Mario Barrenechea for Colorado University
Commercial dynamic Analyser: http://www.viva64.com/en/d/
Practical Memory Checking with Dr. Memory - Derek Bruening and Qin Zhao, http://www.burningcutlery.com/derek/docs/drmem-CGO11.pdf
CppCheck: http://cppcheck.sourceforge.net/
Flawfinder: http://www.dwheeler.com/flawfinder/
Valgrind: http://www.valgrind.org/
Dr. Memory http://www.drmemory.org/
Downloads
Published
How to Cite
Issue
Section
License
Authors who publish with this journal agree to the following terms:
- Authors retain copyright and grant the journal right of first publication with the work simultaneously licensed under a Creative Commons Attribution License that allows others to share the work with an acknowledgement of the work's authorship and initial publication in this journal.
- Authors are able to enter into separate, additional contractual arrangements for the non-exclusive distribution of the journal's published version of the work (e.g., post it to an institutional repository or publish it in a book), with an acknowledgement of its initial publication in this journal.
- Authors are permitted and encouraged to post their work online (e.g., in institutional repositories or on their website) prior to and during the submission process, as it can lead to productive exchanges, as well as earlier and greater citation of published work (See The Effect of Open Access).
- The author(s) is responsible for the correctness and legality of the paper content.
- Papers that are copyrighted or published will not be taken into consideration for publication in JMEDS It is the author(s) responsibility to ensure that the paper does not cause any copyright infringements and other problems.
- It is the responsibility of the author(s) to obtain all necessary copyright release permissions for the use of any copyrighted materials in the paper prior to the submission.
- The Author(s) retains the right to reuse any portion of the paper, in future works, including books, lectures and presentations in all media, with the condition that the publication by JMEDS is properly credited and referenced.
JMEDS articles by Journal of Mobile, Embedded and Distributed Systems (JMEDS) is licensed under a Creative Commons Attribution 4.0 International License.
Based on a work at http://jmeds.eu.
Permissions beyond the scope of this license may be available at http://jmeds.eu/index.php/jmeds/about/submissions#copyrightNotice.