Contributors: 11
| Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
| Roland Dreier |
146 |
44.11% |
2 |
10.53% |
| Haggai Eran |
94 |
28.40% |
3 |
15.79% |
| Shiraz Saleem |
44 |
13.29% |
2 |
10.53% |
| Jason Gunthorpe |
29 |
8.76% |
5 |
26.32% |
| Moni Shoua |
4 |
1.21% |
1 |
5.26% |
| Shachar Raindel |
3 |
0.91% |
1 |
5.26% |
| Yishai Hadas |
3 |
0.91% |
1 |
5.26% |
| Alexey Dobriyan |
3 |
0.91% |
1 |
5.26% |
| Leon Romanovsky |
2 |
0.60% |
1 |
5.26% |
| Artemy Kovalyov |
2 |
0.60% |
1 |
5.26% |
| Joachim Fenkes |
1 |
0.30% |
1 |
5.26% |
| Total |
331 |
|
19 |
|
/* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
/*
* Copyright (c) 2007 Cisco Systems. All rights reserved.
*/
#ifndef IB_UMEM_H
#define IB_UMEM_H
#include <linux/list.h>
#include <linux/scatterlist.h>
#include <linux/workqueue.h>
#include <rdma/ib_verbs.h>
struct ib_ucontext;
struct ib_umem_odp;
struct ib_umem {
struct ib_device *ibdev;
struct mm_struct *owning_mm;
size_t length;
unsigned long address;
u32 writable : 1;
u32 is_odp : 1;
struct work_struct work;
struct sg_table sg_head;
int nmap;
unsigned int sg_nents;
};
/* Returns the offset of the umem start relative to the first page. */
static inline int ib_umem_offset(struct ib_umem *umem)
{
return umem->address & ~PAGE_MASK;
}
static inline size_t ib_umem_num_pages(struct ib_umem *umem)
{
return (ALIGN(umem->address + umem->length, PAGE_SIZE) -
ALIGN_DOWN(umem->address, PAGE_SIZE)) >>
PAGE_SHIFT;
}
#ifdef CONFIG_INFINIBAND_USER_MEM
struct ib_umem *ib_umem_get(struct ib_device *device, unsigned long addr,
size_t size, int access);
void ib_umem_release(struct ib_umem *umem);
int ib_umem_page_count(struct ib_umem *umem);
int ib_umem_copy_from(void *dst, struct ib_umem *umem, size_t offset,
size_t length);
unsigned long ib_umem_find_best_pgsz(struct ib_umem *umem,
unsigned long pgsz_bitmap,
unsigned long virt);
#else /* CONFIG_INFINIBAND_USER_MEM */
#include <linux/err.h>
static inline struct ib_umem *ib_umem_get(struct ib_device *device,
unsigned long addr, size_t size,
int access)
{
return ERR_PTR(-EINVAL);
}
static inline void ib_umem_release(struct ib_umem *umem) { }
static inline int ib_umem_page_count(struct ib_umem *umem) { return 0; }
static inline int ib_umem_copy_from(void *dst, struct ib_umem *umem, size_t offset,
size_t length) {
return -EINVAL;
}
static inline int ib_umem_find_best_pgsz(struct ib_umem *umem,
unsigned long pgsz_bitmap,
unsigned long virt) {
return -EINVAL;
}
#endif /* CONFIG_INFINIBAND_USER_MEM */
#endif /* IB_UMEM_H */