<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;background-color:#FFFFFF;font-family:Calibri,Arial,Helvetica,sans-serif;">
<p>I am using Bird on my system, and when I change config (use different interfaces for OSPF, from using tap-0, tap-4 to tap-0, tap-11) and restart Bird using "birdc restart all", I got a coredump in Bird with the following backtrace:</p>
<p><br>
</p>
<p></p>
<div>(gdb) bt</div>
<div>#0  kif_choose_primary (i=i@entry=0x66ce10) at krt.c:155</div>
<div>#1  0x000000000040be49 in ifa_recalc_primary (i=i@entry=0x66ce10) at ../../nest/iface.c:469</div>
<div>#2  0x000000000040c9f5 in ifa_delete (a=<optimized out>) at ../../nest/iface.c:579</div>
<div>#3  0x0000000000441649 in nl_parse_addr (h=h@entry=0x68c140, scan=scan@entry=0) at netlink.c:554</div>
<div>#4  0x000000000044182a in nl_async_msg (h=0x68c140) at netlink.c:979</div>
<div>#5  nl_async_hook (sk=<optimized out>, size=<optimized out>) at netlink.c:1026</div>
<div>#6  0x000000000043ba65 in sk_read (s=s@entry=0x68e150) at io.c:1831</div>
<div>#7  0x000000000043c2b2 in io_loop () at io.c:2187</div>
<div>#8  0x0000000000402ca1 in main (argc=<optimized out>, argv=<optimized out>) at main.c:844</div>
<div><br>
</div>
I added some debug message and noticed the problem is the device protocol is restarting, and kif_shutdown is called, then as the backtrace shows it tries to delete the interface and call kif_choose_primary() while kif_proto is NULL at the time. I comment out
 that part of the code and noticed kif_start is called after those kif_choose_primary() calls.
<p></p>
<p><br>
</p>
<p>I am new to Bird code, so is this a Bird bug or I am not doing things correct (i.e. when change config, I shouldn't just call birdc restart all)?</p>
<p><br>
</p>
<p>Wei</p>
</div>
</body>
</html>