diff options
Diffstat (limited to 'compat_reports')
-rw-r--r-- | compat_reports/1.0.16_to_1.0.17/compat_report.html | 1170 |
1 files changed, 1170 insertions, 0 deletions
diff --git a/compat_reports/1.0.16_to_1.0.17/compat_report.html b/compat_reports/1.0.16_to_1.0.17/compat_report.html new file mode 100644 index 0000000..521b439 --- /dev/null +++ b/compat_reports/1.0.16_to_1.0.17/compat_report.html @@ -0,0 +1,1170 @@ +<!-- kind:binary;verdict:incompatible;affected:1;added:12;removed:0;type_problems_high:0;type_problems_medium:7;type_problems_low:1;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:2;changed_constants:0;constant_changes_other:2;tool_version:2.3 --> +<!-- kind:source;verdict:incompatible;affected:0.8;added:12;removed:0;type_problems_high:6;type_problems_medium:0;type_problems_low:2;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:6;constant_changes_other:2;tool_version:2.3 --> +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> +<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> +<meta name="viewport" content="width=device-width,initial-scale=1" /> +<meta name="keywords" content="libsodium, compatibility, API, ABI, report" /> +<meta name="description" content="API/ABI compatibility report for the libsodium library between 1.0.16 and 1.0.17 versions" /> +<title>libsodium: 1.0.16 to 1.0.17 compatibility report</title> +<style type="text/css"> +body { + font-family:Arial, sans-serif; + background-color:White; + color:Black; +} +hr { + color:Black; + background-color:Black; + height:1px; + border:0; +} +h1 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.625em; +} +h2 { + margin-bottom:0px; + padding-bottom:0px; + font-size:1.25em; + white-space:nowrap; +} +span.section { + font-weight:bold; + cursor:pointer; + color:#003E69; + white-space:nowrap; + margin-left:0.3125em; +} +span.new_sign { + font-weight:bold; + margin-left:1.65em; + color:#003E69; +} +span.new_sign_lbl { + margin-left:3em; + font-size:1em; + color:Black; +} +span:hover.section { + color:#336699; +} +span.sect_aff { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:#cc3300; +} +span.sect_info { + cursor:pointer; + padding-left:1.55em; + font-size:0.875em; + color:Black; +} +span.ext { + font-weight:normal; +} +span.h_name { + color:#cc3300; + font-size:0.875em; + font-weight:bold; +} +div.h_list, div.lib_list { + font-size:0.94em; + padding-left:0.4em; +} +span.ns { + color:#408080; + font-size:0.94em; +} +span.lib_name { + color:Green; + font-size:0.875em; + font-weight:bold; +} +span.iname { + font-weight:bold; + color:#003E69; + margin-left:0.3125em; +} +span.iname_b { + font-weight:bold; +} +span.iname_a { + color:#333333; + font-weight:bold; + font-size:0.94em; +} +span.sym_p { + font-weight:normal; + white-space:normal; +} +span.sym_pd { + white-space:normal; +} +span.sym_p span, span.sym_pd span { + white-space:nowrap; +} +div.affect { + padding-left:1em; + padding-bottom:10px; + font-size:0.87em; + font-style:italic; + line-height:0.9em; +} +div.affected { + padding-left:1.9em; + padding-top:10px; +} +table.ptable { + border-collapse:collapse; + border:1px outset black; + margin-left:0.95em; + margin-top:3px; + margin-bottom:3px; + width:56.25em; +} +table.ptable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + text-align:left; + vertical-align:top; + max-width:28em; + word-wrap:break-word; +} +table.ptable th.pn { + width:2%; +} +table.ptable th.chg { + width:47%; +} +table.vtable { + border-collapse:collapse; + border:1px outset black; + margin-left:1.9em; + margin-top:0.7em; +} +table.vtable td { + border:1px solid gray; + padding:3px; + font-size:0.875em; + vertical-align:top; + max-width:450px; + word-wrap:break-word; +} +table.ptable th, table.vtable th { + background-color:#eeeeee; + font-weight:bold; + color:#333333; + font-family:Verdana, Arial; + font-size:0.875em; + border:1px solid gray; + text-align:center; + vertical-align:top; + white-space:nowrap; + padding:3px; +} +table.summary { + border-collapse:collapse; + border:1px outset black; +} +table.summary th { + background-color:#eeeeee; + font-weight:normal; + text-align:left; + font-size:0.94em; + white-space:nowrap; + border:1px inset gray; + padding:3px; +} +table.summary td { + text-align:right; + white-space:nowrap; + border:1px inset gray; + padding:3px 5px 3px 10px; +} +span.mngl { + padding-left:1em; + font-size:0.875em; + cursor:text; + color:#444444; + font-weight:bold; +} +span.pleft { + padding-left:2.5em; +} +span.sym_ver { + color:#333333; + white-space:nowrap; + font-family:"DejaVu Sans Mono", Monospace; +} +span.attr { + color:#333333; + font-weight:normal; +} +span.color_p { + font-style:italic; + color:Brown; +} +span.p { + font-style:italic; +} +span.fp { + font-style:italic; + background-color:#DCDCDC; +} +span.ttype { + font-weight:normal; +} +span.nowrap { + white-space:nowrap; +} +span.value { + font-weight:bold; +} +.passed { + background-color:#CCFFCC; + font-weight:normal; +} +.warning { + background-color:#F4F4AF; + font-weight:normal; +} +.failed { + background-color:#FFCCCC; + font-weight:normal; +} +.new { + background-color:#C6DEFF; + font-weight:normal; +} +.compatible { + background-color:#CCFFCC; + font-weight:normal; +} +.almost_compatible { + background-color:#FFDAA3; + font-weight:normal; +} +.incompatible { + background-color:#FFCCCC; + font-weight:normal; +} +.gray { + background-color:#DCDCDC; + font-weight:normal; +} +.top_ref { + font-size:0.69em; +} +.footer { + font-size:0.75em; +} + +.tabset { + float:left; +} +a.tab { + border:1px solid Black; + float:left; + margin:0px 5px -1px 0px; + padding:3px 5px 3px 5px; + position:relative; + font-size:0.875em; + background-color:#DDD; + text-decoration:none; + color:Black; +} +a.disabled:hover +{ + color:Black; + background:#EEE; +} +a.active:hover +{ + color:Black; + background:White; +} +a.active { + border-bottom-color:White; + background-color:White; +} +div.tab { + border-top:1px solid Black; + padding:0px; + width:100%; + clear:both; +} +</style> +<script type="text/javascript" language="JavaScript"> +<!-- +function showContent(header, id) +{ + e = document.getElementById(id); + if(e.style.display == 'none') + { + e.style.display = 'block'; + e.style.visibility = 'visible'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[−]"); + } + else + { + e.style.display = 'none'; + e.style.visibility = 'hidden'; + header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi,"[+]"); + } +} +function initTabs() +{ + var url = window.location.href; + if(url.indexOf('_Source_')!=-1 || url.indexOf('#Source')!=-1) + { + var tab1 = document.getElementById('BinaryID'); + var tab2 = document.getElementById('SourceID'); + tab1.className='tab disabled'; + tab2.className='tab active'; + } + var sets = document.getElementsByTagName('div'); + for (var i = 0; i < sets.length; i++) + { + if (sets[i].className.indexOf('tabset') != -1) + { + var tabs = []; + var links = sets[i].getElementsByTagName('a'); + for (var j = 0; j < links.length; j++) + { + if (links[j].className.indexOf('tab') != -1) + { + tabs.push(links[j]); + links[j].tabs = tabs; + var tab = document.getElementById(links[j].href.substr(links[j].href.indexOf('#') + 1)); + //reset all tabs on start + if (tab) + { + if (links[j].className.indexOf('active')!=-1) { + tab.style.display = 'block'; + } + else { + tab.style.display = 'none'; + } + } + links[j].onclick = function() + { + var tab = document.getElementById(this.href.substr(this.href.indexOf('#') + 1)); + if (tab) + { + //reset all tabs before change + for (var k = 0; k < this.tabs.length; k++) + { + document.getElementById(this.tabs[k].href.substr(this.tabs[k].href.indexOf('#') + 1)).style.display = 'none'; + this.tabs[k].className = this.tabs[k].className.replace('active', 'disabled'); + } + this.className = 'tab active'; + tab.style.display = 'block'; + // window.location.hash = this.id.replace('ID', ''); + return false; + } + } + } + } + } + } + if(url.indexOf('#')!=-1) { + location.href=location.href; + } +} +if (window.addEventListener) window.addEventListener('load', initTabs, false); +else if (window.attachEvent) window.attachEvent('onload', initTabs); +--> +</script> +</head> +<body><a name='Source'></a><a name='Binary'></a><a name='Top'></a><h1>API compatibility report for the <span style='color:Blue;'>libsodium</span> library between <span style='color:Red;'>1.0.16</span> and <span style='color:Red;'>1.0.17</span> versions on <span style='color:Blue;'>x86_64</span></h1> + + <br/> + <div class='tabset'> + <a id='BinaryID' href='#BinaryTab' class='tab active'>Binary<br/>Compatibility</a> + <a id='SourceID' href='#SourceTab' style='margin-left:3px' class='tab disabled'>Source<br/>Compatibility</a> + </div><div id='BinaryTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>libsodium</td></tr> +<tr><th>Version #1</th><td>1.0.16</td></tr> +<tr><th>Version #2</th><td>1.0.17</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>GCC Version</th><td>8</td></tr> +<tr><th>Subject</th><td width='150px'>Binary Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>61</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>579 / 50</td></tr> +<tr><th>Compatibility</th> +<td class='warning'>99%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td class='new'><a href='#Binary_Added' style='color:Blue;'>12</a></td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td class='failed'><a href='#Type_Binary_Problems_Medium' style='color:Blue;'>7</a></td></tr> +<tr><td>Low</td><td class='warning'><a href='#Type_Binary_Problems_Low' style='color:Blue;'>1</a></td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td class='warning'><a href='#Symbol_Binary_Problems_Low' style='color:Blue;'>2</a></td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td>0</td></tr> +<tr><th>Other Changes<br/>in Constants</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Constants' style='color:Blue;'>2</a></td></tr> +</table> + +<a name='Binary_Added'></a><h2>Added Symbols <span class='new'> 12 </span></h2><hr/> +<span class='h_name'>crypto_core_ed25519.h</span>, <span class='lib_name'>libsodium.so.23.2.0</span><br/> +<span class="iname">crypto_core_ed25519_nonreducedscalarbytes <span class='sym_p'>( )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_add <span class='sym_p'><span>( unsigned char* <span class='color_p'>z</span></span>, <span>unsigned char const* <span class='color_p'>x</span></span>, <span>unsigned char const* <span class='color_p'>y</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_complement <span class='sym_p'><span>( unsigned char* <span class='color_p'>comp</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_invert <span class='sym_p'><span>( unsigned char* <span class='color_p'>recip</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_negate <span class='sym_p'><span>( unsigned char* <span class='color_p'>neg</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_random <span class='sym_p'><span>( unsigned char* <span class='color_p'>r</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_reduce <span class='sym_p'><span>( unsigned char* <span class='color_p'>r</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_sub <span class='sym_p'><span>( unsigned char* <span class='color_p'>z</span></span>, <span>unsigned char const* <span class='color_p'>x</span></span>, <span>unsigned char const* <span class='color_p'>y</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalarbytes <span class='sym_p'>( )</span></span><br/> +<br/> +<span class='h_name'>crypto_scalarmult_ed25519.h</span>, <span class='lib_name'>libsodium.so.23.2.0</span><br/> +<span class="iname">crypto_scalarmult_ed25519_base_noclamp <span class='sym_p'><span>( unsigned char* <span class='color_p'>q</span></span>, <span>unsigned char const* <span class='color_p'>n</span></span> )</span></span><br/> +<span class="iname">crypto_scalarmult_ed25519_noclamp <span class='sym_p'><span>( unsigned char* <span class='color_p'>q</span></span>, <span>unsigned char const* <span class='color_p'>n</span></span>, <span>unsigned char const* <span class='color_p'>p</span></span> )</span></span><br/> +<br/> +<span class='h_name'>utils.h</span>, <span class='lib_name'>libsodium.so.23.2.0</span><br/> +<span class="iname">sodium_sub <span class='sym_p'><span>( unsigned char* <span class='color_p'>a</span></span>, <span>unsigned char const* <span class='color_p'>b</span></span>, <span>size_t const <span class='color_p'>len</span></span> )</span></span><br/> +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Medium_Risk_Binary_Problems'></a><a name='Type_Binary_Problems_Medium'></a> +<h2>Problems with Data Types, Medium Severity <span class='failed'> 7 </span></h2><hr/> +<span class='h_name'>crypto_aead_aes256gcm.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_1')"> +<span class='ext'>[+]</span> <span class='ttype'>typedef</span> crypto_aead_aes256gcm_state <span class='failed'> 1 </span></span> +<br/> +<div id="c_1" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Base type has been changed from <span class='value'>unsigned char[512]</span> to <span class='value'>struct crypto_aead_aes256gcm_state_</span> of different format.</td> +<td>The fields or parameters of such data type may be incorrectly initialized or accessed by old client applications.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_2')"> +[+] affected symbols: 5 (0.9%)</span> +<div id="c_2" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_aead_aes256gcm_beforenm <span class='sym_p'><span>( unsigned char[512]* <span class='fp'>ctx_</span></span>, <span>unsigned char const* <i>k</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_decrypt_afternm <span class='sym_p'><span>( unsigned char* <i>m</i></span>, <span>unsigned long long* <i>mlen_p</i></span>, <span>unsigned char* <i>nsec</i></span>, <span>unsigned char const* <i>c</i></span>, <span>unsigned long long <i>clen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_decrypt_detached_afternm <span class='sym_p'><span>( unsigned char* <i>m</i></span>, <span>unsigned char* <i>nsec</i></span>, <span>unsigned char const* <i>c</i></span>, <span>unsigned long long <i>clen</i></span>, <span>unsigned char const* <i>mac</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_encrypt_afternm <span class='sym_p'><span>( unsigned char* <i>c</i></span>, <span>unsigned long long* <i>clen_p</i></span>, <span>unsigned char const* <i>m</i></span>, <span>unsigned long long <i>mlen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>nsec</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_encrypt_detached_afternm <span class='sym_p'><span>( unsigned char* <i>c</i></span>, <span>unsigned char* <i>mac</i></span>, <span>unsigned long long* <i>maclen_p</i></span>, <span>unsigned char const* <i>m</i></span>, <span>unsigned long long <i>mlen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>nsec</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>10th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<span class='h_name'>crypto_generichash_blake2b.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_3')"> +<span class='ext'>[+]</span> <span class='ttype'>struct</span> crypto_generichash_blake2b_state <span class='failed'> 6 </span></span> +<br/> +<div id="c_3" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Field <b>buf</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +<tr> +<th>2</th> +<td>Field <b>buflen</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +<tr> +<th>3</th> +<td>Field <b>f</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +<tr> +<th>4</th> +<td>Field <b>h</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +<tr> +<th>5</th> +<td>Field <b>last_node</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +<tr> +<th>6</th> +<td>Field <b>t</b> has been removed from this type.</td> +<td>Applications will access incorrect memory when attempting to access this field.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_4')"> +[+] affected symbols: 7 (1.2%)</span> +<div id="c_4" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_generichash_blake2b_final <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init_salt_personal <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span>, <span>unsigned char const* <i>salt</i></span>, <span>unsigned char const* <i>personal</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_update <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_final <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_init <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_update <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Low_Risk_Binary_Problems'></a><a name='Type_Binary_Problems_Low'></a> +<h2>Problems with Data Types, Low Severity <span class='warning'> 1 </span></h2><hr/> +<span class='h_name'>crypto_generichash_blake2b.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_5')"> +<span class='ext'>[+]</span> <span class='ttype'>struct</span> crypto_generichash_blake2b_state <span class='warning'> 1 </span></span> +<br/> +<div id="c_5" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Field <b>opaque</b> has been added to this type.</td> +<td>This field will not be initialized by old clients.<br/><br/><b>NOTE</b>: this field should be accessed only from the new library functions, otherwise it may result in crash or incorrect behavior of applications.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_6')"> +[+] affected symbols: 7 (1.2%)</span> +<div id="c_6" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_generichash_blake2b_final <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init_salt_personal <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span>, <span>unsigned char const* <i>salt</i></span>, <span>unsigned char const* <i>personal</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_update <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_final <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_init <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_update <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Symbol_Binary_Problems_Low'></a><a name='Interface_Binary_Problems_Low'></a> +<h2>Problems with Symbols, Low Severity <span class='warning'> 2 </span></h2><hr/> +<span class='h_name'>crypto_sign.h</span>, <span class='lib_name'>libsodium.so.23.1.0</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_7')"> +<span class='ext'>[+]</span> crypto_sign_final_verify <span class='sym_p'><span>( crypto_sign_state* <span class='color_p'>state</span></span>, <span>unsigned char* <span class='color_p'>sig</span></span>, <span>unsigned char const* <span class='color_p'>pk</span></span> )</span> <span class='warning'> 1 </span></span> +<br/> +<div id="c_7" style="display:none;"> + + +<span class='new_sign_lbl'>⇣</span> +<br/> +<span class='new_sign'>crypto_sign_final_verify <span class='sym_p'><span>( crypto_sign_state* <span class='color_p'>state</span></span>, <span>unsigned char const* <span class='color_p'>sig</span></span>, <span>unsigned char const* <span class='color_p'>pk</span></span> )</span></span><br/> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>Type of <b>2nd</b> parameter <b>sig</b> has been changed from <span class='value'>unsigned char*</span> to <span class='value'>unsigned char const*</span>.</td> +<td>Replacement of parameter data type may indicate a change in its semantic meaning.</td> +</tr> +</table> +<br/> +</div> +<br/> +<span class='h_name'>crypto_sign_ed25519.h</span>, <span class='lib_name'>libsodium.so.23.1.0</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_8')"> +<span class='ext'>[+]</span> crypto_sign_ed25519ph_final_verify <span class='sym_p'><span>( crypto_sign_ed25519ph_state* <span class='color_p'>state</span></span>, <span>unsigned char* <span class='color_p'>sig</span></span>, <span>unsigned char const* <span class='color_p'>pk</span></span> )</span> <span class='warning'> 1 </span></span> +<br/> +<div id="c_8" style="display:none;"> + + +<span class='new_sign_lbl'>⇣</span> +<br/> +<span class='new_sign'>crypto_sign_ed25519ph_final_verify <span class='sym_p'><span>( crypto_sign_ed25519ph_state* <span class='color_p'>state</span></span>, <span>unsigned char const* <span class='color_p'>sig</span></span>, <span>unsigned char const* <span class='color_p'>pk</span></span> )</span></span><br/> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>Type of <b>2nd</b> parameter <b>sig</b> has been changed from <span class='value'>unsigned char*</span> to <span class='value'>unsigned char const*</span>.</td> +<td>Replacement of parameter data type may indicate a change in its semantic meaning.</td> +</tr> +</table> +<br/> +</div> +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Binary_Changes'></a><a name='Other_Binary_Changes_In_Constants'></a> +<h2>Other Changes in Constants <span class='passed'> 2 </span></h2><hr/> +<span class='h_name'>crypto_core_ed25519.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_9')"> +<span class='ext'>[+]</span> crypto_core_ed25519_NONREDUCEDSCALARBYTES</span> +<br/> +<div id="c_9" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>crypto_core_ed25519_NONREDUCEDSCALARBYTES</b> with value <b>64</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<span class="section" onclick="javascript:showContent(this, 'c_10')"> +<span class='ext'>[+]</span> crypto_core_ed25519_SCALARBYTES</span> +<br/> +<div id="c_10" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>crypto_core_ed25519_SCALARBYTES</b> with value <b>32</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Headers'></a><h2>Header Files <span class='gray'> 61 </span></h2><hr/> +<div class='h_list'> +core.h<br/> +crypto_aead_aes256gcm.h<br/> +crypto_aead_chacha20poly1305.h<br/> +crypto_aead_xchacha20poly1305.h<br/> +crypto_auth.h<br/> +crypto_auth_hmacsha256.h<br/> +crypto_auth_hmacsha512.h<br/> +crypto_auth_hmacsha512256.h<br/> +crypto_box.h<br/> +crypto_box_curve25519xchacha20poly1305.h<br/> +crypto_box_curve25519xsalsa20poly1305.h<br/> +crypto_core_ed25519.h<br/> +crypto_core_hchacha20.h<br/> +crypto_core_hsalsa20.h<br/> +crypto_core_salsa20.h<br/> +crypto_core_salsa2012.h<br/> +crypto_core_salsa208.h<br/> +crypto_generichash.h<br/> +crypto_generichash_blake2b.h<br/> +crypto_hash.h<br/> +crypto_hash_sha256.h<br/> +crypto_hash_sha512.h<br/> +crypto_kdf.h<br/> +crypto_kdf_blake2b.h<br/> +crypto_kx.h<br/> +crypto_onetimeauth.h<br/> +crypto_onetimeauth_poly1305.h<br/> +crypto_pwhash.h<br/> +crypto_pwhash_argon2i.h<br/> +crypto_pwhash_argon2id.h<br/> +crypto_pwhash_scryptsalsa208sha256.h<br/> +crypto_scalarmult.h<br/> +crypto_scalarmult_curve25519.h<br/> +crypto_scalarmult_ed25519.h<br/> +crypto_secretbox.h<br/> +crypto_secretbox_xchacha20poly1305.h<br/> +crypto_secretbox_xsalsa20poly1305.h<br/> +crypto_secretstream_xchacha20poly1305.h<br/> +crypto_shorthash.h<br/> +crypto_shorthash_siphash24.h<br/> +crypto_sign.h<br/> +crypto_sign_ed25519.h<br/> +crypto_sign_edwards25519sha512batch.h<br/> +crypto_stream.h<br/> +crypto_stream_chacha20.h<br/> +crypto_stream_salsa20.h<br/> +crypto_stream_salsa2012.h<br/> +crypto_stream_salsa208.h<br/> +crypto_stream_xchacha20.h<br/> +crypto_stream_xsalsa20.h<br/> +crypto_verify_16.h<br/> +crypto_verify_32.h<br/> +crypto_verify_64.h<br/> +export.h<br/> +randombytes.h<br/> +randombytes_salsa20_random.h<br/> +randombytes_sysrandom.h<br/> +runtime.h<br/> +sodium.h<br/> +utils.h<br/> +version.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +libsodium.so.23.1.0<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><div id='SourceTab' class='tab'> +<h2>Test Info</h2><hr/> +<table class='summary'> +<tr><th>Library Name</th><td>libsodium</td></tr> +<tr><th>Version #1</th><td>1.0.16</td></tr> +<tr><th>Version #2</th><td>1.0.17</td></tr> +<tr><th>Arch</th><td>x86_64</td></tr> +<tr><th>Subject</th><td width='150px'>Source Compatibility</td></tr> +</table> +<h2>Test Results</h2><hr/> +<table class='summary'><tr><th>Total Header Files</th><td><a href='#Headers' style='color:Blue;'>61</a></td></tr> +<tr><th>Total Libraries</th><td><a href='#Libs' style='color:Blue;'>1</a></td></tr> +<tr><th>Total Symbols / Types</th><td>828 / 102</td></tr> +<tr><th>Compatibility</th> +<td class='warning'>99.2%</td> +</tr> +</table> +<h2>Problem Summary</h2><hr/> +<table class='summary'><tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr><tr><th>Added Symbols</th><td>-</td><td class='new'><a href='#Source_Added' style='color:Blue;'>12</a></td></tr> +<tr><th>Removed Symbols</th><td>High</td><td>0</td></tr> +<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td class='failed'><a href='#Type_Source_Problems_High' style='color:Blue;'>6</a></td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td class='warning'><a href='#Type_Source_Problems_Low' style='color:Blue;'>2</a></td></tr> +<tr><th rowspan='3'>Problems with<br/>Symbols</th><td>High</td><td>0</td></tr> +<tr><td>Medium</td><td>0</td></tr> +<tr><td>Low</td><td>0</td></tr> +<tr><th>Problems with<br/>Constants</th><td>Low</td><td class='warning'><a href='#Constant_Source_Problems_Low' style='color:Blue;'>6</a></td></tr> +<tr><th>Other Changes<br/>in Constants</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Constants' style='color:Blue;'>2</a></td></tr> +</table> + +<a name='Source_Added'></a><h2>Added Symbols <span class='new'> 12 </span></h2><hr/> +<span class='h_name'>crypto_core_ed25519.h</span><br/> +<span class="iname">crypto_core_ed25519_nonreducedscalarbytes <span class='sym_p'>( )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_add <span class='sym_p'><span>( unsigned char* <span class='color_p'>z</span></span>, <span>unsigned char const* <span class='color_p'>x</span></span>, <span>unsigned char const* <span class='color_p'>y</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_complement <span class='sym_p'><span>( unsigned char* <span class='color_p'>comp</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_invert <span class='sym_p'><span>( unsigned char* <span class='color_p'>recip</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_negate <span class='sym_p'><span>( unsigned char* <span class='color_p'>neg</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_random <span class='sym_p'><span>( unsigned char* <span class='color_p'>r</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_reduce <span class='sym_p'><span>( unsigned char* <span class='color_p'>r</span></span>, <span>unsigned char const* <span class='color_p'>s</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalar_sub <span class='sym_p'><span>( unsigned char* <span class='color_p'>z</span></span>, <span>unsigned char const* <span class='color_p'>x</span></span>, <span>unsigned char const* <span class='color_p'>y</span></span> )</span></span><br/> +<span class="iname">crypto_core_ed25519_scalarbytes <span class='sym_p'>( )</span></span><br/> +<br/> +<span class='h_name'>crypto_scalarmult_ed25519.h</span><br/> +<span class="iname">crypto_scalarmult_ed25519_base_noclamp <span class='sym_p'><span>( unsigned char* <span class='color_p'>q</span></span>, <span>unsigned char const* <span class='color_p'>n</span></span> )</span></span><br/> +<span class="iname">crypto_scalarmult_ed25519_noclamp <span class='sym_p'><span>( unsigned char* <span class='color_p'>q</span></span>, <span>unsigned char const* <span class='color_p'>n</span></span>, <span>unsigned char const* <span class='color_p'>p</span></span> )</span></span><br/> +<br/> +<span class='h_name'>utils.h</span><br/> +<span class="iname">sodium_sub <span class='sym_p'><span>( unsigned char* <span class='color_p'>a</span></span>, <span>unsigned char const* <span class='color_p'>b</span></span>, <span>size_t const <span class='color_p'>len</span></span> )</span></span><br/> +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='High_Risk_Source_Problems'></a><a name='Type_Source_Problems_High'></a> +<h2>Problems with Data Types, High Severity <span class='failed'> 6 </span></h2><hr/> +<span class='h_name'>crypto_generichash_blake2b.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_11')"> +<span class='ext'>[+]</span> <span class='ttype'>struct</span> crypto_generichash_blake2b_state <span class='failed'> 6 </span></span> +<br/> +<div id="c_11" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Field <b>buf</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>buf</b>'.</td> +</tr> +<tr> +<th>2</th> +<td>Field <b>buflen</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>buflen</b>'.</td> +</tr> +<tr> +<th>3</th> +<td>Field <b>f</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>f</b>'.</td> +</tr> +<tr> +<th>4</th> +<td>Field <b>h</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>h</b>'.</td> +</tr> +<tr> +<th>5</th> +<td>Field <b>last_node</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>last_node</b>'.</td> +</tr> +<tr> +<th>6</th> +<td>Field <b>t</b> has been removed from this type.</td> +<td>Recompilation of a client program may be broken with the error message: '<span class='value'>struct crypto_generichash_blake2b_state</span>' has no member named '<b>t</b>'.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_12')"> +[+] affected symbols: 7 (0.8%)</span> +<div id="c_12" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_generichash_blake2b_final <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init_salt_personal <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span>, <span>unsigned char const* <i>salt</i></span>, <span>unsigned char const* <i>personal</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_update <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_final <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_init <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_update <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Low_Risk_Source_Problems'></a><a name='Type_Source_Problems_Low'></a> +<h2>Problems with Data Types, Low Severity <span class='warning'> 2 </span></h2><hr/> +<span class='h_name'>crypto_aead_aes256gcm.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_13')"> +<span class='ext'>[+]</span> <span class='ttype'>typedef</span> crypto_aead_aes256gcm_state <span class='warning'> 1 </span></span> +<br/> +<div id="c_13" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Base type has been changed from <span class='value'>unsigned char[512]</span> to <span class='value'>struct crypto_aead_aes256gcm_state_</span> of different format.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_14')"> +[+] affected symbols: 5 (0.6%)</span> +<div id="c_14" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_aead_aes256gcm_beforenm <span class='sym_p'><span>( unsigned char[512]* <span class='fp'>ctx_</span></span>, <span>unsigned char const* <i>k</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_decrypt_afternm <span class='sym_p'><span>( unsigned char* <i>m</i></span>, <span>unsigned long long* <i>mlen_p</i></span>, <span>unsigned char* <i>nsec</i></span>, <span>unsigned char const* <i>c</i></span>, <span>unsigned long long <i>clen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_decrypt_detached_afternm <span class='sym_p'><span>( unsigned char* <i>m</i></span>, <span>unsigned char* <i>nsec</i></span>, <span>unsigned char const* <i>c</i></span>, <span>unsigned long long <i>clen</i></span>, <span>unsigned char const* <i>mac</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_encrypt_afternm <span class='sym_p'><span>( unsigned char* <i>c</i></span>, <span>unsigned long long* <i>clen_p</i></span>, <span>unsigned char const* <i>m</i></span>, <span>unsigned long long <i>mlen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>nsec</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>9th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +<span class='iname_a'>crypto_aead_aes256gcm_encrypt_detached_afternm <span class='sym_p'><span>( unsigned char* <i>c</i></span>, <span>unsigned char* <i>mac</i></span>, <span>unsigned long long* <i>maclen_p</i></span>, <span>unsigned char const* <i>m</i></span>, <span>unsigned long long <i>mlen</i></span>, <span>unsigned char const* <i>ad</i></span>, <span>unsigned long long <i>adlen</i></span>, <span>unsigned char const* <i>nsec</i></span>, <span>unsigned char const* <i>npub</i></span>, <span>unsigned char[512] const* <span class='fp'>ctx_</span></span> )</span></span><br/> +<div class='affect'>10th parameter 'ctx_' (pointer) has base type 'crypto_aead_aes256gcm_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<span class='h_name'>crypto_generichash_blake2b.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_15')"> +<span class='ext'>[+]</span> <span class='ttype'>struct</span> crypto_generichash_blake2b_state <span class='warning'> 1 </span></span> +<br/> +<div id="c_15" style="display:none;"> +<table class='ptable'><tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th></tr><tr> +<th>1</th> +<td>Field <b>opaque</b> has been added to this type.</td> +<td>This field will not be initialized or used by old client applications.</td> +</tr> +</table> +<span class="sect_aff" onclick="javascript:showContent(this, 'c_16')"> +[+] affected symbols: 7 (0.8%)</span> +<div id="c_16" style="display:none;"> +<div class='affected'><span class='iname_a'>crypto_generichash_blake2b_final <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_init_salt_personal <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span>, <span>unsigned char const* <i>salt</i></span>, <span>unsigned char const* <i>personal</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_blake2b_update <span class='sym_p'><span>( crypto_generichash_blake2b_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_final <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char* <i>out</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_init <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>key</i></span>, <span>size_t const <i>keylen</i></span>, <span>size_t const <i>outlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +<span class='iname_a'>crypto_generichash_update <span class='sym_p'><span>( crypto_generichash_state* <span class='fp'>state</span></span>, <span>unsigned char const* <i>in</i></span>, <span>unsigned long long <i>inlen</i></span> )</span></span><br/> +<div class='affect'>1st parameter 'state' (pointer) has base type 'struct crypto_generichash_blake2b_state'.</div> +</div> +</div> +<br/><br/></div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Constant_Source_Problems_Low'></a> +<h2>Problems with Constants, Low Severity <span class='warning'> 6 </span></h2><hr/> +<span class='h_name'>crypto_aead_aes256gcm.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_17')"> +<span class='ext'>[+]</span> crypto_aead_aes256gcm_MESSAGEBYTES_MAX</span> +<br/> +<div id="c_17" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>crypto_aead_aes256gcm_MESSAGEBYTES_MAX</b> has been changed from <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_aes256gcm_ABYTES, (16ULL * ((1ULL << 32) - 2ULL)) - crypto_aead_aes256gcm_ABYTES)</span> to <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_aes256gcm_ABYTES, (16ULL * ((1ULL << 32) - 2ULL)))</span>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<span class='h_name'>crypto_aead_chacha20poly1305.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_18')"> +<span class='ext'>[+]</span> crypto_aead_chacha20poly1305_ietf_MESSAGEBYTES_MAX</span> +<br/> +<div id="c_18" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>crypto_aead_chacha20poly1305_ietf_MESSAGEBYTES_MAX</b> has been changed from <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_chacha20poly1305_ietf_ABYTES, (64ULL * (1ULL << 32) - 64ULL) - crypto_aead_chacha20poly1305_ietf_ABYTES)</span> to <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_chacha20poly1305_ietf_ABYTES, (64ULL * ((1ULL << 32) - 1ULL)))</span>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<span class="section" onclick="javascript:showContent(this, 'c_19')"> +<span class='ext'>[+]</span> crypto_aead_chacha20poly1305_IETF_MESSAGEBYTES_MAX</span> +<br/> +<div id="c_19" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>crypto_aead_chacha20poly1305_IETF_MESSAGEBYTES_MAX</b> has been changed from <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_chacha20poly1305_ietf_ABYTES, (64ULL * (1ULL << 32) - 64ULL) - crypto_aead_chacha20poly1305_ietf_ABYTES)</span> to <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_chacha20poly1305_ietf_ABYTES, (64ULL * ((1ULL << 32) - 1ULL)))</span>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<span class='h_name'>crypto_secretstream_xchacha20poly1305.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_20')"> +<span class='ext'>[+]</span> crypto_secretstream_xchacha20poly1305_MESSAGEBYTES_MAX</span> +<br/> +<div id="c_20" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>crypto_secretstream_xchacha20poly1305_MESSAGEBYTES_MAX</b> has been changed from <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX, ((1ULL << 32) - 2ULL) * 64ULL)</span> to <span class='value'>SODIUM_MIN(SODIUM_SIZE_MAX - crypto_secretstream_xchacha20poly1305_ABYTES, (64ULL * ((1ULL << 32) - 2ULL)))</span>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<span class='h_name'>version.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_21')"> +<span class='ext'>[+]</span> SODIUM_LIBRARY_VERSION_MINOR</span> +<br/> +<div id="c_21" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>SODIUM_LIBRARY_VERSION_MINOR</b> has been changed from <b>1</b> to <b>2</b>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<span class="section" onclick="javascript:showContent(this, 'c_22')"> +<span class='ext'>[+]</span> SODIUM_VERSION_STRING</span> +<br/> +<div id="c_22" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The value of constant <b>SODIUM_VERSION_STRING</b> has been changed from <b>"1.0.16"</b> to <b>"1.0.17"</b>.</td> +<td>Recompilation of a client program may be broken.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Other_Source_Changes'></a><a name='Other_Source_Changes_In_Constants'></a> +<h2>Other Changes in Constants <span class='passed'> 2 </span></h2><hr/> +<span class='h_name'>crypto_core_ed25519.h</span><br/> +<span class="section" onclick="javascript:showContent(this, 'c_23')"> +<span class='ext'>[+]</span> crypto_core_ed25519_NONREDUCEDSCALARBYTES</span> +<br/> +<div id="c_23" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>crypto_core_ed25519_NONREDUCEDSCALARBYTES</b> with value <b>64</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<span class="section" onclick="javascript:showContent(this, 'c_24')"> +<span class='ext'>[+]</span> crypto_core_ed25519_SCALARBYTES</span> +<br/> +<div id="c_24" style="display:none;"> +<table class='ptable'> +<tr> +<th class='pn'></th> +<th class='chg'>Change</th> +<th>Effect</th> +</tr> +<tr> +<th>1</th> +<td>The constant <b>crypto_core_ed25519_SCALARBYTES</b> with value <b>32</b> has been added.</td> +<td>No effect.</td> +</tr> +</table> +<br/> +</div> + +<br/> +<a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Headers'></a><h2>Header Files <span class='gray'> 61 </span></h2><hr/> +<div class='h_list'> +core.h<br/> +crypto_aead_aes256gcm.h<br/> +crypto_aead_chacha20poly1305.h<br/> +crypto_aead_xchacha20poly1305.h<br/> +crypto_auth.h<br/> +crypto_auth_hmacsha256.h<br/> +crypto_auth_hmacsha512.h<br/> +crypto_auth_hmacsha512256.h<br/> +crypto_box.h<br/> +crypto_box_curve25519xchacha20poly1305.h<br/> +crypto_box_curve25519xsalsa20poly1305.h<br/> +crypto_core_ed25519.h<br/> +crypto_core_hchacha20.h<br/> +crypto_core_hsalsa20.h<br/> +crypto_core_salsa20.h<br/> +crypto_core_salsa2012.h<br/> +crypto_core_salsa208.h<br/> +crypto_generichash.h<br/> +crypto_generichash_blake2b.h<br/> +crypto_hash.h<br/> +crypto_hash_sha256.h<br/> +crypto_hash_sha512.h<br/> +crypto_kdf.h<br/> +crypto_kdf_blake2b.h<br/> +crypto_kx.h<br/> +crypto_onetimeauth.h<br/> +crypto_onetimeauth_poly1305.h<br/> +crypto_pwhash.h<br/> +crypto_pwhash_argon2i.h<br/> +crypto_pwhash_argon2id.h<br/> +crypto_pwhash_scryptsalsa208sha256.h<br/> +crypto_scalarmult.h<br/> +crypto_scalarmult_curve25519.h<br/> +crypto_scalarmult_ed25519.h<br/> +crypto_secretbox.h<br/> +crypto_secretbox_xchacha20poly1305.h<br/> +crypto_secretbox_xsalsa20poly1305.h<br/> +crypto_secretstream_xchacha20poly1305.h<br/> +crypto_shorthash.h<br/> +crypto_shorthash_siphash24.h<br/> +crypto_sign.h<br/> +crypto_sign_ed25519.h<br/> +crypto_sign_edwards25519sha512batch.h<br/> +crypto_stream.h<br/> +crypto_stream_chacha20.h<br/> +crypto_stream_salsa20.h<br/> +crypto_stream_salsa2012.h<br/> +crypto_stream_salsa208.h<br/> +crypto_stream_xchacha20.h<br/> +crypto_stream_xsalsa20.h<br/> +crypto_verify_16.h<br/> +crypto_verify_32.h<br/> +crypto_verify_64.h<br/> +export.h<br/> +randombytes.h<br/> +randombytes_salsa20_random.h<br/> +randombytes_sysrandom.h<br/> +runtime.h<br/> +sodium.h<br/> +utils.h<br/> +version.h<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<a name='Libs'></a><h2>Libraries <span class='gray'> 1 </span></h2><hr/> +<div class='lib_list'> +libsodium.so.23.1.0<br/> +</div> +<br/><a class='top_ref' href='#Top'>to the top</a><br/> +<br/><br/><br/></div><hr/> +<div class='footer' align='right'><i>Generated by <a href='https://github.com/lvc/abi-compliance-checker'>ABI Compliance Checker</a> 2.3  </i> +</div> +<br/> + +</body></html> |