提交 145186a3 编写于 作者: S Stephen Hemminger 提交者: David S. Miller

fddi: convert to new network device ops

Similar to ethernet. Convert infrastructure and the one lone FDDI
driver (for the one lone user of that hardware??). Compile tested only.
Signed-off-by: NStephen Hemminger <shemminger@vyatta.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 007c3838
...@@ -168,6 +168,17 @@ static int num_boards; /* total number of adapters configured */ ...@@ -168,6 +168,17 @@ static int num_boards; /* total number of adapters configured */
#define PRINTK(s, args...) #define PRINTK(s, args...)
#endif // DRIVERDEBUG #endif // DRIVERDEBUG
static const struct net_device_ops skfp_netdev_ops = {
.ndo_open = skfp_open,
.ndo_stop = skfp_close,
.ndo_start_xmit = skfp_send_pkt,
.ndo_get_stats = skfp_ctl_get_stats,
.ndo_change_mtu = fddi_change_mtu,
.ndo_set_multicast_list = skfp_ctl_set_multicast_list,
.ndo_set_mac_address = skfp_ctl_set_mac_address,
.ndo_do_ioctl = skfp_ioctl,
};
/* /*
* ================= * =================
* = skfp_init_one = * = skfp_init_one =
...@@ -253,13 +264,7 @@ static int skfp_init_one(struct pci_dev *pdev, ...@@ -253,13 +264,7 @@ static int skfp_init_one(struct pci_dev *pdev,
} }
dev->irq = pdev->irq; dev->irq = pdev->irq;
dev->get_stats = &skfp_ctl_get_stats; dev->netdev_ops = &skfp_netdev_ops;
dev->open = &skfp_open;
dev->stop = &skfp_close;
dev->hard_start_xmit = &skfp_send_pkt;
dev->set_multicast_list = &skfp_ctl_set_multicast_list;
dev->set_mac_address = &skfp_ctl_set_mac_address;
dev->do_ioctl = &skfp_ioctl;
SET_NETDEV_DEV(dev, &pdev->dev); SET_NETDEV_DEV(dev, &pdev->dev);
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
#ifdef __KERNEL__ #ifdef __KERNEL__
extern __be16 fddi_type_trans(struct sk_buff *skb, extern __be16 fddi_type_trans(struct sk_buff *skb,
struct net_device *dev); struct net_device *dev);
extern int fddi_change_mtu(struct net_device *dev, int new_mtu);
extern struct net_device *alloc_fddidev(int sizeof_priv); extern struct net_device *alloc_fddidev(int sizeof_priv);
#endif #endif
......
...@@ -167,23 +167,27 @@ __be16 fddi_type_trans(struct sk_buff *skb, struct net_device *dev) ...@@ -167,23 +167,27 @@ __be16 fddi_type_trans(struct sk_buff *skb, struct net_device *dev)
EXPORT_SYMBOL(fddi_type_trans); EXPORT_SYMBOL(fddi_type_trans);
static int fddi_change_mtu(struct net_device *dev, int new_mtu) int fddi_change_mtu(struct net_device *dev, int new_mtu)
{ {
if ((new_mtu < FDDI_K_SNAP_HLEN) || (new_mtu > FDDI_K_SNAP_DLEN)) if ((new_mtu < FDDI_K_SNAP_HLEN) || (new_mtu > FDDI_K_SNAP_DLEN))
return(-EINVAL); return(-EINVAL);
dev->mtu = new_mtu; dev->mtu = new_mtu;
return(0); return(0);
} }
EXPORT_SYMBOL(fddi_change_mtu);
static const struct header_ops fddi_header_ops = { static const struct header_ops fddi_header_ops = {
.create = fddi_header, .create = fddi_header,
.rebuild = fddi_rebuild_header, .rebuild = fddi_rebuild_header,
}; };
static void fddi_setup(struct net_device *dev) static void fddi_setup(struct net_device *dev)
{ {
dev->change_mtu = fddi_change_mtu;
dev->header_ops = &fddi_header_ops; dev->header_ops = &fddi_header_ops;
#ifdef CONFIG_COMPAT_NET_DEV_OPS
dev->change_mtu = fddi_change_mtu,
#endif
dev->type = ARPHRD_FDDI; dev->type = ARPHRD_FDDI;
dev->hard_header_len = FDDI_K_SNAP_HLEN+3; /* Assume 802.2 SNAP hdr len + 3 pad bytes */ dev->hard_header_len = FDDI_K_SNAP_HLEN+3; /* Assume 802.2 SNAP hdr len + 3 pad bytes */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册