1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright 2011 Cisco Systems, Inc. All rights reserved. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * This program is free software; you may redistribute it and/or modify 5*4882a593Smuzhiyun * it under the terms of the GNU General Public License as published by 6*4882a593Smuzhiyun * the Free Software Foundation; version 2 of the License. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 9*4882a593Smuzhiyun * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 10*4882a593Smuzhiyun * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 11*4882a593Smuzhiyun * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 12*4882a593Smuzhiyun * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 13*4882a593Smuzhiyun * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 14*4882a593Smuzhiyun * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 15*4882a593Smuzhiyun * SOFTWARE. 16*4882a593Smuzhiyun * 17*4882a593Smuzhiyun */ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun #ifndef _ENIC_DEV_H_ 20*4882a593Smuzhiyun #define _ENIC_DEV_H_ 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun #include "vnic_dev.h" 23*4882a593Smuzhiyun #include "vnic_vic.h" 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun /* 26*4882a593Smuzhiyun * Calls the devcmd function given by argument vnicdevcmdfn. 27*4882a593Smuzhiyun * If vf argument is valid, it proxies the devcmd 28*4882a593Smuzhiyun */ 29*4882a593Smuzhiyun #define ENIC_DEVCMD_PROXY_BY_INDEX(vf, err, enic, vnicdevcmdfn, ...) \ 30*4882a593Smuzhiyun do { \ 31*4882a593Smuzhiyun spin_lock_bh(&enic->devcmd_lock); \ 32*4882a593Smuzhiyun if (enic_is_valid_vf(enic, vf)) { \ 33*4882a593Smuzhiyun vnic_dev_cmd_proxy_by_index_start(enic->vdev, vf); \ 34*4882a593Smuzhiyun err = vnicdevcmdfn(enic->vdev, ##__VA_ARGS__); \ 35*4882a593Smuzhiyun vnic_dev_cmd_proxy_end(enic->vdev); \ 36*4882a593Smuzhiyun } else { \ 37*4882a593Smuzhiyun err = vnicdevcmdfn(enic->vdev, ##__VA_ARGS__); \ 38*4882a593Smuzhiyun } \ 39*4882a593Smuzhiyun spin_unlock_bh(&enic->devcmd_lock); \ 40*4882a593Smuzhiyun } while (0) 41*4882a593Smuzhiyun 42*4882a593Smuzhiyun int enic_dev_fw_info(struct enic *enic, struct vnic_devcmd_fw_info **fw_info); 43*4882a593Smuzhiyun int enic_dev_stats_dump(struct enic *enic, struct vnic_stats **vstats); 44*4882a593Smuzhiyun int enic_dev_add_station_addr(struct enic *enic); 45*4882a593Smuzhiyun int enic_dev_del_station_addr(struct enic *enic); 46*4882a593Smuzhiyun int enic_dev_packet_filter(struct enic *enic, int directed, int multicast, 47*4882a593Smuzhiyun int broadcast, int promisc, int allmulti); 48*4882a593Smuzhiyun int enic_dev_add_addr(struct enic *enic, const u8 *addr); 49*4882a593Smuzhiyun int enic_dev_del_addr(struct enic *enic, const u8 *addr); 50*4882a593Smuzhiyun int enic_vlan_rx_add_vid(struct net_device *netdev, __be16 proto, u16 vid); 51*4882a593Smuzhiyun int enic_vlan_rx_kill_vid(struct net_device *netdev, __be16 proto, u16 vid); 52*4882a593Smuzhiyun int enic_dev_notify_unset(struct enic *enic); 53*4882a593Smuzhiyun int enic_dev_hang_notify(struct enic *enic); 54*4882a593Smuzhiyun int enic_dev_set_ig_vlan_rewrite_mode(struct enic *enic); 55*4882a593Smuzhiyun int enic_dev_enable(struct enic *enic); 56*4882a593Smuzhiyun int enic_dev_disable(struct enic *enic); 57*4882a593Smuzhiyun int enic_dev_intr_coal_timer_info(struct enic *enic); 58*4882a593Smuzhiyun int enic_dev_status_to_errno(int devcmd_status); 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun #endif /* _ENIC_DEV_H_ */ 61