OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [net/] [bridge/] [br_notify.c] - Blame information for rev 1275

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
/*
2
 *      Device event handling
3
 *      Linux ethernet bridge
4
 *
5
 *      Authors:
6
 *      Lennert Buytenhek               <buytenh@gnu.org>
7
 *
8
 *      $Id: br_notify.c,v 1.1.1.1 2004-04-15 01:16:27 phoenix Exp $
9
 *
10
 *      This program is free software; you can redistribute it and/or
11
 *      modify it under the terms of the GNU General Public License
12
 *      as published by the Free Software Foundation; either version
13
 *      2 of the License, or (at your option) any later version.
14
 */
15
 
16
#include <linux/kernel.h>
17
#include <linux/if_bridge.h>
18
#include "br_private.h"
19
 
20
static int br_device_event(struct notifier_block *unused, unsigned long event, void *ptr);
21
 
22
struct notifier_block br_device_notifier =
23
{
24
        br_device_event,
25
        NULL,
26
 
27
};
28
 
29
static int br_device_event(struct notifier_block *unused, unsigned long event, void *ptr)
30
{
31
        struct net_device *dev;
32
        struct net_bridge_port *p;
33
 
34
        dev = ptr;
35
        p = dev->br_port;
36
 
37
        if (p == NULL)
38
                return NOTIFY_DONE;
39
 
40
        switch (event)
41
        {
42
        case NETDEV_CHANGEADDR:
43
                read_lock(&p->br->lock);
44
                br_fdb_changeaddr(p, dev->dev_addr);
45
                br_stp_recalculate_bridge_id(p->br);
46
                read_unlock(&p->br->lock);
47
                break;
48
 
49
        case NETDEV_GOING_DOWN:
50
                /* extend the protocol to send some kind of notification? */
51
                break;
52
 
53
        case NETDEV_DOWN:
54
                if (p->br->dev.flags & IFF_UP) {
55
                        read_lock(&p->br->lock);
56
                        br_stp_disable_port(dev->br_port);
57
                        read_unlock(&p->br->lock);
58
                }
59
                break;
60
 
61
        case NETDEV_UP:
62
                if (p->br->dev.flags & IFF_UP) {
63
                        read_lock(&p->br->lock);
64
                        br_stp_enable_port(dev->br_port);
65
                        read_unlock(&p->br->lock);
66
                }
67
                break;
68
 
69
        case NETDEV_UNREGISTER:
70
                br_del_if(dev->br_port->br, dev);
71
                break;
72
        }
73
 
74
        return NOTIFY_DONE;
75
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.