f20b553d75
Since the FW can be shared between PCI functions it is common that more than one health poll will detected a failure, this can lead to multiple resets. The solution is to use a FW locking mechanism using semaphore space to provide a way to synchronize between functions. The FW semaphore is acquired via config cycle access. First the VSEC gateway must be acquired, then the semaphore can be locked by writing a value to it and confirmed it's locked by reading the same value back. The process in the same to free the semaphore, except the value written should be zero. Submitted by: slavash@ MFC after: 1 week Sponsored by: Mellanox Technologies
41 lines
723 B
Makefile
41 lines
723 B
Makefile
# $FreeBSD$
|
|
.PATH: ${SRCTOP}/sys/dev/mlx5/mlx5_core
|
|
|
|
KMOD=mlx5
|
|
SRCS= \
|
|
mlx5_alloc.c \
|
|
mlx5_cmd.c \
|
|
mlx5_cq.c \
|
|
mlx5_crspace.c \
|
|
mlx5_diagnostics.c \
|
|
mlx5_eq.c \
|
|
mlx5_fs_cmd.c \
|
|
mlx5_fs_tree.c \
|
|
mlx5_fw.c \
|
|
mlx5_fwdump.c \
|
|
mlx5_fwdump_regmaps.c \
|
|
mlx5_health.c \
|
|
mlx5_mad.c \
|
|
mlx5_main.c \
|
|
mlx5_mcg.c \
|
|
mlx5_mr.c \
|
|
mlx5_pagealloc.c \
|
|
mlx5_pd.c \
|
|
mlx5_port.c \
|
|
mlx5_qp.c \
|
|
mlx5_srq.c \
|
|
mlx5_transobj.c \
|
|
mlx5_uar.c \
|
|
mlx5_vport.c \
|
|
mlx5_vsc.c \
|
|
mlx5_wq.c \
|
|
device_if.h bus_if.h vnode_if.h pci_if.h \
|
|
opt_inet.h opt_inet6.h opt_rss.h
|
|
|
|
CFLAGS+= -I${SRCTOP}/sys/ofed/include
|
|
CFLAGS+= -I${SRCTOP}/sys/compat/linuxkpi/common/include
|
|
|
|
.include <bsd.kmod.mk>
|
|
|
|
CFLAGS+= -Wno-cast-qual -Wno-pointer-arith ${GCC_MS_EXTENSIONS}
|