2015-05-30 23:22:08 +02:00
|
|
|
# Created by: John Marino <marino@FreeBSD.org>
|
|
|
|
# $FreeBSD$
|
|
|
|
|
|
|
|
PORTNAME= ghdl
|
|
|
|
PORTVERSION= 0.32
|
2015-06-16 10:57:36 +02:00
|
|
|
PORTREVISION= 2
|
2015-05-30 23:22:08 +02:00
|
|
|
CATEGORIES= cad
|
2015-06-16 11:43:00 +02:00
|
|
|
DISTFILES= ${DISTNAME}${EXTRACT_SUFX}
|
2015-05-30 23:22:08 +02:00
|
|
|
|
|
|
|
MAINTAINER= marino@FreeBSD.org
|
|
|
|
COMMENT= GNU VHDL simulator
|
|
|
|
|
|
|
|
LICENSE= GPLv2
|
|
|
|
LICENSE_FILE= ${WRKSRC}/COPYING
|
|
|
|
|
|
|
|
LIB_DEPENDS= libgmp.so:${PORTSDIR}/math/gmp \
|
|
|
|
libmpfr.so:${PORTSDIR}/math/mpfr \
|
|
|
|
libmpc.so:${PORTSDIR}/math/mpc
|
|
|
|
|
2015-06-01 01:58:12 +02:00
|
|
|
USES= ada gmake
|
2015-05-30 23:22:08 +02:00
|
|
|
USE_GITHUB= yes
|
|
|
|
GH_ACCOUNT= hanzer
|
2015-06-16 10:57:36 +02:00
|
|
|
GH_PROJECT= gVHDL
|
|
|
|
GH_TAGNAME= 5adb2f6
|
2015-05-30 23:22:08 +02:00
|
|
|
|
|
|
|
GNU_CONFIGURE= yes
|
|
|
|
GCCVER= 4.9.2
|
2015-06-01 01:58:12 +02:00
|
|
|
LLVMVER= 35
|
2015-05-30 23:22:08 +02:00
|
|
|
BLD_TARGET= ${ARCH:S/amd64/x86_64/}-portbld-${OPSYS:tl}${OSREL:R}
|
|
|
|
BUILDDIR= ${WRKDIR}/build
|
|
|
|
GCCSRCDIR= ${WRKDIR}/gcc-${GCCVER}
|
|
|
|
CFG_SCRIPT= ${GCCSRCDIR}/configure
|
|
|
|
PKG_PREFIX= ${PREFIX}/ghdl
|
|
|
|
LINKER_COMMAND= ${LOCALBASE}/gcc-aux/bin/gcc
|
|
|
|
|
|
|
|
GHDL_ARGS= --enable-languages="c,vhdl" \
|
|
|
|
--build=${BLD_TARGET} \
|
|
|
|
--prefix=${PKG_PREFIX:Q} \
|
|
|
|
--disable-bootstrap \
|
|
|
|
--disable-nls \
|
|
|
|
--disable-libquadmath \
|
|
|
|
--disable-libmudflap \
|
|
|
|
--disable-libgomp \
|
|
|
|
--disable-libssp \
|
|
|
|
--with-system-zlib \
|
|
|
|
--with-gmp=${PREFIX} \
|
|
|
|
--with-mpfr=${PREFIX} \
|
|
|
|
--with-mpc=${PREFIX} \
|
|
|
|
--enable-shared \
|
|
|
|
--enable-threads=posix \
|
|
|
|
${ICONV_CONFIGURE_ARG} ${EXTRA_CONFIG}
|
|
|
|
|
2015-06-01 01:58:12 +02:00
|
|
|
OPTIONS_SINGLE= BACKEND
|
|
|
|
OPTIONS_SINGLE_BACKEND= GCC LLVM
|
|
|
|
|
|
|
|
GCC_DESC= Code generator is GCC (mature)
|
|
|
|
LLVM_DESC= Code generator is LLVM (experimental)
|
|
|
|
|
|
|
|
.if exists (/sbin/hammer)
|
|
|
|
OPTIONS_DEFAULT= LLVM
|
|
|
|
PLIST_SUB= DRAGONFLY="" FREEBSD="@comment "
|
|
|
|
.else
|
|
|
|
OPTIONS_DEFAULT= GCC
|
|
|
|
PLIST_SUB= DRAGONFLY="@comment " FREEBSD=""
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.include <bsd.port.options.mk>
|
2015-05-30 23:22:08 +02:00
|
|
|
|
|
|
|
.if ${OPSYS} == FreeBSD
|
|
|
|
MODERN_BINUTILS= yes
|
|
|
|
. if ${OSREL:R} == 8 && ${ARCH} == i386
|
|
|
|
BROKEN= get_pc_thunk.cx errors
|
|
|
|
. endif
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if ${ARCH:S/amd64/x86_64/} == x86_64
|
|
|
|
PLIST_SUB+= X86_64=""
|
|
|
|
.else
|
|
|
|
PLIST_SUB+= X86_64="@comment "
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if defined(MODERN_BINUTILS)
|
|
|
|
# Apparently gcc 4.9 needs binutils 2.23 or greater to link Ada correctly
|
|
|
|
USE_BINUTILS= yes
|
|
|
|
RUN_DEPENDS+= ${LOCALBASE}/bin/as:${PORTSDIR}/devel/binutils
|
|
|
|
AS_COMMAND= ${LOCALBASE}/bin/as
|
|
|
|
EXTRA_CONFIG+= --with-ld=${LOCALBASE}/bin/ld
|
|
|
|
.else
|
|
|
|
AS_COMMAND= /usr/bin/as
|
|
|
|
EXTRA_CONFIG+= --with-ld=/usr/bin/ld
|
|
|
|
.endif
|
|
|
|
EXTRA_CONFIG+= --with-as=${AS_COMMAND}
|
|
|
|
|
2015-06-01 01:58:12 +02:00
|
|
|
.if ${PORT_OPTIONS:MGCC}
|
2015-06-16 11:43:00 +02:00
|
|
|
DISTFILES+= gcc-${GCCVER}.tar.bz2
|
2015-06-02 11:13:42 +02:00
|
|
|
USES+= iconv libtool makeinfo perl5
|
2015-06-01 01:58:12 +02:00
|
|
|
USE_PERL5= build
|
|
|
|
INFO= ghdl
|
|
|
|
PLIST_SUB+= GLEX=ghdl/libexec/gcc/${BLD_TARGET}/${GCCVER} \
|
|
|
|
GLIB=ghdl/lib/gcc/${BLD_TARGET}/${GCCVER} \
|
|
|
|
TARGET=${BLD_TARGET}
|
|
|
|
. if ${OPSYS} == DragonFly
|
|
|
|
IGNORE= Not supported by GCC backend
|
|
|
|
. endif
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if ${PORT_OPTIONS:MLLVM}
|
|
|
|
BUILD_DEPENDS+= llvm-config${LLVMVER}:${PORTSDIR}/devel/llvm${LLVMVER} \
|
|
|
|
clang++${LLVMVER}:${PORTSDIR}/lang/clang${LLVMVER}
|
|
|
|
RUN_DEPENDS+= llc${LLVMVER}:${PORTSDIR}/devel/llvm${LLVMVER}
|
|
|
|
PLIST= ${.CURDIR}/llvm-plist
|
|
|
|
PLIST_SUB+= GLIB=ghdl/lib/ghdl/
|
|
|
|
.endif
|
|
|
|
|
2015-05-30 23:22:08 +02:00
|
|
|
post-patch:
|
2015-06-01 01:58:12 +02:00
|
|
|
@${REINPLACE_CMD} \
|
2015-05-30 23:22:08 +02:00
|
|
|
-e 's|\@AS_COMMAND\@|${AS_COMMAND}|' \
|
|
|
|
-e 's|\@LINKER_COMMAND\@|${LINKER_COMMAND}|' \
|
|
|
|
${WRKSRC}/src/ghdldrv/ghdldrv.adb
|
2015-06-01 01:58:12 +02:00
|
|
|
@${REINPLACE_CMD} \
|
|
|
|
-e 's|llvm-config|llvm-config${LLVMVER}|' \
|
|
|
|
-e 's|(INSTALL_PROGRAM)|(BSD_INSTALL_PROGRAM)|' \
|
|
|
|
-e 's|(INSTALL_DATA)|(BSD_INSTALL_DATA)|' \
|
|
|
|
${WRKSRC}/configure ${WRKSRC}/Makefile.in
|
|
|
|
@${REINPLACE_CMD} -e 's|clang++|clang++${LLVMVER}|' \
|
|
|
|
${WRKSRC}/src/ortho/llvm/Makefile
|
|
|
|
|
|
|
|
.if ${PORT_OPTIONS:MGCC}
|
2015-05-30 23:22:08 +02:00
|
|
|
do-configure:
|
|
|
|
${MKDIR} ${BUILDDIR}
|
|
|
|
(cd ${WRKSRC} && ${SETENV} ${CONFIGURE_ENV} ./configure \
|
|
|
|
--with-gcc=${GCCSRCDIR} --prefix=${PKG_PREFIX:Q})
|
|
|
|
${SETENV} ${MAKE_ENV} ${MAKE_CMD} -C ${WRKSRC} copy-sources
|
|
|
|
(cd ${BUILDDIR} && ${SETENV} ${CONFIGURE_ENV} \
|
|
|
|
${CFG_SCRIPT} ${GHDL_ARGS})
|
|
|
|
|
|
|
|
do-build:
|
|
|
|
(cd ${BUILDDIR} && ${SETENV} ${MAKE_ENV} \
|
|
|
|
${MAKE_CMD} -j${MAKE_JOBS_NUMBER} ${MAKE_ARGS} all)
|
|
|
|
|
|
|
|
do-install:
|
|
|
|
(cd ${BUILDDIR} && ${SETENV} ${MAKE_ENV} \
|
|
|
|
${MAKE_CMD} install-strip ${MAKE_ARGS})
|
|
|
|
${MV} ${STAGEDIR}${PREFIX}/ghdl/share/man/man1/ghdl.1 \
|
|
|
|
${STAGEDIR}${PREFIX}/man/man1
|
|
|
|
${MV} ${STAGEDIR}${PREFIX}/ghdl/share/info/ghdl.info \
|
|
|
|
${STAGEDIR}${PREFIX}/info
|
|
|
|
${RM} -r ${STAGEDIR}${PREFIX}/ghdl/share
|
|
|
|
|
2015-06-01 01:58:12 +02:00
|
|
|
.endif # TAIL: GCC
|
|
|
|
|
|
|
|
.if ${PORT_OPTIONS:MLLVM}
|
|
|
|
do-configure:
|
|
|
|
(cd ${WRKSRC} && ${SETENV} ${CONFIGURE_ENV} ./configure \
|
|
|
|
--with-llvm=${LOCALBASE} --prefix=${PKG_PREFIX:Q})
|
|
|
|
.endif # TAIL: LLVM
|
|
|
|
|
2015-05-30 23:22:08 +02:00
|
|
|
check:
|
|
|
|
(cd ${WRKSRC}/testsuite && ${SETENV} ${MAKE_ENV} \
|
|
|
|
GHDL=${STAGEDIR}${PREFIX}/ghdl/bin/ghdl ${SH} testsuite.sh)
|
|
|
|
|
2015-06-01 01:58:12 +02:00
|
|
|
.include <bsd.port.mk>
|