On Sun, Dec 13, 2009 at 7:11 PM, Doran Mori <dhm...@gmail.com> wrote:
> Having stuck my head into the kernel routing code for a few weeks now
> I thought I would take a look at this problem since it partially
> affects what I'm trying to do.
>
> I don't think it's good idea to delete the downed routes.  You'll need
> something to add the statics back when the interface comes back up
> including the default route.
>
> What I see going on is rn_match finds the most specific route whether
> the route is up or down.  In your case it's finding the arp entry
> which is an exact match.  Once the arp entry expires then the next
> specific route will be the directly connected interface route which is
> also down.  Thus it's broke.
>
> I would probably add a flag argument to tell rn_match and rn_lookup to
> skip entries that aren't RTF_UP.  rn_match is indeed very "hairy" and
> I'm not sure where even to check for RTF_UP.  I haven't gained enough
> experience points to wield the right tools to combat that beast.  I'll
> leave it to a much higher leveled kernel sorcerer to craft the proper
> enchantment.
>
> dmo
>
>

You could also use ifstated to restore static routes.

--
Aaron Mason - Programmer, open source addict
I've taken my software vows - for beta or for worse

Reply via email to