mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-12-27 08:45:26 -05:00
Use struct dibs_dmb instead of struct smc_dmb and move the corresponding client tables to dibs_dev. Leave driver specific implementation details like sba in the device drivers. Register and unregister dmbs via dibs_dev_ops. A dmb is dedicated to a single client, but a dibs device can have dmbs for more than one client. Trigger dibs clients via dibs_client_ops->handle_irq(), when data is received into a dmb. For dibs_loopback replace scheduling an smcd receive tasklet with calling dibs_client_ops->handle_irq(). For loopback devices attach_dmb(), detach_dmb() and move_data() need to access the dmb tables, so move those to dibs_dev_ops in this patch as well. Remove remaining definitions of smc_loopback as they are no longer required, now that everything is in dibs_loopback. Note that struct ism_client and struct ism_dev are still required in smc until a follow-on patch moves event handling to dibs. (Loopback does not use events). Signed-off-by: Alexandra Winter <wintera@linux.ibm.com> Link: https://patch.msgid.link/20250918110500.1731261-14-wintera@linux.ibm.com Signed-off-by: Paolo Abeni <pabeni@redhat.com>
58 lines
1.1 KiB
C
58 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* dibs loopback (aka loopback-ism) device structure definitions.
|
|
*
|
|
* Copyright (c) 2024, Alibaba Inc.
|
|
*
|
|
* Author: Wen Gu <guwen@linux.alibaba.com>
|
|
* Tony Lu <tonylu@linux.alibaba.com>
|
|
*
|
|
*/
|
|
|
|
#ifndef _DIBS_LOOPBACK_H
|
|
#define _DIBS_LOOPBACK_H
|
|
|
|
#include <linux/dibs.h>
|
|
#include <linux/hashtable.h>
|
|
#include <linux/spinlock.h>
|
|
#include <linux/types.h>
|
|
#include <linux/wait.h>
|
|
|
|
#if IS_ENABLED(CONFIG_DIBS_LO)
|
|
#define DIBS_LO_DMBS_HASH_BITS 12
|
|
#define DIBS_LO_MAX_DMBS 5000
|
|
|
|
struct dibs_lo_dmb_node {
|
|
struct hlist_node list;
|
|
u64 token;
|
|
u32 len;
|
|
u32 sba_idx;
|
|
void *cpu_addr;
|
|
dma_addr_t dma_addr;
|
|
refcount_t refcnt;
|
|
};
|
|
|
|
struct dibs_lo_dev {
|
|
struct dibs_dev *dibs;
|
|
atomic_t dmb_cnt;
|
|
rwlock_t dmb_ht_lock;
|
|
DECLARE_BITMAP(sba_idx_mask, DIBS_LO_MAX_DMBS);
|
|
DECLARE_HASHTABLE(dmb_ht, DIBS_LO_DMBS_HASH_BITS);
|
|
wait_queue_head_t ldev_release;
|
|
};
|
|
|
|
int dibs_loopback_init(void);
|
|
void dibs_loopback_exit(void);
|
|
#else
|
|
static inline int dibs_loopback_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void dibs_loopback_exit(void)
|
|
{
|
|
}
|
|
#endif
|
|
|
|
#endif /* _DIBS_LOOPBACK_H */
|