summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRemi Collet <remi@remirepo.net>2021-01-27 10:14:42 +0100
committerRemi Collet <remi@remirepo.net>2021-01-27 10:14:42 +0100
commit2cd9604e9b05ac57ee5e11e07544db36b4f89614 (patch)
tree13e0970d0654cdb73bd2e0b277098213ab5a4860
parenta5c119dc317cb5c454bc27fbf27617207f710105 (diff)
update to 1.5.3
use rapidjson
-rw-r--r--compat_reports/1.5.3_to_1.6.0/compat_report.html1105
-rw-r--r--librdkafka.spec6
-rw-r--r--librdkafka.xml2
3 files changed, 1109 insertions, 4 deletions
diff --git a/compat_reports/1.5.3_to_1.6.0/compat_report.html b/compat_reports/1.5.3_to_1.6.0/compat_report.html
new file mode 100644
index 0000000..4fab325
--- /dev/null
+++ b/compat_reports/1.5.3_to_1.6.0/compat_report.html
@@ -0,0 +1,1105 @@
+<!-- kind:binary;verdict:incompatible;affected:0.2;added:29;removed:0;type_problems_high:0;type_problems_medium:1;type_problems_low:1;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:1;changed_constants:1;type_changes_other:14;constant_changes_other:3;tool_version:2.3 -->
+<!-- kind:source;verdict:compatible;affected:0;added:29;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;interface_problems_high:0;interface_problems_medium:0;interface_problems_low:0;changed_constants:2;type_changes_other:16;constant_changes_other:3;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="librdkafka, compatibility, API, ABI, report" />
+<meta name="description" content="API/ABI compatibility report for the librdkafka library between 1.5.3 and 1.6.0 versions" />
+<title>librdkafka: 1.5.3 to 1.6.0 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,"[&minus;]");
+ }
+ 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;'>librdkafka</span> library between <span style='color:Red;'>1.5.3</span> and <span style='color:Red;'>1.6.0</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>librdkafka</td></tr>
+<tr><th>Version #1</th><td>1.5.3</td></tr>
+<tr><th>Version #2</th><td>1.6.0</td></tr>
+<tr><th>Arch</th><td>x86_64</td></tr>
+<tr><th>GCC Version</th><td>10</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;'>1</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>271 / 115</td></tr>
+<tr><th>Compatibility</th>
+<td class='warning'>99.8%</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;'>29</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;'>1</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;'>1</a></td></tr>
+<tr><th>Problems with<br/>Constants</th><td>Low</td><td class='warning'><a href='#Constant_Binary_Problems_Low' style='color:Blue;'>1</a></td></tr>
+<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Binary_Changes_In_Types' style='color:Blue;'>14</a></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;'>3</a></td></tr>
+</table>
+
+<a name='Binary_Added'></a><h2>Added Symbols <span class='new'>&nbsp;29&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span>, <span class='lib_name'>librdkafka.so.101</span><br/>
+<span class="iname">rd_kafka_assignment_lost&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_conf_get_default_topic_conf&#160;<span class='sym_p'><span>(&#160;rd_kafka_conf_t* <span class='color_p'>conf</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_consumer_group_metadata_new_with_genid&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group_id</span></span>, <span>int32_t <span class='color_p'>generation_id</span></span>, <span>char const* <span class='color_p'>member_id</span></span>, <span>char const* <span class='color_p'>group_instance_id</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteConsumerGroupOffsets_t** <span class='color_p'>del_grpoffsets</span></span>, <span>size_t <span class='color_p'>del_grpoffsets_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_t* <span class='color_p'>del_grpoffsets</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_t** <span class='color_p'>del_grpoffsets</span></span>, <span>size_t <span class='color_p'>del_grpoffset_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_new&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_result_groups&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_result_t const* <span class='color_p'>result</span></span>, <span>size_t* <span class='color_p'>cntp</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroup_t* <span class='color_p'>del_group</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroup_t** <span class='color_p'>del_groups</span></span>, <span>size_t <span class='color_p'>del_group_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_new&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroups&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteGroup_t** <span class='color_p'>del_groups</span></span>, <span>size_t <span class='color_p'>del_group_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroups_result_groups&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroups_result_t const* <span class='color_p'>result</span></span>, <span>size_t* <span class='color_p'>cntp</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteRecords_t** <span class='color_p'>del_records</span></span>, <span>size_t <span class='color_p'>del_record_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_t* <span class='color_p'>del_records</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_t** <span class='color_p'>del_records</span></span>, <span>size_t <span class='color_p'>del_record_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_new&#160;<span class='sym_p'><span>(&#160;rd_kafka_topic_partition_list_t const* <span class='color_p'>before_offsets</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_result_offsets&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_result_t const* <span class='color_p'>result</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteConsumerGroupOffsets_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteGroups_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteRecords_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_error&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_name&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_partitions&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_incremental_assign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_incremental_unassign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_queue_yield&#160;<span class='sym_p'><span>(&#160;rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_rebalance_protocol&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_seek_partitions&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t* <span class='color_p'>partitions</span></span>, <span>int <span class='color_p'>timeout_ms</span></span>&#160;)</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'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_1')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_admin_op_t <span class='failed'>&nbsp;1&nbsp;</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>Value of member <b>RD_KAFKA_ADMIN_OP__CNT</b> has been changed from <b>6</b> to <b>9</b>.</td>
+<td>Applications may execute a wrong branch of code in the library and therefore change the behavior.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_2')">
+[+] affected symbols: 1 (0.4%)</span>
+<div id="c_2" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_new&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_admin_op_t <span class='fp'>for_api</span></span>&#160;)</span></span><br/>
+<div class='affect'>2nd parameter &#39;for_api&#39; has base type &#39;enum rd_kafka_admin_op_t&#39;.</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'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_3')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='warning'>&nbsp;1&nbsp;</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>Value of member <b>RD_KAFKA_RESP_ERR_END_ALL</b> has been changed from <b>89</b> to <b>98</b>.</td>
+<td>Applications may execute a wrong branch of code in the library and therefore change the behavior.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_4')">
+[+] affected symbols: 106 (39.1%)</span>
+<div id="c_4" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_set_broker&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int32_t <i>broker_id</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_operation_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_request_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_validate_only&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>true_or_false</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assignment&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;offsets.elems.err&#39; in 2nd parameter &#39;offsets&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_message&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;rkmessage.err&#39; in 2nd parameter &#39;rkmessage&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_queue&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>commit_opaque</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;cb.p1&#39; in 4th parameter &#39;cb&#39; has base type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_committed&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+ <b>...</b>
+<br/>
+</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'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span>, <span class='lib_name'>librdkafka.so.101</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_5')">
+<span class='ext'>[+]</span> rd_kafka_topic_partition_list_find&#160;<span class='sym_p'><span>(&#160;rd_kafka_topic_partition_list_t* <span class='color_p'>rktparlist</span></span>, <span>char const* <span class='color_p'>topic</span></span>, <span>int32_t <span class='color_p'>partition</span></span>&#160;)</span> <span class='warning'>&nbsp;1&nbsp;</span></span>
+<br/>
+<div id="c_5" style="display:none;">
+
+
+<span class='new_sign_lbl'>&#8675;</span>
+<br/>
+<span class='new_sign'>rd_kafka_topic_partition_list_find&#160;<span class='sym_p'><span>(&#160;rd_kafka_topic_partition_list_t const* <span class='color_p'>rktparlist</span></span>, <span>char const* <span class='color_p'>topic</span></span>, <span>int32_t <span class='color_p'>partition</span></span>&#160;)</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>1st</b> parameter <b>rktparlist</b> has been changed from <b>rd_kafka_topic_partition_list_t*</b> to <span class='value'>rd_kafka_topic_partition_list_t 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='Constant_Binary_Problems_Low'></a>
+<h2>Problems with Constants, Low Severity <span class='warning'>&nbsp;1&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_6')">
+<span class='ext'>[+]</span> RD_KAFKA_DEBUG_CONTEXTS</span>
+<br/>
+<div id="c_6" 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>RD_KAFKA_DEBUG_CONTEXTS</b> has been changed from <b>&quot;all,generic,broker,topic,metadata,feature,queue,msg,protocol,cgrp,security,fetch,interceptor,plugin,consumer,admin,eos,mock&quot;</b> to <b>&quot;all,generic,broker,topic,metadata,feature,queue,msg,protocol,cgrp,security,fetch,interceptor,plugin,consumer,admin,eos,mock,assignor,conf&quot;</b>.</td>
+<td>Applications will pass an old value of this constant as the parameter to the new-version library functions, that expect a new one. This may result in crash of incorrect behavior of applications.</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_Types'></a>
+<h2>Other Changes in Data Types <span class='passed'>&nbsp;14&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_7')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_admin_op_t <span class='passed'>&nbsp;3&nbsp;</span></span>
+<br/>
+<div id="c_7" 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 member <b>RD_KAFKA_ADMIN_OP_DELETECONSUMERGROUPOFFSETS</b> with value <b>8</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>The member <b>RD_KAFKA_ADMIN_OP_DELETEGROUPS</b> with value <b>7</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>3</th>
+<td>The member <b>RD_KAFKA_ADMIN_OP_DELETERECORDS</b> with value <b>6</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_8')">
+[+] affected symbols: 1 (0.4%)</span>
+<div id="c_8" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_new&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_admin_op_t <span class='fp'>for_api</span></span>&#160;)</span></span><br/>
+<div class='affect'>2nd parameter &#39;for_api&#39; has base type &#39;enum rd_kafka_admin_op_t&#39;.</div>
+</div>
+</div>
+<br/><br/></div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_9')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='passed'>&nbsp;11&nbsp;</span></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 member <b>RD_KAFKA_RESP_ERR_DUPLICATE_RESOURCE</b> with value <b>92</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_FEATURE_UPDATE_FAILED</b> with value <b>96</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>3</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_INCONSISTENT_VOTER_SET</b> with value <b>94</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>4</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_UPDATE_VERSION</b> with value <b>95</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>5</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_PRINCIPAL_DESERIALIZATION_FAILURE</b> with value <b>97</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>6</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_PRODUCER_FENCED</b> with value <b>90</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>7</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_RESOURCE_NOT_FOUND</b> with value <b>91</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>8</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_THROTTLING_QUOTA_EXCEEDED</b> with value <b>89</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>9</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_UNACCEPTABLE_CREDENTIAL</b> with value <b>93</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>10</th>
+<td>The member <b>RD_KAFKA_RESP_ERR__ASSIGNMENT_LOST</b> with value <b>-142</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>11</th>
+<td>The member <b>RD_KAFKA_RESP_ERR__NOOP</b> with value <b>-141</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_10')">
+[+] affected symbols: 106 (39.1%)</span>
+<div id="c_10" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_set_broker&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int32_t <i>broker_id</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_operation_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_request_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_validate_only&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>true_or_false</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assignment&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;offsets.elems.err&#39; in 2nd parameter &#39;offsets&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_message&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;rkmessage.err&#39; in 2nd parameter &#39;rkmessage&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_queue&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>commit_opaque</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;cb.p1&#39; in 4th parameter &#39;cb&#39; has base type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_committed&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+ <b>...</b>
+<br/>
+</div>
+</div>
+<br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Binary_Changes_In_Constants'></a>
+<h2>Other Changes in Constants <span class='passed'>&nbsp;3&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_11')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETECONSUMERGROUPOFFSETS_RESULT</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>The constant <b>RD_KAFKA_EVENT_DELETECONSUMERGROUPOFFSETS_RESULT</b> with value <b>107</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<br/>
+</div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_12')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETEGROUPS_RESULT</span>
+<br/>
+<div id="c_12" 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>RD_KAFKA_EVENT_DELETEGROUPS_RESULT</b> with value <b>106</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<br/>
+</div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_13')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETERECORDS_RESULT</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>The constant <b>RD_KAFKA_EVENT_DELETERECORDS_RESULT</b> with value <b>105</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'>&nbsp;1&nbsp;</span></h2><hr/>
+<div class='h_list'>
+rdkafka.h<br/>
+</div>
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Libs'></a><h2>Libraries <span class='gray'>&nbsp;1&nbsp;</span></h2><hr/>
+<div class='lib_list'>
+librdkafka.so.101<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>librdkafka</td></tr>
+<tr><th>Version #1</th><td>1.5.3</td></tr>
+<tr><th>Version #2</th><td>1.6.0</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;'>1</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>271 / 115</td></tr>
+<tr><th>Compatibility</th>
+<td class='compatible'>100%</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;'>29</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>0</td></tr>
+<tr><td>Low</td><td>0</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;'>2</a></td></tr>
+<tr><th>Other Changes<br/>in Data Types</th><td>-</td><td class='passed'><a href='#Other_Source_Changes_In_Types' style='color:Blue;'>16</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;'>3</a></td></tr>
+</table>
+
+<a name='Source_Added'></a><h2>Added Symbols <span class='new'>&nbsp;29&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="iname">rd_kafka_assignment_lost&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_conf_get_default_topic_conf&#160;<span class='sym_p'><span>(&#160;rd_kafka_conf_t* <span class='color_p'>conf</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_consumer_group_metadata_new_with_genid&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group_id</span></span>, <span>int32_t <span class='color_p'>generation_id</span></span>, <span>char const* <span class='color_p'>member_id</span></span>, <span>char const* <span class='color_p'>group_instance_id</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteConsumerGroupOffsets_t** <span class='color_p'>del_grpoffsets</span></span>, <span>size_t <span class='color_p'>del_grpoffsets_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_t* <span class='color_p'>del_grpoffsets</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_t** <span class='color_p'>del_grpoffsets</span></span>, <span>size_t <span class='color_p'>del_grpoffset_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_new&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteConsumerGroupOffsets_result_groups&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteConsumerGroupOffsets_result_t const* <span class='color_p'>result</span></span>, <span>size_t* <span class='color_p'>cntp</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroup_t* <span class='color_p'>del_group</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroup_t** <span class='color_p'>del_groups</span></span>, <span>size_t <span class='color_p'>del_group_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroup_new&#160;<span class='sym_p'><span>(&#160;char const* <span class='color_p'>group</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroups&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteGroup_t** <span class='color_p'>del_groups</span></span>, <span>size_t <span class='color_p'>del_group_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteGroups_result_groups&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteGroups_result_t const* <span class='color_p'>result</span></span>, <span>size_t* <span class='color_p'>cntp</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_DeleteRecords_t** <span class='color_p'>del_records</span></span>, <span>size_t <span class='color_p'>del_record_cnt</span></span>, <span>rd_kafka_AdminOptions_t const* <span class='color_p'>options</span></span>, <span>rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_destroy&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_t* <span class='color_p'>del_records</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_destroy_array&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_t** <span class='color_p'>del_records</span></span>, <span>size_t <span class='color_p'>del_record_cnt</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_new&#160;<span class='sym_p'><span>(&#160;rd_kafka_topic_partition_list_t const* <span class='color_p'>before_offsets</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_DeleteRecords_result_offsets&#160;<span class='sym_p'><span>(&#160;rd_kafka_DeleteRecords_result_t const* <span class='color_p'>result</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteConsumerGroupOffsets_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteGroups_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_event_DeleteRecords_result&#160;<span class='sym_p'><span>(&#160;rd_kafka_event_t* <span class='color_p'>rkev</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_error&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_name&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_group_result_partitions&#160;<span class='sym_p'><span>(&#160;rd_kafka_group_result_t const* <span class='color_p'>groupres</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_incremental_assign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_incremental_unassign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t const* <span class='color_p'>partitions</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_queue_yield&#160;<span class='sym_p'><span>(&#160;rd_kafka_queue_t* <span class='color_p'>rkqu</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_rebalance_protocol&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>&#160;)</span></span><br/>
+<span class="iname">rd_kafka_seek_partitions&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <span class='color_p'>rk</span></span>, <span>rd_kafka_topic_partition_list_t* <span class='color_p'>partitions</span></span>, <span>int <span class='color_p'>timeout_ms</span></span>&#160;)</span></span><br/>
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Low_Risk_Source_Problems'></a><a name='Constant_Source_Problems_Low'></a>
+<h2>Problems with Constants, Low Severity <span class='warning'>&nbsp;2&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_14')">
+<span class='ext'>[+]</span> RD_KAFKA_DEBUG_CONTEXTS</span>
+<br/>
+<div id="c_14" 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>RD_KAFKA_DEBUG_CONTEXTS</b> has been changed from <b>&quot;all,generic,broker,topic,metadata,feature,queue,msg,protocol,cgrp,security,fetch,interceptor,plugin,consumer,admin,eos,mock&quot;</b> to <b>&quot;all,generic,broker,topic,metadata,feature,queue,msg,protocol,cgrp,security,fetch,interceptor,plugin,consumer,admin,eos,mock,assignor,conf&quot;</b>.</td>
+<td>Recompilation of a client program may be broken.</td>
+</tr>
+</table>
+<br/>
+</div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_15')">
+<span class='ext'>[+]</span> RD_KAFKA_VERSION</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>The value of constant <b>RD_KAFKA_VERSION</b> has been changed from <b>0x010503ff</b> to <b>0x010600ff</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_Types'></a>
+<h2>Other Changes in Data Types <span class='passed'>&nbsp;16&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_16')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_admin_op_t <span class='passed'>&nbsp;4&nbsp;</span></span>
+<br/>
+<div id="c_16" 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 member <b>RD_KAFKA_ADMIN_OP_DELETECONSUMERGROUPOFFSETS</b> with value <b>8</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>The member <b>RD_KAFKA_ADMIN_OP_DELETEGROUPS</b> with value <b>7</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>3</th>
+<td>The member <b>RD_KAFKA_ADMIN_OP_DELETERECORDS</b> with value <b>6</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>4</th>
+<td>Value of member <b>RD_KAFKA_ADMIN_OP__CNT</b> has been changed from <b>6</b> to <b>9</b>.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_17')">
+[+] affected symbols: 1 (0.4%)</span>
+<div id="c_17" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_new&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_admin_op_t <span class='fp'>for_api</span></span>&#160;)</span></span><br/>
+<div class='affect'>2nd parameter &#39;for_api&#39; has base type &#39;enum rd_kafka_admin_op_t&#39;.</div>
+</div>
+</div>
+<br/><br/></div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_18')">
+<span class='ext'>[+]</span> <span class='ttype'>enum</span> rd_kafka_resp_err_t <span class='passed'>&nbsp;12&nbsp;</span></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 member <b>RD_KAFKA_RESP_ERR_DUPLICATE_RESOURCE</b> with value <b>92</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>2</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_FEATURE_UPDATE_FAILED</b> with value <b>96</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>3</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_INCONSISTENT_VOTER_SET</b> with value <b>94</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>4</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_INVALID_UPDATE_VERSION</b> with value <b>95</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>5</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_PRINCIPAL_DESERIALIZATION_FAILURE</b> with value <b>97</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>6</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_PRODUCER_FENCED</b> with value <b>90</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>7</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_RESOURCE_NOT_FOUND</b> with value <b>91</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>8</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_THROTTLING_QUOTA_EXCEEDED</b> with value <b>89</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>9</th>
+<td>The member <b>RD_KAFKA_RESP_ERR_UNACCEPTABLE_CREDENTIAL</b> with value <b>93</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>10</th>
+<td>The member <b>RD_KAFKA_RESP_ERR__ASSIGNMENT_LOST</b> with value <b>-142</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>11</th>
+<td>The member <b>RD_KAFKA_RESP_ERR__NOOP</b> with value <b>-141</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+<tr>
+<th>12</th>
+<td>Value of member <b>RD_KAFKA_RESP_ERR_END_ALL</b> has been changed from <b>89</b> to <b>98</b>.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<span class="sect_aff" onclick="javascript:showContent(this, 'c_19')">
+[+] affected symbols: 106 (39.1%)</span>
+<div id="c_19" style="display:none;">
+<div class='affected'><span class='iname_a'>rd_kafka_AdminOptions_set_broker&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int32_t <i>broker_id</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_operation_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_request_timeout&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>timeout_ms</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_AdminOptions_set_validate_only&#160;<span class='sym_p'><span>(&#160;rd_kafka_AdminOptions_t* <i>options</i></span>, <span>int <i>true_or_false</i></span>, <span>char* <i>errstr</i></span>, <span>size_t <i>errstr_size</i></span>&#160;)</span></span><br/>
+<div class='affect'>Return value is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assign&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_assignment&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t** <span class='fp'>partitions</span></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <span class='fp'>offsets</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;offsets.elems.err&#39; in 2nd parameter &#39;offsets&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_message&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_message_t const* <span class='fp'>rkmessage</span></span>, <span>int <i>async</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;rkmessage.err&#39; in 2nd parameter &#39;rkmessage&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_commit_queue&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t const* <i>offsets</i></span>, <span>rd_kafka_queue_t* <i>rkqu</i></span>, <span>void(*<span class='fp'>cb</span>)(rd_kafka_t*, enum rd_kafka_resp_err_t, rd_kafka_topic_partition_list_t*, void*)</span>, <span>void* <i>commit_opaque</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;cb.p1&#39; in 4th parameter &#39;cb&#39; has base type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+<span class='iname_a'>rd_kafka_committed&#160;<span class='sym_p'><span>(&#160;rd_kafka_t* <i>rk</i></span>, <span>rd_kafka_topic_partition_list_t* <span class='fp'>partitions</span></span>, <span>int <i>timeout_ms</i></span>&#160;)</span></span><br/>
+<div class='affect'>Field &#39;partitions.elems.err&#39; in 2nd parameter &#39;partitions&#39; (pointer) is of type &#39;enum rd_kafka_resp_err_t&#39;.</div>
+ <b>...</b>
+<br/>
+</div>
+</div>
+<br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Other_Source_Changes_In_Constants'></a>
+<h2>Other Changes in Constants <span class='passed'>&nbsp;3&nbsp;</span></h2><hr/>
+<span class='h_name'>rdkafka.h</span><br/>
+<span class="section" onclick="javascript:showContent(this, 'c_20')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETECONSUMERGROUPOFFSETS_RESULT</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 constant <b>RD_KAFKA_EVENT_DELETECONSUMERGROUPOFFSETS_RESULT</b> with value <b>107</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<br/>
+</div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_21')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETEGROUPS_RESULT</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 constant <b>RD_KAFKA_EVENT_DELETEGROUPS_RESULT</b> with value <b>106</b> has been added.</td>
+<td>No effect.</td>
+</tr>
+</table>
+<br/>
+</div>
+
+<span class="section" onclick="javascript:showContent(this, 'c_22')">
+<span class='ext'>[+]</span> RD_KAFKA_EVENT_DELETERECORDS_RESULT</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 constant <b>RD_KAFKA_EVENT_DELETERECORDS_RESULT</b> with value <b>105</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'>&nbsp;1&nbsp;</span></h2><hr/>
+<div class='h_list'>
+rdkafka.h<br/>
+</div>
+<br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Libs'></a><h2>Libraries <span class='gray'>&nbsp;1&nbsp;</span></h2><hr/>
+<div class='lib_list'>
+librdkafka.so.101<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 &#160;</i>
+</div>
+<br/>
+
+</body></html>
diff --git a/librdkafka.spec b/librdkafka.spec
index e65330b..bdc20f4 100644
--- a/librdkafka.spec
+++ b/librdkafka.spec
@@ -1,20 +1,20 @@
# remirepo/fedora spec file for librdkafka
#
-# Copyright (c) 2015-2020 Remi Collet
+# Copyright (c) 2015-2021 Remi Collet
# License: CC-BY-SA
# http://creativecommons.org/licenses/by-sa/4.0/
#
# Please, preserve the changelog entries
#
%global libname librdkafka
-%global gh_commit 6283304aefc7b306738489e14e87c2c2c8bee359
+%global gh_commit 7fe18e432e49e351c72b72fb7c2f2564346e1add
%global gh_short %(c=%{gh_commit}; echo ${c:0:7})
%global gh_owner edenhill
%global gh_project %{libname}
%global oldsoname 1
%global newsoname 101
-%global upstream_version 1.5.3
+%global upstream_version 1.6.0
#global upstream_prever RC1
Name: %{libname}%{oldsoname}php
diff --git a/librdkafka.xml b/librdkafka.xml
index 458b4b7..63ddf5d 100644
--- a/librdkafka.xml
+++ b/librdkafka.xml
@@ -9,7 +9,7 @@
<version>
<!-- Version of the library -->
-1.5.3
+1.6.0
</version>
<headers>