lang/pypy(3): update to 5.8

Change Log:
 - supports upstream library 2.7.13 and 3.5.3
 - critical bugs fixed in shadowstack
 - native support for profiling frames in vmprof
 - performance improvements for pack* and unpack* structs
 - cffi updates to 1.10.1
 - numpy 1.13.0 requires at least this version
This commit is contained in:
David Naylor 2017-06-18 16:55:38 +00:00
parent 795c8e51a0
commit be9819f737
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=443834
10 changed files with 48 additions and 55 deletions

View file

@ -2,8 +2,7 @@
# $FreeBSD$ # $FreeBSD$
PORTNAME?= pypy PORTNAME?= pypy
DISTVERSION?= 5.7.1 # Also update bsd.pypy.cffi.mk DISTVERSION?= 5.8.0 # Also update bsd.pypy.cffi.mk
PORTREVISION?= 1
CATEGORIES= lang python CATEGORIES= lang python
MASTER_SITES= https://bitbucket.org/pypy/pypy/downloads/ http://buildbot.pypy.org/mirror/ MASTER_SITES= https://bitbucket.org/pypy/pypy/downloads/ http://buildbot.pypy.org/mirror/
DISTNAME?= ${PORTNAME}2-v${PORTVERSION}-src DISTNAME?= ${PORTNAME}2-v${PORTVERSION}-src

View file

@ -11,7 +11,7 @@ PLIST_FILES= %%PYPY_DIR%%/lib_pypy/${CFFI_MODULE}_cffi.%%PYPY_CFFI_VER%%.so
CFFI_MODULE?= _${PORTNAME} CFFI_MODULE?= _${PORTNAME}
PYTHON_IMPL= pypy PYTHON_IMPL= pypy
PYTHON_PORTVERSION?= 5.7.1 PYTHON_PORTVERSION?= 5.8.0
PYTHON_PKGNAMEPREFIX= pypy- PYTHON_PKGNAMEPREFIX= pypy-
PYTHON_CMD= ${LOCALBASE}/bin/${PYTHON_IMPL} PYTHON_CMD= ${LOCALBASE}/bin/${PYTHON_IMPL}

View file

@ -1,3 +1,3 @@
TIMESTAMP = 1491510301 TIMESTAMP = 1497478804
SHA256 (pypy2-v5.7.1-src.tar.bz2) = d01bee43c6df79f7bbc1149bb3e85f489491fb2358a6a1f9a7f0d6e07715832f SHA256 (pypy2-v5.8.0-src.tar.bz2) = 504c2d522595baf8775ae1045a217a2b120732537861d31b889d47c340b58bd5
SIZE (pypy2-v5.7.1-src.tar.bz2) = 18940413 SIZE (pypy2-v5.8.0-src.tar.bz2) = 19163498

View file

@ -1,18 +0,0 @@
--- lib-python/2.7/distutils/sysconfig_pypy.py.orig 2017-04-06 19:44:56 UTC
+++ lib-python/2.7/distutils/sysconfig_pypy.py
@@ -61,12 +61,12 @@ _config_vars = None
def _init_posix():
"""Initialize the module as appropriate for POSIX systems."""
g = {}
- g['CC'] = "gcc -pthread"
- g['CXX'] = "g++ -pthread"
+ g['CC'] = "cc -pthread"
+ g['CXX'] = "c++ -pthread"
g['OPT'] = "-DNDEBUG -O2"
g['CFLAGS'] = "-DNDEBUG -O2"
g['CCSHARED'] = "-fPIC"
- g['LDSHARED'] = "gcc -pthread -shared"
+ g['LDSHARED'] = "cc -pthread -shared"
g['SO'] = [s[0] for s in imp.get_suffixes() if s[2] == imp.C_EXTENSION][0]
g['AR'] = "ar"
g['ARFLAGS'] = "rc"

View file

