<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>datenkobold.de &#187; Softwaretest</title>
	<atom:link href="http://www.datenkobold.de/weblog/tags/softwaretest/feed" rel="self" type="application/rss+xml" />
	<link>http://www.datenkobold.de/weblog</link>
	<description>das Weblog von Steffen Bauch</description>
	<lastBuildDate>Fri, 09 Dec 2011 21:58:05 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Statische Codeanalyse mit Uno</title>
		<link>http://www.datenkobold.de/weblog/2006/12/statische-codeanalyse-mit-uno</link>
		<comments>http://www.datenkobold.de/weblog/2006/12/statische-codeanalyse-mit-uno#comments</comments>
		<pubDate>Thu, 21 Dec 2006 23:20:43 +0000</pubDate>
		<dc:creator>aquo</dc:creator>
				<category><![CDATA[Programmierung]]></category>
		<category><![CDATA[Codeanalyse]]></category>
		<category><![CDATA[Sicherheit]]></category>
		<category><![CDATA[Softwaretest]]></category>
		<category><![CDATA[Uno]]></category>

		<guid isPermaLink="false">http://www.datenkobold.de/weblog/?p=312</guid>
		<description><![CDATA[Statische Codeanalyse ist eine Art von Softwaretest, bei der Quellcode bestimmten formalen und algorithmischen Pr&#252;fungen unterzogen wird um Fehler in Software zu finden. Die &#220;berpr&#252;fung erfolgt hier im Gegensatz zur dynamischen Analyse nicht zur Laufzeit und wird deswegen als statische Analyse bezeichnet. Uno ist ein Tool, mit dem man nach drei der h&#228;ufigsten Fehlerarten in [...]


<strong>Ähnliche Artikel:</strong><ol><li><a href='http://www.datenkobold.de/weblog/2007/01/arithmetik-ohne-begrenzungen' rel='bookmark' title='Arithmetik ohne Begrenzungen'>Arithmetik ohne Begrenzungen</a></li>
<li><a href='http://www.datenkobold.de/weblog/2005/12/unmaintainable-code' rel='bookmark' title='Unmaintainable Code'>Unmaintainable Code</a></li>
<li><a href='http://www.datenkobold.de/weblog/2005/10/cache-attack-auf-aes' rel='bookmark' title='Cache Attack auf AES'>Cache Attack auf AES</a></li>
</ol>]]></description>
			<content:encoded><![CDATA[<p>Statische Codeanalyse ist eine Art von Softwaretest, bei der Quellcode bestimmten formalen und algorithmischen Pr&#252;fungen unterzogen wird um Fehler in Software zu finden. Die &#220;berpr&#252;fung erfolgt hier im Gegensatz zur dynamischen Analyse nicht zur Laufzeit und wird deswegen als statische Analyse bezeichnet.</p>
<p><a href="http://spinroot.com/uno/">Uno</a> ist ein Tool, mit dem man nach drei  der h&#228;ufigsten Fehlerarten in C-Quellcode suchen kann:</p>
<ul>
<li>Nutzung uninitialisierter Variablen</li>
<li>Dereferenzierung von NULL-Pointern</li>
<li>Bereichs&#252;berschreitung bei der Array-Adressierung</li>
</ul>
<p>Entsprechende Beispiele und ein Download des Werkzeuges sind auf der Seite von Uno zu finden. Eine kurze Probe hier hat gezeigt, da&#223; sich sowohl einfache Beispiele konstruieren lassen bei dem Dereferenzierungsfehler gefunden werden, als auch Beispiele, bei dem das Werkzeug die Fehler &#252;bersieht.</p>
<p>Hier wird der Fehler gefunden:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
</pre></td><td class="code"><pre class="c" style="font-family:monospace;"><span style="color: #993333;">int</span> <span style="color: #339933;">*</span>ptr<span style="color: #339933;">;</span>
&nbsp;
<span style="color: #993333;">int</span> main<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span>ptr<span style="color: #009900;">&#41;</span>
        <span style="color: #339933;">*</span>ptr <span style="color: #339933;">=</span> <span style="color: #0000dd;">123</span><span style="color: #339933;">;</span>
    <span style="color: #b1b100;">else</span>
        <span style="color: #339933;">*</span>ptr <span style="color: #339933;">=</span> <span style="color: #0000dd;">345</span><span style="color: #339933;">;</span>
    <span style="color: #b1b100;">return</span> <span style="color: #0000dd;">0</span><span style="color: #339933;">;</span> 
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>


<div class="wp_syntax"><div class="code"><pre class="sh" style="font-family:monospace;">uno:#1: possible global use or deref before def:
[R ptr global_nullptr_deref.c 9]
in fct main global_nullptr_deref.c 4</pre></div></div>

<p>und hier nicht:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
</pre></td><td class="code"><pre class="c" style="font-family:monospace;"><span style="color: #993333;">int</span> main<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
&nbsp;
    <span style="color: #993333;">int</span> <span style="color: #339933;">*</span>ptr<span style="color: #339933;">;</span>
    ptr <span style="color: #339933;">=</span> NULL<span style="color: #339933;">;</span>
&nbsp;
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span>ptr<span style="color: #009900;">&#41;</span>
        <span style="color: #339933;">*</span>ptr <span style="color: #339933;">=</span> <span style="color: #0000dd;">123</span><span style="color: #339933;">;</span>
    <span style="color: #b1b100;">else</span>
        <span style="color: #339933;">*</span>ptr <span style="color: #339933;">=</span> <span style="color: #0000dd;">345</span><span style="color: #339933;">;</span>
    <span style="color: #b1b100;">return</span> <span style="color: #0000dd;">0</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Generell ist die quelloffene Verf&#252;gbarkeit von leistungsf&#228;higen Werkzeugen zur Codeanalyse nicht gegeben, die Werkzeuge &#252;bersehen Fehler oder liefern zuviele Falschpositive. Professionelle Tools wie <a href="http://www.coverity.com/">Coverity</a> stehen wiederum nicht zur freien Verf&#252;gung. Wer sich mehr mit diesem Thema besch&#228;ftigen will, findet allerdings auf der Seite von <a href="http://www.stanford.edu/%7Eengler/">Dawson Engler</a>, dem Gr&#252;nder von Coverity, einen guten Einstiegspunkt mit ein paar interessanten Ver&#246;ffentlichungen, auch zur probalistischen Analyse von Quellcode.</p>


<p><strong>Ähnliche Artikel:</strong><ol><li><a href='http://www.datenkobold.de/weblog/2007/01/arithmetik-ohne-begrenzungen' rel='bookmark' title='Arithmetik ohne Begrenzungen'>Arithmetik ohne Begrenzungen</a></li>
<li><a href='http://www.datenkobold.de/weblog/2005/12/unmaintainable-code' rel='bookmark' title='Unmaintainable Code'>Unmaintainable Code</a></li>
<li><a href='http://www.datenkobold.de/weblog/2005/10/cache-attack-auf-aes' rel='bookmark' title='Cache Attack auf AES'>Cache Attack auf AES</a></li>
</ol></p>]]></content:encoded>
			<wfw:commentRss>http://www.datenkobold.de/weblog/2006/12/statische-codeanalyse-mit-uno/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

