xref: /linux/drivers/infiniband/hw/usnic/usnic_fwd.h (revision 03ab8e6297acd1bc0eedaa050e2a1635c576fd11)
1e3cf00d0SUpinder Malhi /*
2e3cf00d0SUpinder Malhi  * Copyright (c) 2013, Cisco Systems, Inc. All rights reserved.
3e3cf00d0SUpinder Malhi  *
43805eadeSJeff Squyres  * This software is available to you under a choice of one of two
53805eadeSJeff Squyres  * licenses.  You may choose to be licensed under the terms of the GNU
63805eadeSJeff Squyres  * General Public License (GPL) Version 2, available from the file
73805eadeSJeff Squyres  * COPYING in the main directory of this source tree, or the
83805eadeSJeff Squyres  * BSD license below:
93805eadeSJeff Squyres  *
103805eadeSJeff Squyres  *     Redistribution and use in source and binary forms, with or
113805eadeSJeff Squyres  *     without modification, are permitted provided that the following
123805eadeSJeff Squyres  *     conditions are met:
133805eadeSJeff Squyres  *
143805eadeSJeff Squyres  *      - Redistributions of source code must retain the above
153805eadeSJeff Squyres  *        copyright notice, this list of conditions and the following
163805eadeSJeff Squyres  *        disclaimer.
173805eadeSJeff Squyres  *
183805eadeSJeff Squyres  *      - Redistributions in binary form must reproduce the above
193805eadeSJeff Squyres  *        copyright notice, this list of conditions and the following
203805eadeSJeff Squyres  *        disclaimer in the documentation and/or other materials
213805eadeSJeff Squyres  *        provided with the distribution.
22e3cf00d0SUpinder Malhi  *
23e3cf00d0SUpinder Malhi  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24e3cf00d0SUpinder Malhi  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25e3cf00d0SUpinder Malhi  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26e3cf00d0SUpinder Malhi  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
27e3cf00d0SUpinder Malhi  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
28e3cf00d0SUpinder Malhi  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
29e3cf00d0SUpinder Malhi  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30e3cf00d0SUpinder Malhi  * SOFTWARE.
31e3cf00d0SUpinder Malhi  *
32e3cf00d0SUpinder Malhi  */
33e3cf00d0SUpinder Malhi 
34e3cf00d0SUpinder Malhi #ifndef USNIC_FWD_H_
35e3cf00d0SUpinder Malhi #define USNIC_FWD_H_
36e3cf00d0SUpinder Malhi 
37e3cf00d0SUpinder Malhi #include <linux/if.h>
382183b990SUpinder Malhi #include <linux/netdevice.h>
3969ae5439SSelvin Xavier #include <linux/if_ether.h>
40e3cf00d0SUpinder Malhi #include <linux/pci.h>
412183b990SUpinder Malhi #include <linux/in.h>
42e3cf00d0SUpinder Malhi 
43e3cf00d0SUpinder Malhi #include "usnic_abi.h"
442183b990SUpinder Malhi #include "usnic_common_pkt_hdr.h"
45e3cf00d0SUpinder Malhi #include "vnic_devcmd.h"
46e3cf00d0SUpinder Malhi 
47e3cf00d0SUpinder Malhi struct usnic_fwd_dev {
48e3cf00d0SUpinder Malhi 	struct pci_dev			*pdev;
49e3cf00d0SUpinder Malhi 	struct net_device		*netdev;
50e3cf00d0SUpinder Malhi 	spinlock_t			lock;
512183b990SUpinder Malhi 	/*
522183b990SUpinder Malhi 	 * The following fields can be read directly off the device.
532183b990SUpinder Malhi 	 * However, they should be set by a accessor function, except name,
542183b990SUpinder Malhi 	 * which cannot be changed.
552183b990SUpinder Malhi 	 */
562183b990SUpinder Malhi 	bool				link_up;
572183b990SUpinder Malhi 	char				mac[ETH_ALEN];
582183b990SUpinder Malhi 	unsigned int			mtu;
593f92bed3SUpinder Malhi 	__be32				inaddr;
607cfcc71eSBart Van Assche 	char				name[IFNAMSIZ];
61e3cf00d0SUpinder Malhi };
62e3cf00d0SUpinder Malhi 
632183b990SUpinder Malhi struct usnic_fwd_flow {
642183b990SUpinder Malhi 	uint32_t			flow_id;
65e3cf00d0SUpinder Malhi 	struct usnic_fwd_dev		*ufdev;
662183b990SUpinder Malhi 	unsigned int			vnic_idx;
672183b990SUpinder Malhi };
682183b990SUpinder Malhi 
692183b990SUpinder Malhi struct usnic_filter_action {
702183b990SUpinder Malhi 	int				vnic_idx;
712183b990SUpinder Malhi 	struct filter_action		action;
72e3cf00d0SUpinder Malhi };
73e3cf00d0SUpinder Malhi 
74e3cf00d0SUpinder Malhi struct usnic_fwd_dev *usnic_fwd_dev_alloc(struct pci_dev *pdev);
75e3cf00d0SUpinder Malhi void usnic_fwd_dev_free(struct usnic_fwd_dev *ufdev);
762183b990SUpinder Malhi 
77*fd92213eSJakub Kicinski void usnic_fwd_set_mac(struct usnic_fwd_dev *ufdev, const char mac[ETH_ALEN]);
785d50f400SLeon Romanovsky void usnic_fwd_add_ipaddr(struct usnic_fwd_dev *ufdev, __be32 inaddr);
793f92bed3SUpinder Malhi void usnic_fwd_del_ipaddr(struct usnic_fwd_dev *ufdev);
802183b990SUpinder Malhi void usnic_fwd_carrier_up(struct usnic_fwd_dev *ufdev);
812183b990SUpinder Malhi void usnic_fwd_carrier_down(struct usnic_fwd_dev *ufdev);
822183b990SUpinder Malhi void usnic_fwd_set_mtu(struct usnic_fwd_dev *ufdev, unsigned int mtu);
832183b990SUpinder Malhi 
842183b990SUpinder Malhi /*
852183b990SUpinder Malhi  * Allocate a flow on this forwarding device. Whoever calls this function,
862183b990SUpinder Malhi  * must monitor netdev events on ufdev's netdevice. If NETDEV_REBOOT or
872183b990SUpinder Malhi  * NETDEV_DOWN is seen, flow will no longer function and must be
882183b990SUpinder Malhi  * immediately freed by calling usnic_dealloc_flow.
892183b990SUpinder Malhi  */
902183b990SUpinder Malhi struct usnic_fwd_flow*
912183b990SUpinder Malhi usnic_fwd_alloc_flow(struct usnic_fwd_dev *ufdev, struct filter *filter,
922183b990SUpinder Malhi 				struct usnic_filter_action *action);
932183b990SUpinder Malhi int usnic_fwd_dealloc_flow(struct usnic_fwd_flow *flow);
942183b990SUpinder Malhi int usnic_fwd_enable_qp(struct usnic_fwd_dev *ufdev, int vnic_idx, int qp_idx);
952183b990SUpinder Malhi int usnic_fwd_disable_qp(struct usnic_fwd_dev *ufdev, int vnic_idx, int qp_idx);
962183b990SUpinder Malhi 
usnic_fwd_init_usnic_filter(struct filter * filter,uint32_t usnic_id)972183b990SUpinder Malhi static inline void usnic_fwd_init_usnic_filter(struct filter *filter,
982183b990SUpinder Malhi 						uint32_t usnic_id)
992183b990SUpinder Malhi {
1002183b990SUpinder Malhi 	filter->type = FILTER_USNIC_ID;
10169ae5439SSelvin Xavier 	filter->u.usnic.ethtype = ETH_P_IBOE;
1022183b990SUpinder Malhi 	filter->u.usnic.flags = FILTER_FIELD_USNIC_ETHTYPE |
1032183b990SUpinder Malhi 				FILTER_FIELD_USNIC_ID |
1042183b990SUpinder Malhi 				FILTER_FIELD_USNIC_PROTO;
1052183b990SUpinder Malhi 	filter->u.usnic.proto_version = (USNIC_ROCE_GRH_VER <<
1062183b990SUpinder Malhi 					 USNIC_ROCE_GRH_VER_SHIFT) |
1072183b990SUpinder Malhi 					 USNIC_PROTO_VER;
1082183b990SUpinder Malhi 	filter->u.usnic.usnic_id = usnic_id;
1092183b990SUpinder Malhi }
110e3cf00d0SUpinder Malhi 
usnic_fwd_init_udp_filter(struct filter * filter,uint32_t daddr,uint16_t dport)1113f92bed3SUpinder Malhi static inline void usnic_fwd_init_udp_filter(struct filter *filter,
1123f92bed3SUpinder Malhi 						uint32_t daddr, uint16_t dport)
1133f92bed3SUpinder Malhi {
1143f92bed3SUpinder Malhi 	filter->type = FILTER_IPV4_5TUPLE;
1153f92bed3SUpinder Malhi 	filter->u.ipv4.flags = FILTER_FIELD_5TUP_PROTO;
1163f92bed3SUpinder Malhi 	filter->u.ipv4.protocol = PROTO_UDP;
1173f92bed3SUpinder Malhi 
1183f92bed3SUpinder Malhi 	if (daddr) {
1193f92bed3SUpinder Malhi 		filter->u.ipv4.flags |= FILTER_FIELD_5TUP_DST_AD;
1203f92bed3SUpinder Malhi 		filter->u.ipv4.dst_addr = daddr;
1213f92bed3SUpinder Malhi 	}
1223f92bed3SUpinder Malhi 
1233f92bed3SUpinder Malhi 	if (dport) {
1243f92bed3SUpinder Malhi 		filter->u.ipv4.flags |= FILTER_FIELD_5TUP_DST_PT;
1253f92bed3SUpinder Malhi 		filter->u.ipv4.dst_port = dport;
1263f92bed3SUpinder Malhi 	}
1273f92bed3SUpinder Malhi }
1283f92bed3SUpinder Malhi 
129e3cf00d0SUpinder Malhi #endif /* !USNIC_FWD_H_ */
130