blob: fb07eed9e4028345a02aac983269241012de2fae [file] [log] [blame]
Moni Shoua8700e3e2016-06-16 16:45:23 +03001/*
2 * Copyright (c) 2016 Mellanox Technologies Ltd. All rights reserved.
3 * Copyright (c) 2015 System Fabric Works, Inc. All rights reserved.
4 *
5 * This software is available to you under a choice of one of two
6 * licenses. You may choose to be licensed under the terms of the GNU
7 * General Public License (GPL) Version 2, available from the file
8 * COPYING in the main directory of this source tree, or the
9 * OpenIB.org BSD license below:
10 *
11 * Redistribution and use in source and binary forms, with or
12 * without modification, are permitted provided that the following
13 * conditions are met:
14 *
15 * - Redistributions of source code must retain the above
16 * copyright notice, this list of conditions and the following
17 * disclaimer.
18 *
19 * - Redistributions in binary form must reproduce the above
20 * copyright notice, this list of conditions and the following
21 * disclaimer in the documentation and/or other materials
22 * provided with the distribution.
23 *
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
28 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
29 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
30 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
31 * SOFTWARE.
32 */
33
34#ifndef RXE_H
35#define RXE_H
36
Parav Pandite404f942016-09-28 20:26:26 +000037#ifdef pr_fmt
38#undef pr_fmt
39#endif
40#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
41
Moni Shoua8700e3e2016-06-16 16:45:23 +030042#include <linux/module.h>
43#include <linux/skbuff.h>
44#include <linux/crc32.h>
45
46#include <rdma/ib_verbs.h>
47#include <rdma/ib_user_verbs.h>
48#include <rdma/ib_pack.h>
49#include <rdma/ib_smi.h>
50#include <rdma/ib_umem.h>
51#include <rdma/ib_cache.h>
52#include <rdma/ib_addr.h>
yonatanccee26882017-04-20 20:55:55 +030053#include <crypto/hash.h>
Moni Shoua8700e3e2016-06-16 16:45:23 +030054
55#include "rxe_net.h"
56#include "rxe_opcode.h"
57#include "rxe_hdr.h"
58#include "rxe_param.h"
59#include "rxe_verbs.h"
Leon Romanovsky9ef77bd2018-01-01 13:07:11 +020060#include "rxe_loc.h"
Moni Shoua8700e3e2016-06-16 16:45:23 +030061
Jason Gunthorpef2e9bfa2018-03-20 14:19:50 -060062/*
63 * Version 1 and Version 2 are identical on 64 bit machines, but on 32 bit
64 * machines Version 2 has a different struct layout.
65 */
66#define RXE_UVERBS_ABI_VERSION 2
Moni Shoua8700e3e2016-06-16 16:45:23 +030067
Moni Shoua8700e3e2016-06-16 16:45:23 +030068#define RXE_ROCE_V2_SPORT (0xc000)
69
yonatanccee26882017-04-20 20:55:55 +030070static inline u32 rxe_crc32(struct rxe_dev *rxe,
71 u32 crc, void *next, size_t len)
72{
David Millerd41519a2017-06-02 11:28:54 -040073 u32 retval;
yonatanccee26882017-04-20 20:55:55 +030074 int err;
75
76 SHASH_DESC_ON_STACK(shash, rxe->tfm);
77
78 shash->tfm = rxe->tfm;
yonatanccee26882017-04-20 20:55:55 +030079 *(u32 *)shash_desc_ctx(shash) = crc;
80 err = crypto_shash_update(shash, next, len);
81 if (unlikely(err)) {
82 pr_warn_ratelimited("failed crc calculation, err: %d\n", err);
83 return crc32_le(crc, next, len);
84 }
85
David Millerd41519a2017-06-02 11:28:54 -040086 retval = *(u32 *)shash_desc_ctx(shash);
87 barrier_data(shash_desc_ctx(shash));
88 return retval;
yonatanccee26882017-04-20 20:55:55 +030089}
90
Zhu Yanjun0dff4632018-04-20 10:30:54 -040091void rxe_set_mtu(struct rxe_dev *rxe, unsigned int dev_mtu);
Moni Shoua8700e3e2016-06-16 16:45:23 +030092
Steve Wise66920e12019-02-15 11:03:57 -080093int rxe_add(struct rxe_dev *rxe, unsigned int mtu, const char *ibdev_name);
Moni Shoua8700e3e2016-06-16 16:45:23 +030094
Yuval Shaia10c47d52018-04-20 17:05:03 +030095void rxe_rcv(struct sk_buff *skb);
Moni Shoua8700e3e2016-06-16 16:45:23 +030096
Jason Gunthorpe4c173f52019-02-12 21:12:52 -070097/* The caller must do a matching ib_device_put(&dev->ib_dev) */
98static inline struct rxe_dev *rxe_get_dev_from_net(struct net_device *ndev)
99{
100 struct ib_device *ibdev =
101 ib_device_get_by_netdev(ndev, RDMA_DRIVER_RXE);
102
103 if (!ibdev)
104 return NULL;
105 return container_of(ibdev, struct rxe_dev, ib_dev);
106}
107
Moni Shoua8700e3e2016-06-16 16:45:23 +0300108void rxe_port_up(struct rxe_dev *rxe);
109void rxe_port_down(struct rxe_dev *rxe);
Yuval Shaiaf55c3ec2018-12-14 08:05:49 -0800110void rxe_set_port_state(struct rxe_dev *rxe);
Moni Shoua8700e3e2016-06-16 16:45:23 +0300111
112#endif /* RXE_H */