f421436a59
High-availability Seamless Redundancy ("HSR") provides instant failover redundancy for Ethernet networks. It requires a special network topology where all nodes are connected in a ring (each node having two physical network interfaces). It is suited for applications that demand high availability and very short reaction time. HSR acts on the Ethernet layer, using a registered Ethernet protocol type to send special HSR frames in both directions over the ring. The driver creates virtual network interfaces that can be used just like any ordinary Linux network interface, for IP/TCP/UDP traffic etc. All nodes in the network ring must be HSR capable. This code is a "best effort" to comply with the HSR standard as described in IEC 62439-3:2010 (HSRv0). Signed-off-by: Arvid Brodin <arvid.brodin@xdin.com> Signed-off-by: David S. Miller <davem@davemloft.net>
30 lines
1.0 KiB
C
30 lines
1.0 KiB
C
/* Copyright 2011-2013 Autronica Fire and Security AS
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the Free
|
|
* Software Foundation; either version 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* Author(s):
|
|
* 2011-2013 Arvid Brodin, arvid.brodin@xdin.com
|
|
*/
|
|
|
|
#ifndef __HSR_DEVICE_H
|
|
#define __HSR_DEVICE_H
|
|
|
|
#include <linux/netdevice.h>
|
|
#include "hsr_main.h"
|
|
|
|
void hsr_dev_setup(struct net_device *dev);
|
|
int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],
|
|
unsigned char multicast_spec);
|
|
void hsr_set_operstate(struct net_device *hsr_dev, struct net_device *slave1,
|
|
struct net_device *slave2);
|
|
void hsr_set_carrier(struct net_device *hsr_dev, struct net_device *slave1,
|
|
struct net_device *slave2);
|
|
void hsr_check_announce(struct net_device *hsr_dev, int old_operstate);
|
|
bool is_hsr_master(struct net_device *dev);
|
|
int hsr_get_max_mtu(struct hsr_priv *hsr_priv);
|
|
|
|
#endif /* __HSR_DEVICE_H */
|