blob: 9db06269afb0bb38be783d921401c838789d421f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
#
# RDMA (Remote DMA) wrapper CMake fragment, to be included in CMakeLists.txt
#
# Optional RDMA support. Requires ibverbs and rdma_cm.
include(CheckIncludeFiles)
include(CheckLibraryExists)
CHECK_LIBRARY_EXISTS (ibverbs ibv_create_qp "" HAVE_IBVERBS)
CHECK_LIBRARY_EXISTS (rdmacm rdma_create_id "" HAVE_RDMACM)
CHECK_INCLUDE_FILES (infiniband/verbs.h HAVE_IBVERBS_H)
CHECK_INCLUDE_FILES (rdma/rdma_cma.h HAVE_RDMACM_H)
set (rdma_default ${rdma_force})
if (HAVE_IBVERBS AND HAVE_IBVERBS_H)
if (HAVE_RDMACM AND HAVE_RDMACM_H)
set (rdma_default ON)
endif (HAVE_RDMACM AND HAVE_RDMACM_H)
endif (HAVE_IBVERBS AND HAVE_IBVERBS_H)
option(BUILD_RDMA "Build with support for Remote DMA protocols" ${rdma_default})
if (BUILD_RDMA)
if (NOT HAVE_IBVERBS)
message(FATAL_ERROR "libibverbs not found, required for RDMA support")
endif (NOT HAVE_IBVERBS)
if (NOT HAVE_RDMACM)
message(FATAL_ERROR "librdmacm not found, required for RDMA support")
endif (NOT HAVE_RDMACM)
if (NOT HAVE_IBVERBS_H)
message(FATAL_ERROR "ibverbs headers not found, required for RDMA support")
endif (NOT HAVE_IBVERBS_H)
if (NOT HAVE_RDMACM_H)
message(FATAL_ERROR "rdmacm headers not found, required for RDMA support")
endif (NOT HAVE_RDMACM_H)
set (rdma_SOURCES
qpid/sys/rdma/rdma_exception.h
qpid/sys/rdma/rdma_factories.cpp
qpid/sys/rdma/rdma_factories.h
qpid/sys/rdma/RdmaIO.cpp
qpid/sys/rdma/RdmaIO.h
qpid/sys/rdma/rdma_wrap.cpp
qpid/sys/rdma/rdma_wrap.h
)
add_library (rdmawrap SHARED ${rdma_SOURCES})
target_link_libraries (rdmawrap qpidcommon rdmacm ibverbs)
set_target_properties (rdmawrap PROPERTIES
VERSION ${rdmawrap_version}
SOVERSION ${rdmawrap_version_major})
if (CMAKE_COMPILER_IS_GNUCXX)
set_target_properties(rdmawrap PROPERTIES
COMPILE_FLAGS -Wno-missing-field-initializers)
endif (CMAKE_COMPILER_IS_GNUCXX)
install (TARGETS rdmawrap
DESTINATION ${QPID_INSTALL_LIBDIR}
COMPONENT ${QPID_COMPONENT_COMMON})
add_library (rdma MODULE qpid/sys/RdmaIOPlugin.cpp)
target_link_libraries (rdma qpidbroker qpidcommon rdmawrap)
set_target_properties (rdma PROPERTIES
COMPILE_DEFINITIONS _IN_QPID_BROKER
PREFIX "")
if (CMAKE_COMPILER_IS_GNUCXX)
set_target_properties(rdma PROPERTIES
COMPILE_FLAGS -Wno-missing-field-initializers)
endif (CMAKE_COMPILER_IS_GNUCXX)
install (TARGETS rdma
DESTINATION ${QPIDD_MODULE_DIR}
COMPONENT ${QPID_COMPONENT_BROKER})
add_library (rdmaconnector MODULE qpid/client/RdmaConnector.cpp)
target_link_libraries (rdmaconnector qpidclient qpidcommon rdmawrap)
set_target_properties (rdmaconnector PROPERTIES
PREFIX "")
if (CMAKE_COMPILER_IS_GNUCXX)
set_target_properties(rdmaconnector PROPERTIES
COMPILE_FLAGS -Wno-missing-field-initializers)
endif (CMAKE_COMPILER_IS_GNUCXX)
install (TARGETS rdmaconnector
DESTINATION ${QPIDC_MODULE_DIR}
COMPONENT ${QPID_COMPONENT_CLIENT})
# RDMA test/sample programs
add_executable (RdmaServer qpid/sys/rdma/RdmaServer.cpp)
target_link_libraries (RdmaServer rdmawrap qpidcommon)
add_executable (RdmaClient qpid/sys/rdma/RdmaClient.cpp)
target_link_libraries (RdmaClient rdmawrap qpidcommon)
if (CMAKE_COMPILER_IS_GNUCXX)
set_target_properties(RdmaClient PROPERTIES
COMPILE_FLAGS -Wno-missing-field-initializers)
endif (CMAKE_COMPILER_IS_GNUCXX)
endif (BUILD_RDMA)
|