]>
Commit | Line | Data |
---|---|---|
c9c0d073 | 1 | dnl # |
fc0c72b1 | 2 | dnl # Default ZFS kernel configuration |
c9c0d073 BB |
3 | dnl # |
4 | AC_DEFUN([ZFS_AC_CONFIG_KERNEL], [ | |
5 | ZFS_AC_KERNEL | |
6 | ZFS_AC_SPL | |
319a99a3 | 7 | ZFS_AC_TEST_MODULE |
c9c0d073 | 8 | ZFS_AC_KERNEL_CONFIG |
0b39b9f9 | 9 | ZFS_AC_KERNEL_DECLARE_EVENT_CLASS |
37f9dac5 | 10 | ZFS_AC_KERNEL_CURRENT_BIO_TAIL |
bbb1b6ce | 11 | ZFS_AC_KERNEL_SUBMIT_BIO |
c9c0d073 | 12 | ZFS_AC_KERNEL_BDEV_BLOCK_DEVICE_OPERATIONS |
a1d9543a | 13 | ZFS_AC_KERNEL_BLOCK_DEVICE_OPERATIONS_RELEASE_VOID |
c9c0d073 | 14 | ZFS_AC_KERNEL_TYPE_FMODE_T |
b5a28807 | 15 | ZFS_AC_KERNEL_3ARG_BLKDEV_GET |
45066d1f | 16 | ZFS_AC_KERNEL_BLKDEV_GET_BY_PATH |
c9c0d073 | 17 | ZFS_AC_KERNEL_OPEN_BDEV_EXCLUSIVE |
2b7ab9d4 | 18 | ZFS_AC_KERNEL_LOOKUP_BDEV |
c9c0d073 BB |
19 | ZFS_AC_KERNEL_INVALIDATE_BDEV_ARGS |
20 | ZFS_AC_KERNEL_BDEV_LOGICAL_BLOCK_SIZE | |
2404b014 | 21 | ZFS_AC_KERNEL_BDEV_PHYSICAL_BLOCK_SIZE |
d4541210 | 22 | ZFS_AC_KERNEL_BIO_BVEC_ITER |
f4af6bb7 BB |
23 | ZFS_AC_KERNEL_BIO_FAILFAST_DTD |
24 | ZFS_AC_KERNEL_REQ_FAILFAST_MASK | |
c9c0d073 | 25 | ZFS_AC_KERNEL_BIO_END_IO_T_ARGS |
37f9dac5 RY |
26 | ZFS_AC_KERNEL_BIO_RW_BARRIER |
27 | ZFS_AC_KERNEL_BIO_RW_DISCARD | |
b18019d2 | 28 | ZFS_AC_KERNEL_BLK_QUEUE_FLUSH |
34037afe ED |
29 | ZFS_AC_KERNEL_BLK_QUEUE_MAX_HW_SECTORS |
30 | ZFS_AC_KERNEL_BLK_QUEUE_MAX_SEGMENTS | |
e6603b7c | 31 | ZFS_AC_KERNEL_BLK_QUEUE_HAVE_BIO_RW_UNPLUG |
c9c0d073 | 32 | ZFS_AC_KERNEL_GET_DISK_RO |
b5a28807 | 33 | ZFS_AC_KERNEL_GET_GENDISK |
ee5fd0bb | 34 | ZFS_AC_KERNEL_DISCARD_GRANULARITY |
777d4af8 | 35 | ZFS_AC_KERNEL_CONST_XATTR_HANDLER |
232604b5 | 36 | ZFS_AC_KERNEL_XATTR_HANDLER_NAME |
f9637c6c BB |
37 | ZFS_AC_KERNEL_XATTR_HANDLER_GET |
38 | ZFS_AC_KERNEL_XATTR_HANDLER_SET | |
023699cd MM |
39 | ZFS_AC_KERNEL_XATTR_HANDLER_LIST |
40 | ZFS_AC_KERNEL_INODE_OWNER_OR_CAPABLE | |
41 | ZFS_AC_KERNEL_POSIX_ACL_FROM_XATTR_USERNS | |
42 | ZFS_AC_KERNEL_POSIX_ACL_RELEASE | |
43 | ZFS_AC_KERNEL_POSIX_ACL_CHMOD | |
44 | ZFS_AC_KERNEL_POSIX_ACL_CACHING | |
45 | ZFS_AC_KERNEL_POSIX_ACL_EQUIV_MODE_WANTS_UMODE_T | |
46 | ZFS_AC_KERNEL_INODE_OPERATIONS_PERMISSION | |
47 | ZFS_AC_KERNEL_INODE_OPERATIONS_PERMISSION_WITH_NAMEIDATA | |
48 | ZFS_AC_KERNEL_INODE_OPERATIONS_CHECK_ACL | |
49 | ZFS_AC_KERNEL_INODE_OPERATIONS_CHECK_ACL_WITH_FLAGS | |
50 | ZFS_AC_KERNEL_INODE_OPERATIONS_GET_ACL | |
51 | ZFS_AC_KERNEL_CURRENT_UMASK | |
47621f3d | 52 | ZFS_AC_KERNEL_SHOW_OPTIONS |
534759fa | 53 | ZFS_AC_KERNEL_FILE_INODE |
adcd70bd | 54 | ZFS_AC_KERNEL_FSYNC |
2c395def | 55 | ZFS_AC_KERNEL_EVICT_INODE |
8780c539 | 56 | ZFS_AC_KERNEL_DIRTY_INODE_WITH_FLAGS |
ab26409d BB |
57 | ZFS_AC_KERNEL_NR_CACHED_OBJECTS |
58 | ZFS_AC_KERNEL_FREE_CACHED_OBJECTS | |
cb2d1901 | 59 | ZFS_AC_KERNEL_FALLOCATE |
95f5c63b | 60 | ZFS_AC_KERNEL_MKDIR_UMODE_T |
8f195a90 | 61 | ZFS_AC_KERNEL_LOOKUP_NAMEIDATA |
558ef6d0 | 62 | ZFS_AC_KERNEL_CREATE_NAMEIDATA |
beeed459 | 63 | ZFS_AC_KERNEL_GET_LINK |
bd29109f | 64 | ZFS_AC_KERNEL_PUT_LINK |
ea1fdf46 | 65 | ZFS_AC_KERNEL_TRUNCATE_RANGE |
ebe7e575 | 66 | ZFS_AC_KERNEL_AUTOMOUNT |
756c3e5a | 67 | ZFS_AC_KERNEL_ENCODE_FH_WITH_INODE |
393b44c7 | 68 | ZFS_AC_KERNEL_COMMIT_METADATA |
739a1a82 | 69 | ZFS_AC_KERNEL_CLEAR_INODE |
bdf4328b | 70 | ZFS_AC_KERNEL_INSERT_INODE_LOCKED |
6a0936ba | 71 | ZFS_AC_KERNEL_D_MAKE_ROOT |
055656d4 | 72 | ZFS_AC_KERNEL_D_OBTAIN_ALIAS |
218b4e0a | 73 | ZFS_AC_KERNEL_D_PRUNE_ALIASES |
f1a05fa1 NB |
74 | ZFS_AC_KERNEL_D_SET_D_OP |
75 | ZFS_AC_KERNEL_D_REVALIDATE_NAMEIDATA | |
76 | ZFS_AC_KERNEL_CONST_DENTRY_OPERATIONS | |
b3129792 | 77 | ZFS_AC_KERNEL_TRUNCATE_SETSIZE |
5c03efc3 | 78 | ZFS_AC_KERNEL_6ARGS_SECURITY_INODE_INIT_SECURITY |
166dd49d | 79 | ZFS_AC_KERNEL_CALLBACK_SECURITY_INODE_INIT_SECURITY |
2cf7f52b | 80 | ZFS_AC_KERNEL_MOUNT_NODEV |
ab26409d | 81 | ZFS_AC_KERNEL_SHRINK |
90947b23 | 82 | ZFS_AC_KERNEL_SHRINK_CONTROL_HAS_NID |
dba1d705 | 83 | ZFS_AC_KERNEL_S_INSTANCES_LIST_HEAD |
ee930353 | 84 | ZFS_AC_KERNEL_S_D_OP |
5547c2f1 | 85 | ZFS_AC_KERNEL_BDI_SETUP_AND_REGISTER |
28eb9213 | 86 | ZFS_AC_KERNEL_SET_NLINK |
6d1d976b | 87 | ZFS_AC_KERNEL_ELEVATOR_CHANGE |
3c203610 | 88 | ZFS_AC_KERNEL_5ARG_SGET |
802e7b5f | 89 | ZFS_AC_KERNEL_LSEEK_EXECUTE |
0f37d0c8 | 90 | ZFS_AC_KERNEL_VFS_ITERATE |
57ae8400 | 91 | ZFS_AC_KERNEL_VFS_RW_ITERATE |
17888ae3 | 92 | ZFS_AC_KERNEL_KMAP_ATOMIC_ARGS |
278bee93 | 93 | ZFS_AC_KERNEL_FOLLOW_DOWN_ONE |
37f9dac5 | 94 | ZFS_AC_KERNEL_MAKE_REQUEST_FN |
8198d18c | 95 | ZFS_AC_KERNEL_GENERIC_IO_ACCT |
fc0c72b1 | 96 | ZFS_AC_KERNEL_FPU |
82a1b2d6 | 97 | ZFS_AC_KERNEL_KUID_HELPERS |
c9c0d073 | 98 | |
8366cd6a | 99 | AS_IF([test "$LINUX_OBJ" != "$LINUX"], [ |
6283f55e | 100 | KERNELMAKE_PARAMS="$KERNELMAKE_PARAMS O=$LINUX_OBJ" |
8366cd6a | 101 | ]) |
6283f55e BB |
102 | AC_SUBST(KERNELMAKE_PARAMS) |
103 | ||
104 | ||
c9c0d073 BB |
105 | dnl # -Wall -fno-strict-aliasing -Wstrict-prototypes and other |
106 | dnl # compiler options are added by the kernel build system. | |
8a7e1cee | 107 | KERNELCPPFLAGS="$KERNELCPPFLAGS $NO_UNUSED_BUT_SET_VARIABLE" |
c2d17fd8 | 108 | KERNELCPPFLAGS="$KERNELCPPFLAGS $NO_BOOL_COMPARE" |
c9c0d073 BB |
109 | KERNELCPPFLAGS="$KERNELCPPFLAGS -DHAVE_SPL -D_KERNEL" |
110 | KERNELCPPFLAGS="$KERNELCPPFLAGS -DTEXT_DOMAIN=\\\"zfs-linux-kernel\\\"" | |
c9c0d073 | 111 | |
c9c0d073 BB |
112 | AC_SUBST(KERNELCPPFLAGS) |
113 | ]) | |
114 | ||
115 | dnl # | |
116 | dnl # Detect name used for Module.symvers file in kernel | |
117 | dnl # | |
118 | AC_DEFUN([ZFS_AC_MODULE_SYMVERS], [ | |
119 | modpost=$LINUX/scripts/Makefile.modpost | |
120 | AC_MSG_CHECKING([kernel file name for module symbols]) | |
319a99a3 | 121 | AS_IF([test "x$enable_linux_builtin" != xyes -a -f "$modpost"], [ |
8366cd6a | 122 | AS_IF([grep -q Modules.symvers $modpost], [ |
c9c0d073 | 123 | LINUX_SYMBOLS=Modules.symvers |
8366cd6a | 124 | ], [ |
c9c0d073 | 125 | LINUX_SYMBOLS=Module.symvers |
8366cd6a | 126 | ]) |
a60b1c0a | 127 | |
8366cd6a | 128 | AS_IF([test ! -f "$LINUX_OBJ/$LINUX_SYMBOLS"], [ |
a60b1c0a BB |
129 | AC_MSG_ERROR([ |
130 | *** Please make sure the kernel devel package for your distribution | |
4e95cc99 | 131 | *** is installed. If you are building with a custom kernel, make sure the |
a60b1c0a BB |
132 | *** kernel is configured, built, and the '--with-linux=PATH' configure |
133 | *** option refers to the location of the kernel source.]) | |
8366cd6a PS |
134 | ]) |
135 | ], [ | |
c9c0d073 | 136 | LINUX_SYMBOLS=NONE |
8366cd6a | 137 | ]) |
c9c0d073 BB |
138 | AC_MSG_RESULT($LINUX_SYMBOLS) |
139 | AC_SUBST(LINUX_SYMBOLS) | |
140 | ]) | |
141 | ||
142 | dnl # | |
143 | dnl # Detect the kernel to be built against | |
144 | dnl # | |
145 | AC_DEFUN([ZFS_AC_KERNEL], [ | |
146 | AC_ARG_WITH([linux], | |
147 | AS_HELP_STRING([--with-linux=PATH], | |
148 | [Path to kernel source]), | |
149 | [kernelsrc="$withval"]) | |
150 | ||
151 | AC_ARG_WITH(linux-obj, | |
152 | AS_HELP_STRING([--with-linux-obj=PATH], | |
153 | [Path to kernel build objects]), | |
154 | [kernelbuild="$withval"]) | |
155 | ||
156 | AC_MSG_CHECKING([kernel source directory]) | |
8366cd6a PS |
157 | AS_IF([test -z "$kernelsrc"], [ |
158 | AS_IF([test -e "/lib/modules/$(uname -r)/source"], [ | |
1b94c25c BB |
159 | headersdir="/lib/modules/$(uname -r)/source" |
160 | sourcelink=$(readlink -f "$headersdir") | |
8366cd6a | 161 | ], [test -e "/lib/modules/$(uname -r)/build"], [ |
1b94c25c | 162 | headersdir="/lib/modules/$(uname -r)/build" |
c9c0d073 | 163 | sourcelink=$(readlink -f "$headersdir") |
8366cd6a | 164 | ], [ |
c9c0d073 | 165 | sourcelink=$(ls -1d /usr/src/kernels/* \ |
8366cd6a | 166 | /usr/src/linux-* \ |
c9c0d073 | 167 | 2>/dev/null | grep -v obj | tail -1) |
8366cd6a | 168 | ]) |
c9c0d073 | 169 | |
8366cd6a | 170 | AS_IF([test -n "$sourcelink" && test -e ${sourcelink}], [ |
c9c0d073 | 171 | kernelsrc=`readlink -f ${sourcelink}` |
8366cd6a | 172 | ], [ |
56a517ae | 173 | kernelsrc="[Not found]" |
8366cd6a PS |
174 | ]) |
175 | ], [ | |
176 | AS_IF([test "$kernelsrc" = "NONE"], [ | |
c9c0d073 | 177 | kernsrcver=NONE |
8366cd6a PS |
178 | ]) |
179 | ]) | |
c9c0d073 BB |
180 | |
181 | AC_MSG_RESULT([$kernelsrc]) | |
56a517ae BB |
182 | AS_IF([test ! -d "$kernelsrc"], [ |
183 | AC_MSG_ERROR([ | |
184 | *** Please make sure the kernel devel package for your distribution | |
4e95cc99 | 185 | *** is installed and then try again. If that fails, you can specify the |
56a517ae BB |
186 | *** location of the kernel source with the '--with-linux=PATH' option.]) |
187 | ]) | |
188 | ||
c9c0d073 | 189 | AC_MSG_CHECKING([kernel build directory]) |
8366cd6a PS |
190 | AS_IF([test -z "$kernelbuild"], [ |
191 | AS_IF([test -e "/lib/modules/$(uname -r)/build"], [ | |
1b94c25c | 192 | kernelbuild=`readlink -f /lib/modules/$(uname -r)/build` |
8366cd6a | 193 | ], [test -d ${kernelsrc}-obj/${target_cpu}/${target_cpu}], [ |
c9c0d073 | 194 | kernelbuild=${kernelsrc}-obj/${target_cpu}/${target_cpu} |
8366cd6a | 195 | ], [test -d ${kernelsrc}-obj/${target_cpu}/default], [ |
70574182 | 196 | kernelbuild=${kernelsrc}-obj/${target_cpu}/default |
8366cd6a | 197 | ], [test -d `dirname ${kernelsrc}`/build-${target_cpu}], [ |
c9c0d073 | 198 | kernelbuild=`dirname ${kernelsrc}`/build-${target_cpu} |
8366cd6a | 199 | ], [ |
c9c0d073 | 200 | kernelbuild=${kernelsrc} |
8366cd6a PS |
201 | ]) |
202 | ]) | |
c9c0d073 BB |
203 | AC_MSG_RESULT([$kernelbuild]) |
204 | ||
205 | AC_MSG_CHECKING([kernel source version]) | |
206 | utsrelease1=$kernelbuild/include/linux/version.h | |
207 | utsrelease2=$kernelbuild/include/linux/utsrelease.h | |
208 | utsrelease3=$kernelbuild/include/generated/utsrelease.h | |
8366cd6a | 209 | AS_IF([test -r $utsrelease1 && fgrep -q UTS_RELEASE $utsrelease1], [ |
c9c0d073 | 210 | utsrelease=linux/version.h |
8366cd6a | 211 | ], [test -r $utsrelease2 && fgrep -q UTS_RELEASE $utsrelease2], [ |
c9c0d073 | 212 | utsrelease=linux/utsrelease.h |
8366cd6a | 213 | ], [test -r $utsrelease3 && fgrep -q UTS_RELEASE $utsrelease3], [ |
c9c0d073 | 214 | utsrelease=generated/utsrelease.h |
8366cd6a | 215 | ]) |
c9c0d073 | 216 | |
8366cd6a | 217 | AS_IF([test "$utsrelease"], [ |
c9c0d073 BB |
218 | kernsrcver=`(echo "#include <$utsrelease>"; |
219 | echo "kernsrcver=UTS_RELEASE") | | |
220 | cpp -I $kernelbuild/include | | |
221 | grep "^kernsrcver=" | cut -d \" -f 2` | |
222 | ||
8366cd6a | 223 | AS_IF([test -z "$kernsrcver"], [ |
c9c0d073 BB |
224 | AC_MSG_RESULT([Not found]) |
225 | AC_MSG_ERROR([*** Cannot determine kernel version.]) | |
8366cd6a PS |
226 | ]) |
227 | ], [ | |
c9c0d073 | 228 | AC_MSG_RESULT([Not found]) |
319a99a3 ED |
229 | if test "x$enable_linux_builtin" != xyes; then |
230 | AC_MSG_ERROR([*** Cannot find UTS_RELEASE definition.]) | |
231 | else | |
232 | AC_MSG_ERROR([ | |
233 | *** Cannot find UTS_RELEASE definition. | |
234 | *** Please run 'make prepare' inside the kernel source tree.]) | |
235 | fi | |
8366cd6a | 236 | ]) |
c9c0d073 BB |
237 | |
238 | AC_MSG_RESULT([$kernsrcver]) | |
239 | ||
240 | LINUX=${kernelsrc} | |
241 | LINUX_OBJ=${kernelbuild} | |
242 | LINUX_VERSION=${kernsrcver} | |
243 | ||
244 | AC_SUBST(LINUX) | |
245 | AC_SUBST(LINUX_OBJ) | |
246 | AC_SUBST(LINUX_VERSION) | |
247 | ||
248 | ZFS_AC_MODULE_SYMVERS | |
249 | ]) | |
250 | ||
c9c0d073 BB |
251 | |
252 | dnl # | |
253 | dnl # Detect the SPL module to be built against | |
254 | dnl # | |
255 | AC_DEFUN([ZFS_AC_SPL], [ | |
256 | AC_ARG_WITH([spl], | |
257 | AS_HELP_STRING([--with-spl=PATH], | |
258 | [Path to spl source]), | |
c7e7ec19 OF |
259 | AS_IF([test "$withval" = "yes"], |
260 | AC_MSG_ERROR([--with-spl=PATH requires a PATH]), | |
261 | [splsrc="$withval"])) | |
c9c0d073 BB |
262 | |
263 | AC_ARG_WITH([spl-obj], | |
264 | AS_HELP_STRING([--with-spl-obj=PATH], | |
265 | [Path to spl build objects]), | |
266 | [splbuild="$withval"]) | |
267 | ||
51654737 CALP |
268 | AC_ARG_WITH([spl-timeout], |
269 | AS_HELP_STRING([--with-spl-timeout=SECS], | |
270 | [Wait SECS for SPL header and symver file @<:@default=0@:>@]), | |
271 | [timeout="$withval"], [timeout=0]) | |
272 | ||
9b2af9a0 BB |
273 | dnl # |
274 | dnl # The existence of spl.release.in is used to identify a valid | |
275 | dnl # source directory. In order of preference: | |
276 | dnl # | |
277 | splsrc0="/var/lib/dkms/spl/${VERSION}/build" | |
d8d78267 RY |
278 | splsrc1="/usr/local/src/spl-${VERSION}/${LINUX_VERSION}" |
279 | splsrc2="/usr/local/src/spl-${VERSION}" | |
280 | splsrc3="/usr/src/spl-${VERSION}/${LINUX_VERSION}" | |
281 | splsrc4="/usr/src/spl-${VERSION}" | |
282 | splsrc5="../spl/" | |
283 | splsrc6="$LINUX" | |
c9c0d073 BB |
284 | |
285 | AC_MSG_CHECKING([spl source directory]) | |
9b2af9a0 | 286 | AS_IF([test -z "${splsrc}"], [ |
c7e7ec19 OF |
287 | [all_spl_sources=" |
288 | ${splsrc0} | |
289 | ${splsrc1} | |
290 | ${splsrc2} | |
291 | ${splsrc3} | |
292 | ${splsrc4} | |
293 | ${splsrc5} | |
294 | ${splsrc6}"], | |
9b2af9a0 BB |
295 | AS_IF([ test -e "${splsrc0}/spl.release.in"], [ |
296 | splsrc=${splsrc0} | |
297 | ], [ test -e "${splsrc1}/spl.release.in"], [ | |
298 | splsrc=${splsrc1} | |
299 | ], [ test -e "${splsrc2}/spl.release.in"], [ | |
300 | splsrc=${splsrc2} | |
301 | ], [ test -e "${splsrc3}/spl.release.in"], [ | |
302 | splsrc=$(readlink -f "${splsrc3}") | |
303 | ], [ test -e "${splsrc4}/spl.release.in" ], [ | |
304 | splsrc=${splsrc4} | |
d8d78267 RY |
305 | ], [ test -e "${splsrc5}/spl.release.in"], [ |
306 | splsrc=$(readlink -f "${splsrc5}") | |
307 | ], [ test -e "${splsrc6}/spl.release.in" ], [ | |
308 | splsrc=${splsrc6} | |
8366cd6a | 309 | ], [ |
9b2af9a0 | 310 | splsrc="[Not found]" |
8366cd6a PS |
311 | ]) |
312 | ], [ | |
c7e7ec19 | 313 | [all_spl_sources="$withval"], |
8366cd6a | 314 | AS_IF([test "$splsrc" = "NONE"], [ |
c9c0d073 BB |
315 | splbuild=NONE |
316 | splsrcver=NONE | |
8366cd6a PS |
317 | ]) |
318 | ]) | |
c9c0d073 BB |
319 | |
320 | AC_MSG_RESULT([$splsrc]) | |
9b2af9a0 BB |
321 | AS_IF([ test ! -e "$splsrc/spl.release.in"], [ |
322 | AC_MSG_ERROR([ | |
323 | *** Please make sure the kmod spl devel package for your distribution | |
324 | *** is installed then try again. If that fails you can specify the | |
c7e7ec19 OF |
325 | *** location of the spl source with the '--with-spl=PATH' option. |
326 | *** The spl version must match the version of ZFS you are building, | |
327 | *** ${VERSION}. Failed to find spl.release.in in the following: | |
328 | $all_spl_sources]) | |
9b2af9a0 BB |
329 | ]) |
330 | ||
331 | dnl # | |
332 | dnl # The existence of the spl_config.h is used to identify a valid | |
333 | dnl # spl object directory. In many cases the object and source | |
334 | dnl # directory are the same, however the objects may also reside | |
335 | dnl # is a subdirectory named after the kernel version. | |
336 | dnl # | |
51654737 CALP |
337 | dnl # This file is supposed to be available after DKMS finishes |
338 | dnl # building the SPL kernel module for the target kernel. The | |
339 | dnl # '--with-spl-timeout' option can be passed to pause here, | |
340 | dnl # waiting for the file to appear from a concurrently building | |
341 | dnl # SPL package. | |
342 | dnl # | |
c9c0d073 | 343 | AC_MSG_CHECKING([spl build directory]) |
c7e7ec19 OF |
344 | |
345 | all_spl_config_locs="${splsrc}/${LINUX_VERSION} | |
346 | ${splsrc}" | |
347 | ||
51654737 CALP |
348 | while true; do |
349 | AS_IF([test -z "$splbuild"], [ | |
350 | AS_IF([ test -e "${splsrc}/${LINUX_VERSION}/spl_config.h" ], [ | |
351 | splbuild="${splsrc}/${LINUX_VERSION}" | |
352 | ], [ test -e "${splsrc}/spl_config.h" ], [ | |
353 | splbuild="${splsrc}" | |
47a4a6fd TF |
354 | ], [ find -L "${splsrc}" -name spl_config.h 2> /dev/null | grep -wq spl_config.h ], [ |
355 | splbuild=$(find -L "${splsrc}" -name spl_config.h | sed 's,/spl_config.h,,') | |
51654737 CALP |
356 | ], [ |
357 | splbuild="[Not found]" | |
358 | ]) | |
359 | ]) | |
360 | AS_IF([test -e "$splbuild/spl_config.h" -o $timeout -le 0], [ | |
361 | break; | |
9b2af9a0 | 362 | ], [ |
51654737 CALP |
363 | sleep 1 |
364 | timeout=$((timeout-1)) | |
9b2af9a0 | 365 | ]) |
51654737 | 366 | done |
9b2af9a0 | 367 | |
c9c0d073 | 368 | AC_MSG_RESULT([$splbuild]) |
9b2af9a0 BB |
369 | AS_IF([ ! test -e "$splbuild/spl_config.h"], [ |
370 | AC_MSG_ERROR([ | |
371 | *** Please make sure the kmod spl devel <kernel> package for your | |
372 | *** distribution is installed then try again. If that fails you | |
373 | *** can specify the location of the spl objects with the | |
c7e7ec19 OF |
374 | *** '--with-spl-obj=PATH' option. Failed to find spl_config.h in |
375 | *** any of the following: | |
376 | $all_spl_config_locs]) | |
9b2af9a0 | 377 | ]) |
c9c0d073 BB |
378 | |
379 | AC_MSG_CHECKING([spl source version]) | |
8366cd6a PS |
380 | AS_IF([test -r $splbuild/spl_config.h && |
381 | fgrep -q SPL_META_VERSION $splbuild/spl_config.h], [ | |
c9c0d073 BB |
382 | |
383 | splsrcver=`(echo "#include <spl_config.h>"; | |
b40a77ae | 384 | echo "splsrcver=SPL_META_VERSION-SPL_META_RELEASE") | |
5e612145 | 385 | cpp -I $splbuild | |
b40a77ae | 386 | grep "^splsrcver=" | tr -d \" | cut -d= -f2` |
8366cd6a | 387 | ]) |
c9c0d073 | 388 | |
8366cd6a | 389 | AS_IF([test -z "$splsrcver"], [ |
c9c0d073 BB |
390 | AC_MSG_RESULT([Not found]) |
391 | AC_MSG_ERROR([ | |
2984e0bb PS |
392 | *** Cannot determine the version of the spl source. |
393 | *** Please prepare the spl source before running this script]) | |
8366cd6a | 394 | ]) |
c9c0d073 BB |
395 | |
396 | AC_MSG_RESULT([$splsrcver]) | |
397 | ||
398 | SPL=${splsrc} | |
399 | SPL_OBJ=${splbuild} | |
400 | SPL_VERSION=${splsrcver} | |
401 | ||
402 | AC_SUBST(SPL) | |
403 | AC_SUBST(SPL_OBJ) | |
404 | AC_SUBST(SPL_VERSION) | |
405 | ||
51654737 CALP |
406 | dnl # |
407 | dnl # Detect the name used for the SPL Module.symvers file. If one | |
408 | dnl # does not exist this is likely because the SPL has been configured | |
409 | dnl # but not built. The '--with-spl-timeout' option can be passed | |
410 | dnl # to pause here, waiting for the file to appear from a concurrently | |
411 | dnl # building SPL package. If the file does not appear in time, a good | |
412 | dnl # guess is made as to what this file will be named based on what it | |
413 | dnl # is named in the kernel build products. This file will first be | |
414 | dnl # used at link time so if the guess is wrong the build will fail | |
415 | dnl # then. This unfortunately means the ZFS package does not contain a | |
416 | dnl # reliable mechanism to detect symbols exported by the SPL at | |
417 | dnl # configure time. | |
418 | dnl # | |
419 | AC_MSG_CHECKING([spl file name for module symbols]) | |
420 | SPL_SYMBOLS=NONE | |
421 | ||
422 | while true; do | |
423 | AS_IF([test -r $SPL_OBJ/Module.symvers], [ | |
424 | SPL_SYMBOLS=Module.symvers | |
425 | ], [test -r $SPL_OBJ/Modules.symvers], [ | |
426 | SPL_SYMBOLS=Modules.symvers | |
427 | ], [test -r $SPL_OBJ/module/Module.symvers], [ | |
428 | SPL_SYMBOLS=Module.symvers | |
429 | ], [test -r $SPL_OBJ/module/Modules.symvers], [ | |
430 | SPL_SYMBOLS=Modules.symvers | |
431 | ]) | |
432 | ||
433 | AS_IF([test $SPL_SYMBOLS != NONE -o $timeout -le 0], [ | |
434 | break; | |
435 | ], [ | |
436 | sleep 1 | |
437 | timeout=$((timeout-1)) | |
438 | ]) | |
439 | done | |
440 | ||
441 | AS_IF([test "$SPL_SYMBOLS" = NONE], [ | |
442 | SPL_SYMBOLS=$LINUX_SYMBOLS | |
443 | ]) | |
444 | ||
445 | AC_MSG_RESULT([$SPL_SYMBOLS]) | |
446 | AC_SUBST(SPL_SYMBOLS) | |
c9c0d073 BB |
447 | ]) |
448 | ||
319a99a3 ED |
449 | dnl # |
450 | dnl # Basic toolchain sanity check. | |
451 | dnl # | |
e33045ee BB |
452 | AC_DEFUN([ZFS_AC_TEST_MODULE], [ |
453 | AC_MSG_CHECKING([whether modules can be built]) | |
319a99a3 ED |
454 | ZFS_LINUX_TRY_COMPILE([],[],[ |
455 | AC_MSG_RESULT([yes]) | |
456 | ],[ | |
457 | AC_MSG_RESULT([no]) | |
458 | if test "x$enable_linux_builtin" != xyes; then | |
459 | AC_MSG_ERROR([*** Unable to build an empty module.]) | |
460 | else | |
461 | AC_MSG_ERROR([ | |
462 | *** Unable to build an empty module. | |
463 | *** Please run 'make scripts' inside the kernel source tree.]) | |
464 | fi | |
465 | ]) | |
466 | ]) | |
467 | ||
15805c77 BB |
468 | dnl # |
469 | dnl # Certain kernel build options are not supported. These must be | |
470 | dnl # detected at configure time and cause a build failure. Otherwise | |
471 | dnl # modules may be successfully built that behave incorrectly. | |
472 | dnl # | |
e5b85622 | 473 | AC_DEFUN([ZFS_AC_KERNEL_CONFIG], [ |
76d5bf19 KD |
474 | AS_IF([test "x$cross_compiling" != xyes], [ |
475 | AC_RUN_IFELSE([ | |
476 | AC_LANG_PROGRAM([ | |
477 | #include "$LINUX/include/linux/license.h" | |
478 | ], [ | |
479 | return !license_is_gpl_compatible("$ZFS_META_LICENSE"); | |
480 | ]) | |
481 | ], [ | |
482 | AC_DEFINE([ZFS_IS_GPL_COMPATIBLE], [1], | |
483 | [Define to 1 if GPL-only symbols can be used]) | |
e33045ee | 484 | ], [ |
e33045ee | 485 | ]) |
e5b85622 BB |
486 | ]) |
487 | ||
b58986ee | 488 | ZFS_AC_KERNEL_CONFIG_THREAD_SIZE |
e5b85622 BB |
489 | ZFS_AC_KERNEL_CONFIG_DEBUG_LOCK_ALLOC |
490 | ]) | |
491 | ||
b58986ee BB |
492 | dnl # |
493 | dnl # Check configured THREAD_SIZE | |
494 | dnl # | |
495 | dnl # The stack size will vary by architecture, but as of Linux 3.15 on x86_64 | |
496 | dnl # the default thread stack size was increased to 16K from 8K. Therefore, | |
497 | dnl # on newer kernels and some architectures stack usage optimizations can be | |
498 | dnl # conditionally applied to improve performance without negatively impacting | |
499 | dnl # stability. | |
500 | dnl # | |
501 | AC_DEFUN([ZFS_AC_KERNEL_CONFIG_THREAD_SIZE], [ | |
502 | AC_MSG_CHECKING([whether kernel was built with 16K or larger stacks]) | |
503 | ZFS_LINUX_TRY_COMPILE([ | |
504 | #include <linux/module.h> | |
505 | ],[ | |
506 | #if (THREAD_SIZE < 16384) | |
507 | #error "THREAD_SIZE is less than 16K" | |
508 | #endif | |
509 | ],[ | |
510 | AC_MSG_RESULT([yes]) | |
511 | AC_DEFINE(HAVE_LARGE_STACKS, 1, [kernel has large stacks]) | |
512 | ],[ | |
513 | AC_MSG_RESULT([no]) | |
514 | ]) | |
515 | ]) | |
516 | ||
e5b85622 BB |
517 | dnl # |
518 | dnl # Check CONFIG_DEBUG_LOCK_ALLOC | |
519 | dnl # | |
520 | dnl # This is typically only set for debug kernels because it comes with | |
521 | dnl # a performance penalty. However, when it is set it maps the non-GPL | |
522 | dnl # symbol mutex_lock() to the GPL-only mutex_lock_nested() symbol. | |
523 | dnl # This will cause a failure at link time which we'd rather know about | |
524 | dnl # at compile time. | |
525 | dnl # | |
526 | dnl # Since we plan to pursue making mutex_lock_nested() a non-GPL symbol | |
527 | dnl # with the upstream community we add a check to detect this case. | |
528 | dnl # | |
529 | AC_DEFUN([ZFS_AC_KERNEL_CONFIG_DEBUG_LOCK_ALLOC], [ | |
530 | ||
531 | ZFS_LINUX_CONFIG([DEBUG_LOCK_ALLOC], [ | |
532 | AC_MSG_CHECKING([whether mutex_lock() is GPL-only]) | |
533 | tmp_flags="$EXTRA_KCFLAGS" | |
534 | ZFS_LINUX_TRY_COMPILE([ | |
535 | #include <linux/module.h> | |
536 | #include <linux/mutex.h> | |
537 | ||
538 | MODULE_LICENSE("$ZFS_META_LICENSE"); | |
539 | ],[ | |
540 | struct mutex lock; | |
541 | ||
542 | mutex_init(&lock); | |
543 | mutex_lock(&lock); | |
544 | mutex_unlock(&lock); | |
545 | ],[ | |
546 | AC_MSG_RESULT(no) | |
547 | ],[ | |
548 | AC_MSG_RESULT(yes) | |
549 | AC_MSG_ERROR([ | |
550 | *** Kernel built with CONFIG_DEBUG_LOCK_ALLOC which is incompatible | |
cac1f230 NB |
551 | *** with the CDDL license and will prevent the module linking stage |
552 | *** from succeeding. You must rebuild your kernel without this | |
553 | *** option enabled.]) | |
e5b85622 BB |
554 | ]) |
555 | EXTRA_KCFLAGS="$tmp_flags" | |
556 | ], []) | |
c9c0d073 BB |
557 | ]) |
558 | ||
559 | dnl # | |
0b39b9f9 | 560 | dnl # ZFS_LINUX_CONFTEST_H |
c9c0d073 | 561 | dnl # |
0b39b9f9 PS |
562 | AC_DEFUN([ZFS_LINUX_CONFTEST_H], [ |
563 | cat - <<_ACEOF >conftest.h | |
564 | $1 | |
565 | _ACEOF | |
566 | ]) | |
567 | ||
568 | dnl # | |
569 | dnl # ZFS_LINUX_CONFTEST_C | |
570 | dnl # | |
571 | AC_DEFUN([ZFS_LINUX_CONFTEST_C], [ | |
c9c0d073 BB |
572 | cat confdefs.h - <<_ACEOF >conftest.c |
573 | $1 | |
574 | _ACEOF | |
575 | ]) | |
576 | ||
577 | dnl # | |
578 | dnl # ZFS_LANG_PROGRAM(C)([PROLOGUE], [BODY]) | |
579 | dnl # | |
580 | m4_define([ZFS_LANG_PROGRAM], [ | |
581 | $1 | |
582 | int | |
583 | main (void) | |
584 | { | |
585 | dnl Do *not* indent the following line: there may be CPP directives. | |
586 | dnl Don't move the `;' right after for the same reason. | |
587 | $2 | |
588 | ; | |
589 | return 0; | |
590 | } | |
591 | ]) | |
592 | ||
593 | dnl # | |
594 | dnl # ZFS_LINUX_COMPILE_IFELSE / like AC_COMPILE_IFELSE | |
595 | dnl # | |
596 | AC_DEFUN([ZFS_LINUX_COMPILE_IFELSE], [ | |
0b39b9f9 PS |
597 | m4_ifvaln([$1], [ZFS_LINUX_CONFTEST_C([$1])]) |
598 | m4_ifvaln([$6], [ZFS_LINUX_CONFTEST_H([$6])], [ZFS_LINUX_CONFTEST_H([])]) | |
fc88a6dd | 599 | rm -Rf build && mkdir -p build && touch build/conftest.mod.c |
c9c0d073 | 600 | echo "obj-m := conftest.o" >build/Makefile |
fc88a6dd ED |
601 | modpost_flag='' |
602 | test "x$enable_linux_builtin" = xyes && modpost_flag='modpost=true' # fake modpost stage | |
c9c0d073 | 603 | AS_IF( |
0b39b9f9 | 604 | [AC_TRY_COMMAND(cp conftest.c conftest.h build && make [$2] -C $LINUX_OBJ EXTRA_CFLAGS="-Werror $EXTRA_KCFLAGS" $ARCH_UM M=$PWD/build $modpost_flag) >/dev/null && AC_TRY_COMMAND([$3])], |
c9c0d073 BB |
605 | [$4], |
606 | [_AC_MSG_LOG_CONFTEST m4_ifvaln([$5],[$5])] | |
607 | ) | |
608 | rm -Rf build | |
609 | ]) | |
610 | ||
611 | dnl # | |
612 | dnl # ZFS_LINUX_TRY_COMPILE like AC_TRY_COMPILE | |
613 | dnl # | |
614 | AC_DEFUN([ZFS_LINUX_TRY_COMPILE], | |
615 | [ZFS_LINUX_COMPILE_IFELSE( | |
616 | [AC_LANG_SOURCE([ZFS_LANG_PROGRAM([[$1]], [[$2]])])], | |
617 | [modules], | |
618 | [test -s build/conftest.o], | |
619 | [$3], [$4]) | |
620 | ]) | |
621 | ||
622 | dnl # | |
623 | dnl # ZFS_LINUX_CONFIG | |
624 | dnl # | |
625 | AC_DEFUN([ZFS_LINUX_CONFIG], | |
b58986ee | 626 | [AC_MSG_CHECKING([whether kernel was built with CONFIG_$1]) |
c9c0d073 | 627 | ZFS_LINUX_TRY_COMPILE([ |
0da78696 | 628 | #include <linux/module.h> |
c9c0d073 BB |
629 | ],[ |
630 | #ifndef CONFIG_$1 | |
631 | #error CONFIG_$1 not #defined | |
632 | #endif | |
633 | ],[ | |
634 | AC_MSG_RESULT([yes]) | |
635 | $2 | |
636 | ],[ | |
637 | AC_MSG_RESULT([no]) | |
638 | $3 | |
639 | ]) | |
640 | ]) | |
641 | ||
642 | dnl # | |
643 | dnl # ZFS_CHECK_SYMBOL_EXPORT | |
644 | dnl # check symbol exported or not | |
645 | dnl # | |
70574182 | 646 | AC_DEFUN([ZFS_CHECK_SYMBOL_EXPORT], [ |
c9c0d073 BB |
647 | grep -q -E '[[[:space:]]]$1[[[:space:]]]' \ |
648 | $LINUX_OBJ/$LINUX_SYMBOLS 2>/dev/null | |
649 | rc=$? | |
70574182 | 650 | if test $rc -ne 0; then |
c9c0d073 BB |
651 | export=0 |
652 | for file in $2; do | |
70574182 ED |
653 | grep -q -E "EXPORT_SYMBOL.*($1)" \ |
654 | "$LINUX/$file" 2>/dev/null | |
c9c0d073 | 655 | rc=$? |
70574182 | 656 | if test $rc -eq 0; then |
8366cd6a PS |
657 | export=1 |
658 | break; | |
70574182 | 659 | fi |
c9c0d073 | 660 | done |
70574182 | 661 | if test $export -eq 0; then : |
c9c0d073 | 662 | $4 |
70574182 | 663 | else : |
c9c0d073 | 664 | $3 |
70574182 ED |
665 | fi |
666 | else : | |
c9c0d073 | 667 | $3 |
70574182 ED |
668 | fi |
669 | ]) | |
670 | ||
671 | dnl # | |
672 | dnl # ZFS_LINUX_TRY_COMPILE_SYMBOL | |
673 | dnl # like ZFS_LINUX_TRY_COMPILE, except ZFS_CHECK_SYMBOL_EXPORT | |
674 | dnl # is called if not compiling for builtin | |
675 | dnl # | |
676 | AC_DEFUN([ZFS_LINUX_TRY_COMPILE_SYMBOL], [ | |
677 | ZFS_LINUX_TRY_COMPILE([$1], [$2], [rc=0], [rc=1]) | |
678 | if test $rc -ne 0; then : | |
679 | $6 | |
680 | else | |
681 | if test "x$enable_linux_builtin" != xyes; then | |
682 | ZFS_CHECK_SYMBOL_EXPORT([$3], [$4], [rc=0], [rc=1]) | |
683 | fi | |
684 | if test $rc -ne 0; then : | |
685 | $6 | |
686 | else : | |
687 | $5 | |
688 | fi | |
689 | fi | |
c9c0d073 | 690 | ]) |
0b39b9f9 PS |
691 | |
692 | dnl # | |
693 | dnl # ZFS_LINUX_TRY_COMPILE_HEADER | |
694 | dnl # like ZFS_LINUX_TRY_COMPILE, except the contents conftest.h are | |
695 | dnl # provided via the fifth parameter | |
696 | dnl # | |
697 | AC_DEFUN([ZFS_LINUX_TRY_COMPILE_HEADER], | |
698 | [ZFS_LINUX_COMPILE_IFELSE( | |
699 | [AC_LANG_SOURCE([ZFS_LANG_PROGRAM([[$1]], [[$2]])])], | |
700 | [modules], | |
701 | [test -s build/conftest.o], | |
4e30e68c | 702 | [$3], [$4], [$5]) |
0b39b9f9 | 703 | ]) |