On 2020/08/02 20:25, George Koehler wrote:
> Hi.  This is about OpenBSD ports/lang/crystal.
> 
> When OpenBSD switches base-clang to LLVM 10, it will add
> /usr/bin/llvm-config to base.  This will break crystal, because it
> will run the wrong llvm-config and get a linker error:
> http://build-failures.rhaalovely.net/amd64-clang/2020-08-01/lang/crystal.log
> 
> This diff fixes crystal for me on amd64, by pointing to the correct
> llvm-config.  (I don't set REVISION = 0 because both new and old
> packages use the same llvm-config from ports.)  OK to commit?

OK

> But this only works as long as ports-clang stays at LLVM 8, because
> the bootstrap crystal.o needs libLLVM-8.so, but we use the libLLVM
> from llvm-config.  When we update devel/llvm to LLVM 10, then crystal
> will break, unless someone will provide a new bootstrap.    --George

AFAIK base and ports LLVM should be kept in sync, so it will
likely run into problems again soon.

> Index: Makefile
> ===================================================================
> RCS file: /cvs/ports/lang/crystal/Makefile,v
> retrieving revision 1.8
> diff -u -p -r1.8 Makefile
> --- Makefile  7 Sep 2019 08:46:41 -0000       1.8
> +++ Makefile  2 Aug 2020 23:48:14 -0000
> @@ -29,8 +29,9 @@ DISTFILES = crystal-${V}{${V}}.tar.gz \
>               crystal-${V}-OpenBSD6.5.tar.gz:0 \
>               shards-${V}{v${V_SHARDS}}.tar.gz:1
>  
> -# Build requires llvm-config which only exists in ports-clang
> +# Build requires llvm-config from ports, not from base
>  COMPILER =   ports-clang
> +LLVM_CONFIG =        ${LOCALBASE}/bin/llvm-config
>  
>  BUILD_DEPENDS =      devel/llvm
>  RUN_DEPENDS =        devel/llvm,-main
> @@ -49,13 +50,14 @@ NO_TEST = Yes
>  do-build:
>       mkdir -p ${WRKSRC}/.build
>       # Link the compiler from the pre-built bootstrap object
> -     cd ${WRKSRC} && CXX=${CXX} ${MAKE_PROGRAM} llvm_ext libcrystal
> +     cd ${WRKSRC} && CXX=${CXX} LLVM_CONFIG=${LLVM_CONFIG} \
> +             ${MAKE_PROGRAM} llvm_ext libcrystal
>       cd ${WRKSRC} && ${CXX} -rdynamic -o ${WRKBUILD}/.build/crystal \
>               ${WRKSRC}/../crystal.o \
>               ${WRKSRC}/src/llvm/ext/llvm_ext.o \
>               ${WRKSRC}/src/ext/sigfault.o \
>               -L${LOCALBASE}/lib \
> -             `(llvm-config --libs --system-libs --ldflags 2> /dev/null)` \
> +             `(${LLVM_CONFIG} --libs --system-libs --ldflags 2> /dev/null)` \
>               -lz -lpcre -lgc -lpthread -levent_core -levent_extra -lssl \
>               -lcrypto -liconv
>       # Use the compiler to re-compile the compiler
> @@ -63,7 +65,8 @@ do-build:
>       cd ${WRKSRC}; \
>               ulimit -s 5120 -d 4096000 && \
>               CRYSTAL_CONFIG_PATH="lib:${TRUEPREFIX}/lib/crystal" \
> -             CXX=${CXX} ${MAKE_PROGRAM} ${ALL_TARGET}
> +             CXX=${CXX} LLVM_CONFIG=${LLVM_CONFIG} \
> +             ${MAKE_PROGRAM} ${ALL_TARGET}
>       cd ${WRKSRC}/../shards-${V_SHARDS} && \
>               ${MAKE_PROGRAM} CRYSTAL=${WRKSRC}/.build/crystal \
>               CRYSTAL_PATH=${WRKSRC}/src CRFLAGS=--release
> 

Reply via email to