dolfin team mailing list archive
-
dolfin team
-
Mailing list archive
-
Message #20740
Re: Extending DOLFIN CMake scripts for CUDA interoperability
It looks like changing:
add_definitions(-DPACKAGE_VERSION="${DOLFIN_VERSION}")
to
add_definitions(-DPACKAGE_VERSION=${DOLFIN_VERSION})
Fixed it. PACKAGE_VERSION got added to the defines in the call to nvcc and the
escaped quotes screwed things up.
Johannes: Are the quotes needed for something special? It compiles alright
without the quotes.
Johan
On Monday January 17 2011 09:41:26 Johan Hake wrote:
> Florian!
>
> I am no CMake expert nor have I ever compiled any CUDA code, but it looks
> like something fishy happens when you add your flags to the CUDA code
> generation step. Have you set it up correctly? I also get the erronious
> output from CMake for the nvcc call.
>
> What CMake command is used to set these flags? It almost seems like the
> eronious flags are set automatic? At least I cannot see that you put
> PACKAGE_VERSION to the NVCC flags anywhere. If they are automatically set,
> maybe there is a way to set them using one of the commands from
> FindCUDA.cmake?
>
> Johan
>
> On Friday January 14 2011 12:07:50 Florian Rathgeber wrote:
> > Hi,
> >
> > I'm currently trying to get my DOLFIN GPU code in shape but haven't
> > quite succeeded integrating it with DOLFIN's CMake build.
> >
> > Now the FindCUDA.cmake script tries to propagate host compiler flags and
> > defines to the NVIDIA compiler nvcc but apparently messes up so I get a
> >
> > compiler invocation looking like this (only the relevant part):
> > -DPACKAGE_VERSION= 0.9.9+\" -Ddolfin_gpu_EXPORTS\" -Xcompiler
> >
> > ,\"-fPIC\",\"-O2\",\"-g\"
> >
> > Note the odd quoting and also the space after -DPACKAGE_VERSION=
> >
> > This causes nvcc to assume this is a target and die:
> > nvcc fatal : A single input file is required for a non-link phase when
> > an outputfile is specified
> >
> > The code is at lp:~florian-rathgeber/dolfin/gpu-backend
> >
> > The relevant section from dolfin/CMakeLists.txt (after all the other
> > packages)
> > <<<
> > # CUDA
> > SET(DOLFIN_GPU_LIBRARY "")
> > if (DOLFIN_ENABLE_CUDA AND CUDA_FOUND)
> >
> > list(APPEND DOLFIN_CXX_DEFINITIONS "-DHAS_CUDA")
> > list(APPEND DOLFIN_INCLUDE_DIRECTORIES ${CUDA_INCLUDE_DIRS})
> > # Add CUDA sources (*.cu) only if CUDA is enabled
> > foreach(DIR ${DOLFIN_DIRS})
> >
> > file(GLOB _CU_SOURCES ${DIR}/*.cu)
> > list(APPEND CU_SOURCES ${_CU_SOURCES})
> >
> > endforeach()
> > CUDA_ADD_LIBRARY(dolfin_gpu ${CU_SOURCES} SHARED)
> > SET(DOLFIN_GPU_LIBRARY dolfin_gpu)
> > list(APPEND DOLFIN_TARGET_LINK_LIBRARIES ${CUDA_LIBRARIES}
> >
> > ${DOLFIN_GPU_LIBRARY})
> > endif()
> >
> > # Cusp
> > if (DOLFIN_ENABLE_CUSP AND CUSP_FOUND)
> >
> > list(APPEND DOLFIN_CXX_DEFINITIONS "-DHAS_CUSP")
> > list(APPEND DOLFIN_INCLUDE_DIRECTORIES ${THRUST_INCLUDE_DIRS}
> >
> > ${CUSP_INCLUDE_DIRS})
> >
> > endif()
> > <<<
> >
> > In CMakeLists.txt I check for the packages like this:
> > <<<
> > # Check for CUDA
> > if (DOLFIN_ENABLE_CUDA)
> >
> > find_package(CUDA)
> >
> > endif()
> >
> > # Check for Cusp
> > if (DOLFIN_ENABLE_CUSP)
> >
> > find_package(Cusp)
> >
> > endif()
> > <<<
> > FindCUDA is the stock script from CMake 2.8, FindCusp is a simple script
> > I wrote which lives in cmake/modules
> >
> > I'd be happy about any hints and tips. Garth, afair you wanted to look
> > into this at some point now that the new build system is in place?
> >
> > Florian
>
> _______________________________________________
> Mailing list: https://launchpad.net/~dolfin
> Post to : dolfin@xxxxxxxxxxxxxxxxxxx
> Unsubscribe : https://launchpad.net/~dolfin
> More help : https://help.launchpad.net/ListHelp
Follow ups
References