@ -0,0 +1,20 @@
--- rpython/rlib/rvmprof/src/shared/machine.c.orig 2017-06-05 20:40:44 UTC
+++ rpython/rlib/rvmprof/src/shared/machine.c
@@ -28,6 +28,8 @@ const char * vmp_machine_os_name(void)
#endif
#elif __linux__
return "linux";
+#elif __FreeBSD__
+ return "freebsd";
#else
#error "Unknown compiler"
#endif
@@ -39,7 +41,7 @@ long vmp_fd_to_path(int fd, char * buffe
char proffs[24];
(void)snprintf(proffs, 24, "/proc/self/fd/%d", fd);
return readlink(proffs, buffer, buffer_len);
-#elif defined(VMPROF_UNIX)
+#elif defined(VMPROF_UNIX) && !defined(__FreeBSD__)
fcntl(fd, F_GETPATH, buffer);
return strlen(buffer);
#endif

View file

@ -1,13 +0,0 @@
FreeBSD's base ld(1) does not currently support plugins and is not compatible
with clang's link-time optimisation.
--- rpython/translator/platform/posix.py.orig 2017-03-19 19:55:48 UTC
+++ rpython/translator/platform/posix.py
@@ -132,7 +132,7 @@ class BasePosix(Platform):
# xxx check which compilers accept this option or not
if not config or config.translation.gcrootfinder != 'asmgcc':
- cflags = ('-flto',) + cflags
+ pass
m = GnuMakefile(path)
m.exe_name = path.join(exe_name.basename)

View file

@ -2,8 +2,6 @@
# $FreeBSD$ # $FreeBSD$
PORTNAME= pypy3 PORTNAME= pypy3
DISTVERSION= 5.7.1
PORTREVISION= 2
DISTNAME= ${PORTNAME}-v${DISTVERSION}-src DISTNAME= ${PORTNAME}-v${DISTVERSION}-src
MASTERDIR= ${.CURDIR}/../pypy MASTERDIR= ${.CURDIR}/../pypy

View file

@ -1,3 +1,3 @@
TIMESTAMP = 1491510361 TIMESTAMP = 1497478958
SHA256 (pypy3-v5.7.1-src.tar.bz2) = 40ece0145282980ac121390f13709404c0532896507d5767496381180b631bd0 SHA256 (pypy3-v5.8.0-src.tar.bz2) = 9d090127335c3c0fd2b14c8835bf91752e62756e55ea06aad3353f24a6854223
SIZE (pypy3-v5.7.1-src.tar.bz2) = 28811162 SIZE (pypy3-v5.8.0-src.tar.bz2) = 28986883

View file

@ -0,0 +1,20 @@
--- rpython/rlib/rvmprof/src/shared/machine.c.orig 2017-06-05 20:40:44 UTC
+++ rpython/rlib/rvmprof/src/shared/machine.c
@@ -28,6 +28,8 @@ const char * vmp_machine_os_name(void)
#endif
#elif __linux__
return "linux";
+#elif __FreeBSD__
+ return "freebsd";
#else
#error "Unknown compiler"
#endif
@@ -39,7 +41,7 @@ long vmp_fd_to_path(int fd, char * buffe
char proffs[24];
(void)snprintf(proffs, 24, "/proc/self/fd/%d", fd);
return readlink(proffs, buffer, buffer_len);
-#elif defined(VMPROF_UNIX)
+#elif defined(VMPROF_UNIX) && !defined(__FreeBSD__)
fcntl(fd, F_GETPATH, buffer);
return strlen(buffer);
#endif

View file

@ -1,13 +0,0 @@
FreeBSD's base ld(1) does not currently support plugins and is not compatible
with clang's link-time optimisation.
--- rpython/translator/platform/posix.py.orig 2017-04-03 06:36:13 UTC
+++ rpython/translator/platform/posix.py
@@ -132,7 +132,7 @@ class BasePosix(Platform):
# xxx check which compilers accept this option or not
if not config or config.translation.gcrootfinder != 'asmgcc':
- cflags = ('-flto',) + cflags
+ pass
m = GnuMakefile(path)
m.exe_name = path.join(exe_name.basename)