我正在尝试使用 MAGMA (http://icl.cs.utk.edu/magma/) 在 GPU 上执行一些矩阵运算。我能够成功调用 CUDA 内核,这没有问题。但是当我尝试使用 magmablas_sgemm 函数时,我遇到了错误。
这是我正在使用的编译命令:
nvcc -o msd msd.cu -I../../include -I/util/magma/1.1 -lmagma -lmagmablas -Xcompiler -I../../include -I/util/magma/1.1 "-O3 "
这是部分 printenv 输出:
LD_LIBRARY_PATH=/util/magma/1.1/lib:/util/cuda/4.1.28/cuda/lib64:/util/cuda/4.1.28/cuda/lib 岩浆=/util/岩浆/1.1 PATH=/util/magma/1.1:/util/cuda/4.1.28/cuda/bin:/usr/lib64/qt-3.3/bin:/util/Modules/3.2.8/bin:/usr/local/bin :/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/kerberos/bin _LMFILES_=/util/Modules/modulefiles/null:/util/Modules/modulefiles/modules:/util/Modules/modulefiles/cuda/4.1.28:/util/Modules/modulefiles/magma/1.1 MODULEPATH=/util/Modules/versions:/util/Modules/modulefiles LOADEDMODULES=null:modules:cuda/4.1.28:magma/1.1
可以清楚地看到,岩浆库包含在 LD_LIBRARY_PATH 中,但是,我收到了这个错误:
/usr/bin/ld: 找不到 -lmagma collect2: ld 返回 1 个退出状态 make: *** [msd] 错误 1
任何帮助/指针将不胜感激!谢谢!
PS:如果相关,nvcc 用于主机代码的底层 C 编译器是 gcc。
PPS:我检查了路径“/util/magma/1.1/lib”,它确实包含 libmagma.a 和 libmagmablas.a
更新:哇..我讨厌这个..但这让它工作了
nvcc -o msd msd.cu -I../../include -I/util/magma/1.1 -L/util/cuda/4.0.17/cuda/lib64 -L/util/magma/1.1/lib -lcublas -lm -lmagma -lmagmablas -Xcompiler -I../../include -I/util/magma/1.1 "-O3"
所以我所做的只是明确地包含库路径。但我认为 LD_LIBRARY_PATH 会处理这样的事情。知道为什么那不起作用吗?