diff options
Diffstat (limited to 'drivers/net/sfc/efx.h')
-rw-r--r-- | drivers/net/sfc/efx.h | 68 |
1 files changed, 47 insertions, 21 deletions
diff --git a/drivers/net/sfc/efx.h b/drivers/net/sfc/efx.h index 060dc952a0fd..b0d1209ea18d 100644 --- a/drivers/net/sfc/efx.h +++ b/drivers/net/sfc/efx.h | |||
@@ -1,7 +1,7 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | * Driver for Solarflare Solarstorm network controllers and boards | 2 | * Driver for Solarflare Solarstorm network controllers and boards |
3 | * Copyright 2005-2006 Fen Systems Ltd. | 3 | * Copyright 2005-2006 Fen Systems Ltd. |
4 | * Copyright 2006-2009 Solarflare Communications Inc. | 4 | * Copyright 2006-2010 Solarflare Communications Inc. |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify it | 6 | * This program is free software; you can redistribute it and/or modify it |
7 | * under the terms of the GNU General Public License version 2 as published | 7 | * under the terms of the GNU General Public License version 2 as published |
@@ -12,6 +12,7 @@ | |||
12 | #define EFX_EFX_H | 12 | #define EFX_EFX_H |
13 | 13 | ||
14 | #include "net_driver.h" | 14 | #include "net_driver.h" |
15 | #include "filter.h" | ||
15 | 16 | ||
16 | /* PCI IDs */ | 17 | /* PCI IDs */ |
17 | #define EFX_VENDID_SFC 0x1924 | 18 | #define EFX_VENDID_SFC 0x1924 |
@@ -28,6 +29,7 @@ | |||
28 | extern int efx_probe_tx_queue(struct efx_tx_queue *tx_queue); | 29 | extern int efx_probe_tx_queue(struct efx_tx_queue *tx_queue); |
29 | extern void efx_remove_tx_queue(struct efx_tx_queue *tx_queue); | 30 | extern void efx_remove_tx_queue(struct efx_tx_queue *tx_queue); |
30 | extern void efx_init_tx_queue(struct efx_tx_queue *tx_queue); | 31 | extern void efx_init_tx_queue(struct efx_tx_queue *tx_queue); |
32 | extern void efx_init_tx_queue_core_txq(struct efx_tx_queue *tx_queue); | ||
31 | extern void efx_fini_tx_queue(struct efx_tx_queue *tx_queue); | 33 | extern void efx_fini_tx_queue(struct efx_tx_queue *tx_queue); |
32 | extern void efx_release_tx_buffers(struct efx_tx_queue *tx_queue); | 34 | extern void efx_release_tx_buffers(struct efx_tx_queue *tx_queue); |
33 | extern netdev_tx_t | 35 | extern netdev_tx_t |
@@ -35,10 +37,7 @@ efx_hard_start_xmit(struct sk_buff *skb, struct net_device *net_dev); | |||
35 | extern netdev_tx_t | 37 | extern netdev_tx_t |
36 | efx_enqueue_skb(struct efx_tx_queue *tx_queue, struct sk_buff *skb); | 38 | efx_enqueue_skb(struct efx_tx_queue *tx_queue, struct sk_buff *skb); |
37 | extern void efx_xmit_done(struct efx_tx_queue *tx_queue, unsigned int index); | 39 | extern void efx_xmit_done(struct efx_tx_queue *tx_queue, unsigned int index); |
38 | extern void efx_stop_queue(struct efx_channel *channel); | 40 | extern int efx_setup_tc(struct net_device *net_dev, u8 num_tc); |
39 | extern void efx_wake_queue(struct efx_channel *channel); | ||
40 | #define EFX_TXQ_SIZE 1024 | ||
41 | #define EFX_TXQ_MASK (EFX_TXQ_SIZE - 1) | ||
42 | 41 | ||
43 | /* RX */ | 42 | /* RX */ |
44 | extern int efx_probe_rx_queue(struct efx_rx_queue *rx_queue); | 43 | extern int efx_probe_rx_queue(struct efx_rx_queue *rx_queue); |
@@ -53,23 +52,56 @@ extern void __efx_rx_packet(struct efx_channel *channel, | |||
53 | extern void efx_rx_packet(struct efx_rx_queue *rx_queue, unsigned int index, | 52 | extern void efx_rx_packet(struct efx_rx_queue *rx_queue, unsigned int index, |
54 | unsigned int len, bool checksummed, bool discard); | 53 | unsigned int len, bool checksummed, bool discard); |
55 | extern void efx_schedule_slow_fill(struct efx_rx_queue *rx_queue); | 54 | extern void efx_schedule_slow_fill(struct efx_rx_queue *rx_queue); |
56 | #define EFX_RXQ_SIZE 1024 | 55 | |
57 | #define EFX_RXQ_MASK (EFX_RXQ_SIZE - 1) | 56 | #define EFX_MAX_DMAQ_SIZE 4096UL |
57 | #define EFX_DEFAULT_DMAQ_SIZE 1024UL | ||
58 | #define EFX_MIN_DMAQ_SIZE 512UL | ||
59 | |||
60 | #define EFX_MAX_EVQ_SIZE 16384UL | ||
61 | #define EFX_MIN_EVQ_SIZE 512UL | ||
62 | |||
63 | /* The smallest [rt]xq_entries that the driver supports. Callers of | ||
64 | * efx_wake_queue() assume that they can subsequently send at least one | ||
65 | * skb. Falcon/A1 may require up to three descriptors per skb_frag. */ | ||
66 | #define EFX_MIN_RING_SIZE (roundup_pow_of_two(2 * 3 * MAX_SKB_FRAGS)) | ||
67 | |||
68 | /* Filters */ | ||
69 | extern int efx_probe_filters(struct efx_nic *efx); | ||
70 | extern void efx_restore_filters(struct efx_nic *efx); | ||
71 | extern void efx_remove_filters(struct efx_nic *efx); | ||
72 | extern int efx_filter_insert_filter(struct efx_nic *efx, | ||
73 | struct efx_filter_spec *spec, | ||
74 | bool replace); | ||
75 | extern int efx_filter_remove_filter(struct efx_nic *efx, | ||
76 | struct efx_filter_spec *spec); | ||
77 | extern void efx_filter_clear_rx(struct efx_nic *efx, | ||
78 | enum efx_filter_priority priority); | ||
79 | #ifdef CONFIG_RFS_ACCEL | ||
80 | extern int efx_filter_rfs(struct net_device *net_dev, const struct sk_buff *skb, | ||
81 | u16 rxq_index, u32 flow_id); | ||
82 | extern bool __efx_filter_rfs_expire(struct efx_nic *efx, unsigned quota); | ||
83 | static inline void efx_filter_rfs_expire(struct efx_channel *channel) | ||
84 | { | ||
85 | if (channel->rfs_filters_added >= 60 && | ||
86 | __efx_filter_rfs_expire(channel->efx, 100)) | ||
87 | channel->rfs_filters_added -= 60; | ||
88 | } | ||
89 | #define efx_filter_rfs_enabled() 1 | ||
90 | #else | ||
91 | static inline void efx_filter_rfs_expire(struct efx_channel *channel) {} | ||
92 | #define efx_filter_rfs_enabled() 0 | ||
93 | #endif | ||
58 | 94 | ||
59 | /* Channels */ | 95 | /* Channels */ |
60 | extern void efx_process_channel_now(struct efx_channel *channel); | 96 | extern void efx_process_channel_now(struct efx_channel *channel); |
61 | #define EFX_EVQ_SIZE 4096 | 97 | extern int |
62 | #define EFX_EVQ_MASK (EFX_EVQ_SIZE - 1) | 98 | efx_realloc_channels(struct efx_nic *efx, u32 rxq_entries, u32 txq_entries); |
63 | 99 | ||
64 | /* Ports */ | 100 | /* Ports */ |
65 | extern int efx_reconfigure_port(struct efx_nic *efx); | 101 | extern int efx_reconfigure_port(struct efx_nic *efx); |
66 | extern int __efx_reconfigure_port(struct efx_nic *efx); | 102 | extern int __efx_reconfigure_port(struct efx_nic *efx); |
67 | 103 | ||
68 | /* Ethtool support */ | 104 | /* Ethtool support */ |
69 | extern int efx_ethtool_get_settings(struct net_device *net_dev, | ||
70 | struct ethtool_cmd *ecmd); | ||
71 | extern int efx_ethtool_set_settings(struct net_device *net_dev, | ||
72 | struct ethtool_cmd *ecmd); | ||
73 | extern const struct ethtool_ops efx_ethtool_ops; | 105 | extern const struct ethtool_ops efx_ethtool_ops; |
74 | 106 | ||
75 | /* Reset handling */ | 107 | /* Reset handling */ |
@@ -81,15 +113,11 @@ extern int efx_reset_up(struct efx_nic *efx, enum reset_type method, bool ok); | |||
81 | extern void efx_schedule_reset(struct efx_nic *efx, enum reset_type type); | 113 | extern void efx_schedule_reset(struct efx_nic *efx, enum reset_type type); |
82 | extern void efx_init_irq_moderation(struct efx_nic *efx, int tx_usecs, | 114 | extern void efx_init_irq_moderation(struct efx_nic *efx, int tx_usecs, |
83 | int rx_usecs, bool rx_adaptive); | 115 | int rx_usecs, bool rx_adaptive); |
84 | extern int efx_request_power(struct efx_nic *efx, int mw, const char *name); | ||
85 | extern void efx_hex_dump(const u8 *, unsigned int, const char *); | ||
86 | 116 | ||
87 | /* Dummy PHY ops for PHY drivers */ | 117 | /* Dummy PHY ops for PHY drivers */ |
88 | extern int efx_port_dummy_op_int(struct efx_nic *efx); | 118 | extern int efx_port_dummy_op_int(struct efx_nic *efx); |
89 | extern void efx_port_dummy_op_void(struct efx_nic *efx); | 119 | extern void efx_port_dummy_op_void(struct efx_nic *efx); |
90 | extern void | 120 | |
91 | efx_port_dummy_op_set_id_led(struct efx_nic *efx, enum efx_led_mode mode); | ||
92 | extern bool efx_port_dummy_op_poll(struct efx_nic *efx); | ||
93 | 121 | ||
94 | /* MTD */ | 122 | /* MTD */ |
95 | #ifdef CONFIG_SFC_MTD | 123 | #ifdef CONFIG_SFC_MTD |
@@ -102,8 +130,6 @@ static inline void efx_mtd_rename(struct efx_nic *efx) {} | |||
102 | static inline void efx_mtd_remove(struct efx_nic *efx) {} | 130 | static inline void efx_mtd_remove(struct efx_nic *efx) {} |
103 | #endif | 131 | #endif |
104 | 132 | ||
105 | extern unsigned int efx_monitor_interval; | ||
106 | |||
107 | static inline void efx_schedule_channel(struct efx_channel *channel) | 133 | static inline void efx_schedule_channel(struct efx_channel *channel) |
108 | { | 134 | { |
109 | netif_vdbg(channel->efx, intr, channel->efx->net_dev, | 135 | netif_vdbg(channel->efx, intr, channel->efx->net_dev, |
@@ -116,6 +142,6 @@ static inline void efx_schedule_channel(struct efx_channel *channel) | |||
116 | 142 | ||
117 | extern void efx_link_status_changed(struct efx_nic *efx); | 143 | extern void efx_link_status_changed(struct efx_nic *efx); |
118 | extern void efx_link_set_advertising(struct efx_nic *efx, u32); | 144 | extern void efx_link_set_advertising(struct efx_nic *efx, u32); |
119 | extern void efx_link_set_wanted_fc(struct efx_nic *efx, enum efx_fc_type); | 145 | extern void efx_link_set_wanted_fc(struct efx_nic *efx, u8); |
120 | 146 | ||
121 | #endif /* EFX_EFX_H */ | 147 | #endif /* EFX_EFX_H */ |