mirror of
https://github.com/qemu/qemu.git
synced 2025-07-28 04:52:49 +00:00

The control over the RDMA device's GID table is done by updating the device's Ethernet function addresses. Usually the first GID entry is determined by the MAC address, the second by the first IPv6 address and the third by the IPv4 address. Other entries can be added by adding more IP addresses. The opposite is the same, i.e. whenever an address is removed, the corresponding GID entry is removed. The process is done by the network and RDMA stacks. Whenever an address is added the ib_core driver is notified and calls the device driver add_gid function which in turn update the device. To support this in pvrdma device we need to hook into the create_bind and destroy_bind HW commands triggered by pvrdma driver in guest. Whenever a change is made to the pvrdma port's GID table a special QMP message is sent to be processed by libvirt to update the address of the backend Ethernet device. Signed-off-by: Yuval Shaia <yuval.shaia@oracle.com> Reviewed-by: Marcel Apfelbaum<marcel.apfelbaum@gmail.com> Signed-off-by: Marcel Apfelbaum <marcel.apfelbaum@gmail.com>
67 lines
1.5 KiB
C
67 lines
1.5 KiB
C
/*
|
|
* RDMA device: Debug utilities
|
|
*
|
|
* Copyright (C) 2018 Oracle
|
|
* Copyright (C) 2018 Red Hat Inc
|
|
*
|
|
*
|
|
* Authors:
|
|
* Yuval Shaia <yuval.shaia@oracle.com>
|
|
* Marcel Apfelbaum <marcel@redhat.com>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef RDMA_UTILS_H
|
|
#define RDMA_UTILS_H
|
|
|
|
#include "hw/pci/pci.h"
|
|
#include "sysemu/dma.h"
|
|
#include "stdio.h"
|
|
|
|
#define pr_info(fmt, ...) \
|
|
fprintf(stdout, "%s: %-20s (%3d): " fmt, "rdma", __func__, __LINE__,\
|
|
## __VA_ARGS__)
|
|
|
|
#define pr_err(fmt, ...) \
|
|
fprintf(stderr, "%s: Error at %-20s (%3d): " fmt, "rdma", __func__, \
|
|
__LINE__, ## __VA_ARGS__)
|
|
|
|
#ifdef PVRDMA_DEBUG
|
|
extern unsigned long pr_dbg_cnt;
|
|
|
|
#define init_pr_dbg(void) \
|
|
{ \
|
|
pr_dbg_cnt = 0; \
|
|
}
|
|
|
|
#define pr_dbg(fmt, ...) \
|
|
fprintf(stdout, "%lx %ld: %-20s (%3d): " fmt, pthread_self(), pr_dbg_cnt++, \
|
|
__func__, __LINE__, ## __VA_ARGS__)
|
|
|
|
#define pr_dbg_buf(title, buf, len) \
|
|
{ \
|
|
int i; \
|
|
char *b = g_malloc0(len * 3 + 1); \
|
|
char b1[4]; \
|
|
for (i = 0; i < len; i++) { \
|
|
sprintf(b1, "%.2X ", buf[i] & 0x000000FF); \
|
|
strcat(b, b1); \
|
|
} \
|
|
pr_dbg("%s (%d): %s\n", title, len, b); \
|
|
g_free(b); \
|
|
}
|
|
|
|
#else
|
|
#define init_pr_dbg(void)
|
|
#define pr_dbg(fmt, ...)
|
|
#define pr_dbg_buf(title, buf, len)
|
|
#endif
|
|
|
|
void *rdma_pci_dma_map(PCIDevice *dev, dma_addr_t addr, dma_addr_t plen);
|
|
void rdma_pci_dma_unmap(PCIDevice *dev, void *buffer, dma_addr_t len);
|
|
|
|
#endif
|