blob: a52dbd2b3c63d4be9efb31f21257e574da5957a5 [file] [log] [blame]
Vasanthy Kolluri51987462011-02-04 16:17:05 +00001/*
2 * Copyright 2011 Cisco Systems, Inc. All rights reserved.
3 *
4 * This program is free software; you may redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; version 2 of the License.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
9 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
10 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
11 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
12 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
13 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
14 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
15 * SOFTWARE.
16 *
17 */
18
19#include <linux/pci.h>
20#include <linux/etherdevice.h>
21
22#include "vnic_dev.h"
23#include "vnic_vic.h"
24#include "enic_res.h"
25#include "enic.h"
26#include "enic_dev.h"
27
28int enic_dev_fw_info(struct enic *enic, struct vnic_devcmd_fw_info **fw_info)
29{
30 int err;
31
32 spin_lock(&enic->devcmd_lock);
33 err = vnic_dev_fw_info(enic->vdev, fw_info);
34 spin_unlock(&enic->devcmd_lock);
35
36 return err;
37}
38
39int enic_dev_stats_dump(struct enic *enic, struct vnic_stats **vstats)
40{
41 int err;
42
43 spin_lock(&enic->devcmd_lock);
44 err = vnic_dev_stats_dump(enic->vdev, vstats);
45 spin_unlock(&enic->devcmd_lock);
46
47 return err;
48}
49
50int enic_dev_add_station_addr(struct enic *enic)
51{
52 int err = 0;
53
54 if (is_valid_ether_addr(enic->netdev->dev_addr)) {
55 spin_lock(&enic->devcmd_lock);
56 err = vnic_dev_add_addr(enic->vdev, enic->netdev->dev_addr);
57 spin_unlock(&enic->devcmd_lock);
58 }
59
60 return err;
61}
62
63int enic_dev_del_station_addr(struct enic *enic)
64{
65 int err = 0;
66
67 if (is_valid_ether_addr(enic->netdev->dev_addr)) {
68 spin_lock(&enic->devcmd_lock);
69 err = vnic_dev_del_addr(enic->vdev, enic->netdev->dev_addr);
70 spin_unlock(&enic->devcmd_lock);
71 }
72
73 return err;
74}
75
76int enic_dev_packet_filter(struct enic *enic, int directed, int multicast,
77 int broadcast, int promisc, int allmulti)
78{
79 int err;
80
81 spin_lock(&enic->devcmd_lock);
82 err = vnic_dev_packet_filter(enic->vdev, directed,
83 multicast, broadcast, promisc, allmulti);
84 spin_unlock(&enic->devcmd_lock);
85
86 return err;
87}
88
89int enic_dev_add_addr(struct enic *enic, u8 *addr)
90{
91 int err;
92
93 spin_lock(&enic->devcmd_lock);
94 err = vnic_dev_add_addr(enic->vdev, addr);
95 spin_unlock(&enic->devcmd_lock);
96
97 return err;
98}
99
100int enic_dev_del_addr(struct enic *enic, u8 *addr)
101{
102 int err;
103
104 spin_lock(&enic->devcmd_lock);
105 err = vnic_dev_del_addr(enic->vdev, addr);
106 spin_unlock(&enic->devcmd_lock);
107
108 return err;
109}
110
111int enic_dev_hw_version(struct enic *enic, enum vnic_dev_hw_version *hw_ver)
112{
113 int err;
114
115 spin_lock(&enic->devcmd_lock);
116 err = vnic_dev_hw_version(enic->vdev, hw_ver);
117 spin_unlock(&enic->devcmd_lock);
118
119 return err;
120}
121
122int enic_dev_notify_unset(struct enic *enic)
123{
124 int err;
125
126 spin_lock(&enic->devcmd_lock);
127 err = vnic_dev_notify_unset(enic->vdev);
128 spin_unlock(&enic->devcmd_lock);
129
130 return err;
131}
132
133int enic_dev_hang_notify(struct enic *enic)
134{
135 int err;
136
137 spin_lock(&enic->devcmd_lock);
138 err = vnic_dev_hang_notify(enic->vdev);
139 spin_unlock(&enic->devcmd_lock);
140
141 return err;
142}
143
144int enic_dev_set_ig_vlan_rewrite_mode(struct enic *enic)
145{
146 int err;
147
148 spin_lock(&enic->devcmd_lock);
149 err = vnic_dev_set_ig_vlan_rewrite_mode(enic->vdev,
150 IG_VLAN_REWRITE_MODE_PRIORITY_TAG_DEFAULT_VLAN);
151 spin_unlock(&enic->devcmd_lock);
152
153 return err;
154}
155
156int enic_dev_enable(struct enic *enic)
157{
158 int err;
159
160 spin_lock(&enic->devcmd_lock);
161 err = vnic_dev_enable_wait(enic->vdev);
162 spin_unlock(&enic->devcmd_lock);
163
164 return err;
165}
166
167int enic_dev_disable(struct enic *enic)
168{
169 int err;
170
171 spin_lock(&enic->devcmd_lock);
172 err = vnic_dev_disable(enic->vdev);
173 spin_unlock(&enic->devcmd_lock);
174
175 return err;
176}
177
178int enic_vnic_dev_deinit(struct enic *enic)
179{
180 int err;
181
182 spin_lock(&enic->devcmd_lock);
183 err = vnic_dev_deinit(enic->vdev);
184 spin_unlock(&enic->devcmd_lock);
185
186 return err;
187}
188
189int enic_dev_init_prov(struct enic *enic, struct vic_provinfo *vp)
190{
191 int err;
192
193 spin_lock(&enic->devcmd_lock);
194 err = vnic_dev_init_prov(enic->vdev,
195 (u8 *)vp, vic_provinfo_size(vp));
196 spin_unlock(&enic->devcmd_lock);
197
198 return err;
199}
200
201int enic_dev_init_done(struct enic *enic, int *done, int *error)
202{
203 int err;
204
205 spin_lock(&enic->devcmd_lock);
206 err = vnic_dev_init_done(enic->vdev, done, error);
207 spin_unlock(&enic->devcmd_lock);
208
209 return err;
210}
211
212/* rtnl lock is held */
213void enic_vlan_rx_add_vid(struct net_device *netdev, u16 vid)
214{
215 struct enic *enic = netdev_priv(netdev);
216
217 spin_lock(&enic->devcmd_lock);
218 enic_add_vlan(enic, vid);
219 spin_unlock(&enic->devcmd_lock);
220}
221
222/* rtnl lock is held */
223void enic_vlan_rx_kill_vid(struct net_device *netdev, u16 vid)
224{
225 struct enic *enic = netdev_priv(netdev);
226
227 spin_lock(&enic->devcmd_lock);
228 enic_del_vlan(enic, vid);
229 spin_unlock(&enic->devcmd_lock);
230}