commit:     e1bd456fcf9272cfdeaf542618c6b1f3ce3d1118
Author:     Yuta Satoh <nigoro.dev <AT> gmail <DOT> com>
AuthorDate: Tue Oct 11 12:37:39 2016 +0000
Commit:     Alexis Ballier <aballier <AT> gentoo <DOT> org>
CommitDate: Tue Oct 11 14:47:48 2016 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e1bd456f

sys-freebsd: bump to 11.0

 sys-freebsd/boot0/Manifest                         |   1 +
 sys-freebsd/boot0/boot0-11.0.ebuild                |  82 +++
 sys-freebsd/boot0/files/boot0-11.0-gcc46.patch     |  14 +
 .../boot0/files/boot0-11.0-uefi-support.patch      |  21 +
 sys-freebsd/freebsd-bin/Manifest                   |   1 +
 sys-freebsd/freebsd-bin/freebsd-bin-11.0.ebuild    |  42 ++
 sys-freebsd/freebsd-cddl/Manifest                  |   1 +
 .../files/freebsd-cddl-11.0-add-libs.patch         |  87 +++
 .../files/freebsd-cddl-11.0-workaround.patch       |  12 +
 sys-freebsd/freebsd-cddl/freebsd-cddl-11.0.ebuild  |  79 +++
 sys-freebsd/freebsd-lib/Manifest                   |   1 +
 .../files/freebsd-lib-11.0-bsdxml2expat.patch      |  39 ++
 .../files/freebsd-lib-11.0-liblink.patch           |  62 ++
 .../files/freebsd-lib-11.0-libproc-libcxx.patch    |  13 +
 .../files/freebsd-lib-11.0-libsysdecode.patch      |  22 +
 .../files/freebsd-lib-11.0-workaround.patch        |  12 +
 sys-freebsd/freebsd-lib/freebsd-lib-11.0.ebuild    | 644 +++++++++++++++++++++
 sys-freebsd/freebsd-libexec/Manifest               |   1 +
 .../freebsd-libexec/freebsd-libexec-11.0.ebuild    | 131 +++++
 sys-freebsd/freebsd-mk-defs/Manifest               |   1 +
 ...reebsd-mk-defs-11.0-drop-unsupport-cflags.patch |  13 +
 .../files/freebsd-mk-defs-11.0-gentoo.patch        | 343 +++++++++++
 .../files/freebsd-mk-defs-11.0-gnu.patch           |  63 ++
 .../freebsd-mk-defs-11.0-libproc-libcxx.patch      |  13 +
 .../files/freebsd-mk-defs-11.0-rename-libs.patch   |  16 +
 .../freebsd-mk-defs/freebsd-mk-defs-11.0.ebuild    |  55 ++
 sys-freebsd/freebsd-pam-modules/Manifest           |   1 +
 .../freebsd-pam-modules-11.0.ebuild                |  46 ++
 sys-freebsd/freebsd-pf/Manifest                    |   1 +
 .../files/freebsd-pf-11.0-libevent.patch           |  13 +
 .../freebsd-pf/files/freebsd-pf-11.0-pflogd.patch  |  13 +
 sys-freebsd/freebsd-pf/freebsd-pf-11.0.ebuild      |  71 +++
 sys-freebsd/freebsd-rescue/Manifest                |   1 +
 .../files/freebsd-rescue-11.0-rename-libs.patch    |  22 +
 .../freebsd-rescue/freebsd-rescue-11.0.ebuild      |  85 +++
 sys-freebsd/freebsd-sbin/Manifest                  |   1 +
 sys-freebsd/freebsd-sbin/freebsd-sbin-11.0.ebuild  | 100 ++++
 sys-freebsd/freebsd-share/Manifest                 |   1 +
 .../freebsd-share/freebsd-share-11.0.ebuild        | 114 ++++
 sys-freebsd/freebsd-sources/Manifest               |   1 +
 .../files/freebsd-sources-11.0-gentoo-gcc.patch    |  13 +
 .../files/freebsd-sources-11.0-gentoo.patch        |  22 +
 .../freebsd-sources/freebsd-sources-11.0.ebuild    | 170 ++++++
 sys-freebsd/freebsd-ubin/Manifest                  |   1 +
 .../files/freebsd-ubin-11.0-setXid.patch           | 147 +++++
 sys-freebsd/freebsd-ubin/freebsd-ubin-11.0.ebuild  | 209 +++++++
 sys-freebsd/freebsd-usbin/Manifest                 |   1 +
 .../files/freebsd-usbin-11.0-workaround.patch      |  13 +
 .../freebsd-usbin/freebsd-usbin-11.0.ebuild        | 186 ++++++
 49 files changed, 3001 insertions(+)

diff --git a/sys-freebsd/boot0/Manifest b/sys-freebsd/boot0/Manifest
index f1e6a89..7b7f95b 100644
--- a/sys-freebsd/boot0/Manifest
+++ b/sys-freebsd/boot0/Manifest
@@ -1,5 +1,6 @@
 DIST freebsd-contrib-9.1.tar.bz2 54751432 SHA256 
e7ffa056d4050ce03ee8e23e276e2a9a494326a98d60c43bee2afcc59576deb8 SHA512 
71be13049258c6e6b5e4f63cc16da5d349a89d68f04d87446e4ad33ae8bf2a93ea67d9c256b7bec60b61e65db0487268070cfb77a484c3ac0f8ba368b48c2438
 WHIRLPOOL 
a2a84423175499208d34809e802284d6ba649f317c3a9ad8b7312fa19efe142ebadab0048bac0db8e988e59f9a7468ac7c5d0d25e78b82bdb269a20d18153cee
 DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f51bcc3b14a1e9e90bb0e7cc4a35d SHA512 
40d0c36b6b889c404fa0e0afa38ba4e84a55bc88ffa2f98a70afbd7a32c4f32c158617ba770567d082a986d62c09b3ec8db3dc5ab853ee1c9bbe0b90bb82396e
 WHIRLPOOL 
581878bf9c43184b043b4293409b85901c9ed1f9bd279e965414aca41ba50950848ebda3ee10a503a028135dfd2765e95a11acd4e62a11c528e104392bbbd8d0
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3

diff --git a/sys-freebsd/boot0/boot0-11.0.ebuild 
b/sys-freebsd/boot0/boot0-11.0.ebuild
new file mode 100644
index 00000000..d108508
--- /dev/null
+++ b/sys-freebsd/boot0/boot0-11.0.ebuild
@@ -0,0 +1,82 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd flag-o-matic toolchain-funcs
+
+DESCRIPTION="FreeBSD's bootloader"
+SLOT="0"
+
+IUSE="bzip2 ieee1394 tftp zfs"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       sys/
+       lib/
+       contrib/bzip2/
+"
+
+RDEPEND=""
+DEPEND="=sys-freebsd/freebsd-mk-defs-${RV}*
+       =sys-freebsd/freebsd-lib-${RV}*"
+
+S="${WORKDIR}/sys/boot"
+
+PATCHES=( "${FILESDIR}/${PN}-11.0-gcc46.patch"
+       "${FILESDIR}/${PN}-11.0-uefi-support.patch"
+       "${FILESDIR}/${PN}-add-nossp-cflags.patch" )
+
+boot0_use_enable() {
+       use ${1} && mymakeopts="${mymakeopts} LOADER_${2}_SUPPORT=\"yes\""
+       use ${1} || mymakeopts="${mymakeopts} WITHOUT_${2}= "
+}
+
+pkg_setup() {
+       boot0_use_enable ieee1394 FIREWIRE
+       boot0_use_enable zfs ZFS
+       boot0_use_enable tftp TFTP
+       boot0_use_enable bzip2 BZIP2
+}
+
+src_prepare() {
+       sed -e '/-mno-align-long-strings/d' \
+               -i "${S}"/i386/boot2/Makefile \
+               -i "${S}"/i386/gptboot/Makefile \
+               -i "${S}"/i386/gptzfsboot/Makefile \
+               -i "${S}"/i386/zfsboot/Makefile || die
+
+       mymakeopts="${mymakeopts} LOADER_NO_GELI_SUPPORT=yes"
+       export MAKEOBJDIRPREFIX="${WORKDIR}/build"
+}
+
+src_compile() {
+       strip-flags
+       append-flags "-fno-strict-aliasing"
+
+       cd "${WORKDIR}/lib/libstand" || die
+       freebsd_src_compile
+
+       CFLAGS="${CFLAGS} -I${WORKDIR}/lib/libstand"
+       LDFLAGS="${LDFLAGS} -L${MAKEOBJDIRPREFIX}/${WORKDIR}/lib/libstand"
+       export LIBSTAND="${MAKEOBJDIRPREFIX}/${WORKDIR}/lib/libstand/libstand.a"
+
+       cd "${S}" || die
+       NOFLAGSTRIP="yes" freebsd_src_compile
+}
+
+src_install() {
+       dodir /boot/defaults
+       freebsd_src_install FILESDIR=/boot
+
+       cd "${WORKDIR}/sys/$(tc-arch-kernel)/conf" || die
+       insinto /boot
+       newins GENERIC.hints device.hints
+
+       echo 'CONFIG_PROTECT="/boot/device.hints"' > "${T}"/50boot0
+       doenvd "${T}"/50boot0
+}

diff --git a/sys-freebsd/boot0/files/boot0-11.0-gcc46.patch 
b/sys-freebsd/boot0/files/boot0-11.0-gcc46.patch
new file mode 100644
index 00000000..ec17d92
--- /dev/null
+++ b/sys-freebsd/boot0/files/boot0-11.0-gcc46.patch
@@ -0,0 +1,14 @@
+diff --git a/sys/boot/i386/boot2/Makefile b/sys/boot/i386/boot2/Makefile
+index ead9ad1..af5e021 100644
+--- a/sys/boot/i386/boot2/Makefile
++++ b/sys/boot/i386/boot2/Makefile
+@@ -45,6 +45,9 @@ CFLAGS.gcc+= -Os \
+ .if ${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} <= 40201
+ CFLAGS.gcc+=   -mno-align-long-strings
+ .endif
++.if ${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} >= 40600
++CFLAGS.gcc+=  -fno-asynchronous-unwind-tables
++.endif
+ 
+ CFLAGS.clang+=        -Oz ${CLANG_OPT_SMALL}
+ 

diff --git a/sys-freebsd/boot0/files/boot0-11.0-uefi-support.patch 
b/sys-freebsd/boot0/files/boot0-11.0-uefi-support.patch
new file mode 100644
index 00000000..c7a69d6
--- /dev/null
+++ b/sys-freebsd/boot0/files/boot0-11.0-uefi-support.patch
@@ -0,0 +1,21 @@
+diff --git a/sys/boot/efi/Makefile b/sys/boot/efi/Makefile
+index 79ee9a9..f7789f1 100644
+--- a/sys/boot/efi/Makefile
++++ b/sys/boot/efi/Makefile
+@@ -4,7 +4,7 @@
+ 
+ # In-tree GCC does not support __attribute__((ms_abi)), but gcc newer
+ # than 4.5 supports it.
+-.if ${COMPILER_TYPE} != "gcc" || ${COMPILER_VERSION} >= 404500
++.if ${COMPILER_TYPE} != "gcc" || ${COMPILER_VERSION} >= 40500
+ 
+ .if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm"
+ .if ${MK_FDT} != "no"
+@@ -18,6 +18,6 @@ SUBDIR+=     fdt
+ SUBDIR+=      libefi loader boot1
+ .endif
+ 
+-.endif # ${COMPILER_TYPE} != "gcc" || ${COMPILER_VERSION} >= 404500
++.endif # ${COMPILER_TYPE} != "gcc" || ${COMPILER_VERSION} >= 40500
+ 
+ .include <bsd.subdir.mk>

diff --git a/sys-freebsd/freebsd-bin/Manifest b/sys-freebsd/freebsd-bin/Manifest
index bc22b07..97dc452 100644
--- a/sys-freebsd/freebsd-bin/Manifest
+++ b/sys-freebsd/freebsd-bin/Manifest
@@ -5,4 +5,5 @@ DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-ubin-9.1.tar.bz2 1910472 SHA256 
ff6e586f213534b6ec2e65002c0dee64063d76ddad515c12221b1a80a1815e48 SHA512 
74ae0aceec8597aa66c3f1ab313f0685a3c63d7273c36ae7baf8794275ad9bca241c60c3f6281cccf6d531d250d7611099977d3b1a27279cef3586401b6af05e
 WHIRLPOOL 
c85a3c9cf2bceff2c60ff03556bcc81d3aca22b0bce3c9538990071ac0a907236eee5ae7743ad22c5fd309b047ebf392aaaf2fe177ef5790ea869aff3da7e2fe

diff --git a/sys-freebsd/freebsd-bin/freebsd-bin-11.0.ebuild 
b/sys-freebsd/freebsd-bin/freebsd-bin-11.0.ebuild
new file mode 100644
index 00000000..d4bf7e3
--- /dev/null
+++ b/sys-freebsd/freebsd-bin/freebsd-bin-11.0.ebuild
@@ -0,0 +1,42 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd
+
+DESCRIPTION="FreeBSD /bin tools"
+SLOT="0"
+
+IUSE=""
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       bin/
+       usr.bin/
+       sbin/
+       lib/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*
+       >=dev-libs/libedit-20120311.3.0-r1
+       sys-libs/ncurses:0=
+       sys-apps/ed
+       !app-misc/realpath
+       !<sys-freebsd/freebsd-ubin-8"
+DEPEND="${RDEPEND}
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       >=sys-devel/flex-2.5.31-r2"
+
+S=${WORKDIR}/bin
+
+# csh and tcsh are provided by tcsh package, rmail is sendmail stuff.
+REMOVE_SUBDIRS="csh rmail ed freebsd-version"
+
+pkg_setup() {
+       mymakeopts="${mymakeopts} WITHOUT_TCSH= WITHOUT_SENDMAIL= 
WITHOUT_RCMDS= "
+}

diff --git a/sys-freebsd/freebsd-cddl/Manifest 
b/sys-freebsd/freebsd-cddl/Manifest
index 1a47a31..fe99dff 100644
--- a/sys-freebsd/freebsd-cddl/Manifest
+++ b/sys-freebsd/freebsd-cddl/Manifest
@@ -9,6 +9,7 @@ DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c

diff --git a/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-add-libs.patch 
b/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-add-libs.patch
new file mode 100644
index 00000000..46f2521
--- /dev/null
+++ b/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-add-libs.patch
@@ -0,0 +1,87 @@
+diff --git a/cddl/sbin/zfs/Makefile b/cddl/sbin/zfs/Makefile
+index 1e386e5..a4c08ee 100644
+--- a/cddl/sbin/zfs/Makefile
++++ b/cddl/sbin/zfs/Makefile
+@@ -22,6 +22,6 @@ CFLAGS+= 
-I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/uts/common/fs/zfs
+ CFLAGS+= -I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/uts/common/sys
+ CFLAGS+= -I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/common/zfs
+ 
+-LIBADD=       jail nvpair uutil zfs_core zfs
++LIBADD=       jail nvpair uutil zfs_core zfs umem avl
+ 
+ .include <bsd.prog.mk>
+diff --git a/cddl/sbin/zpool/Makefile b/cddl/sbin/zpool/Makefile
+index ebf0f90..c70a3c4 100644
+--- a/cddl/sbin/zpool/Makefile
++++ b/cddl/sbin/zpool/Makefile
+@@ -27,6 +27,6 @@ CFLAGS+= 
-I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/uts/common/sys
+ CFLAGS+= -I${.CURDIR}/../../../cddl/contrib/opensolaris/lib/libzpool/common
+ CFLAGS+= -I${.CURDIR}/../../../cddl/contrib/opensolaris/cmd/stat/common
+ 
+-LIBADD=       geom nvpair uutil zfs
++LIBADD=       geom nvpair uutil zfs umem avl zfs_core
+ 
+ .include <bsd.prog.mk>
+diff --git a/cddl/usr.sbin/lockstat/Makefile b/cddl/usr.sbin/lockstat/Makefile
+index fc68904..9af6ff2 100644
+--- a/cddl/usr.sbin/lockstat/Makefile
++++ b/cddl/usr.sbin/lockstat/Makefile
+@@ -21,6 +21,6 @@ CFLAGS+=     -DNEED_ERRLOC -g
+ 
+ #YFLAGS+=     -d
+ 
+-LIBADD=       elf dtrace rt
++LIBADD=       elf dtrace rt ctf
+ 
+ .include <bsd.prog.mk>
+diff --git a/cddl/usr.sbin/plockstat/Makefile 
b/cddl/usr.sbin/plockstat/Makefile
+index 77b6139..7737efd 100644
+--- a/cddl/usr.sbin/plockstat/Makefile
++++ b/cddl/usr.sbin/plockstat/Makefile
+@@ -18,6 +18,6 @@ CFLAGS+=     
-I${.CURDIR}/../../../sys/cddl/compat/opensolaris \
+               -I${.CURDIR}/../../../cddl/lib/libdtrace \
+               -I${.CURDIR}/../../../sys
+ 
+-LIBADD=       dtrace proc
++LIBADD=       dtrace proc ctf
+ 
+ .include <bsd.prog.mk>
+diff --git a/cddl/usr.sbin/zdb/Makefile b/cddl/usr.sbin/zdb/Makefile
+index 3609502..71526f7 100644
+--- a/cddl/usr.sbin/zdb/Makefile
++++ b/cddl/usr.sbin/zdb/Makefile
+@@ -24,7 +24,7 @@ CFLAGS+= 
-I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/common/zfs
+ CFLAGS+= -I${.CURDIR}/../../../cddl/contrib/opensolaris/head
+ CFLAGS+= -I${.CURDIR}/../../lib/libumem
+ 
+-LIBADD=       nvpair umem uutil zfs zpool
++LIBADD=       nvpair umem uutil zfs zpool avl zfs_core
+ 
+ # Since there are many asserts in this program, it makes no sense to compile
+ # it without debugging.
+diff --git a/cddl/usr.sbin/zfsd/Makefile.common 
b/cddl/usr.sbin/zfsd/Makefile.common
+index a545609..034d418 100644
+--- a/cddl/usr.sbin/zfsd/Makefile.common
++++ b/cddl/usr.sbin/zfsd/Makefile.common
+@@ -35,7 +35,7 @@ CXXFLAGS= -g -DNEED_SOLARIS_BOOLEAN ${INCFLAGS}
+ 
+ DPADD=  ${LIBDEVDCTL} ${LIBZFS} ${LIBZFS_CORE} ${LIBUTIL} ${LIBGEOM} \
+       ${LIBBSDXML} ${LIBSBUF} ${LIBNVPAIR} ${LIBUUTIL}
+-LIBADD=  devdctl zfs zfs_core util geom bsdxml sbuf nvpair uutil
++LIBADD=  devdctl zfs zfs_core util geom bsdxml sbuf nvpair uutil umem avl
+ 
+ cscope:
+       find ${.CURDIR} -type f -a \( -name "*.[ch]" -o -name "*.cc" \) \
+diff --git a/cddl/usr.sbin/zhack/Makefile b/cddl/usr.sbin/zhack/Makefile
+index 02c51ac..d9b79a9 100644
+--- a/cddl/usr.sbin/zhack/Makefile
++++ b/cddl/usr.sbin/zhack/Makefile
+@@ -23,7 +23,7 @@ CFLAGS+= 
-I${.CURDIR}/../../../sys/cddl/contrib/opensolaris/common/zfs
+ CFLAGS+= -I${.CURDIR}/../../../cddl/contrib/opensolaris/head
+ CFLAGS+= -I${.CURDIR}/../../lib/libumem
+ 
+-LIBADD=       nvpair zfs zpool
++LIBADD=       nvpair zfs zpool umem uutil avl zfs_core
+ 
+ CFLAGS+=      -DDEBUG=1
+ #DEBUG_FLAGS+=        -g

diff --git a/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-workaround.patch 
b/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-workaround.patch
new file mode 100644
index 00000000..839b6b5
--- /dev/null
+++ b/sys-freebsd/freebsd-cddl/files/freebsd-cddl-11.0-workaround.patch
@@ -0,0 +1,12 @@
+diff --git a/cddl/usr.sbin/zfsd/Makefile.common 
b/cddl/usr.sbin/zfsd/Makefile.common
+index 6c71bdf..6b71908 100644
+--- a/cddl/usr.sbin/zfsd/Makefile.common
++++ b/cddl/usr.sbin/zfsd/Makefile.common
+@@ -31,6 +31,7 @@ INCFLAGS+= 
-I${SRCDIR}/sys/cddl/contrib/opensolaris/uts/common/fs/zfs
+ INCFLAGS+= -I${SRCDIR}/sys/cddl/contrib/opensolaris/uts/common/sys
+ 
+ CFLAGS= -g -DNEED_SOLARIS_BOOLEAN ${INCFLAGS}
++CXXFLAGS= -g -DNEED_SOLARIS_BOOLEAN ${INCFLAGS}
+ 
+ DPADD=  ${LIBDEVDCTL} ${LIBZFS} ${LIBZFS_CORE} ${LIBUTIL} ${LIBGEOM} \
+       ${LIBBSDXML} ${LIBSBUF} ${LIBNVPAIR} ${LIBUUTIL}

diff --git a/sys-freebsd/freebsd-cddl/freebsd-cddl-11.0.ebuild 
b/sys-freebsd/freebsd-cddl/freebsd-cddl-11.0.ebuild
new file mode 100644
index 00000000..2efbb35
--- /dev/null
+++ b/sys-freebsd/freebsd-cddl/freebsd-cddl-11.0.ebuild
@@ -0,0 +1,79 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd toolchain-funcs multilib
+
+DESCRIPTION="FreeBSD CDDL (opensolaris/zfs) extra software"
+SLOT="0"
+
+IUSE="build"
+LICENSE="CDDL GPL-2"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~x86-fbsd"
+fi
+
+# sys is required.
+EXTRACTONLY="
+       cddl/
+       contrib/
+       usr.bin/
+       lib/
+       sbin/
+       sys/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*
+       =sys-freebsd/freebsd-libexec-${RV}*
+       build? ( sys-apps/baselayout )"
+
+DEPEND="${RDEPEND}
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       !build? ( =sys-freebsd/freebsd-sources-${RV}* )"
+
+S="${WORKDIR}/cddl"
+
+PATCHES=( "${FILESDIR}/${PN}-11.0-workaround.patch"
+       "${FILESDIR}/${PN}-11.0-add-libs.patch" )
+
+pkg_setup() {
+       # Add the required source files.
+       use build && EXTRACTONLY+="include/ "
+       [[ $(tc-getCXX) != *clang++* ]] && REMOVE_SUBDIRS="usr.sbin/zfsd"
+}
+
+src_prepare() {
+       if [[ ! -e "${WORKDIR}/include" ]]; then
+               # Link in include headers.
+               ln -s "/usr/include" "${WORKDIR}/include" || die "Symlinking 
/usr/include.."
+       fi
+       for d in libavl libctf libdtrace libnvpair libumem libuutil libzfs 
libzfs_core libzpool; do
+               LDFLAGS="${LDFLAGS} -L${S}/lib/${d}"
+       done
+}
+
+src_compile() {
+       cd "${S}"/lib || die
+       freebsd_src_compile
+       cd "${S}" || die
+       freebsd_src_compile
+}
+
+src_install() {
+       # Install libraries proper place
+       local mylibdir=$(get_libdir)
+       freebsd_src_install SHLIBDIR="/usr/${mylibdir}" 
LIBDIR="/usr/${mylibdir}"
+
+       gen_usr_ldscript -a avl nvpair umem uutil zfs zpool zfs_core
+
+       # Install zfs volinit script.
+       newinitd "${FILESDIR}"/zvol.initd-9.0 zvol
+
+       # Install zfs script
+       newinitd "${FILESDIR}"/zfs.initd zfs
+
+       keepdir /etc/zfs
+}

diff --git a/sys-freebsd/freebsd-lib/Manifest b/sys-freebsd/freebsd-lib/Manifest
index 65e15d2..f4a53d4 100644
--- a/sys-freebsd/freebsd-lib/Manifest
+++ b/sys-freebsd/freebsd-lib/Manifest
@@ -15,6 +15,7 @@ DIST freebsd-lib-EN-1606-libc.patch 249 SHA256 
5ad0e95c5418ebd3edb06dc3f287b3fd8
 DIST freebsd-libexec-8.2.tar.bz2 289147 SHA256 
10b996d1d8cd044ee2e7a877e5e6ad2bf050cce9b3bd402a5e0dea7d290b595d SHA512 
abe6cf5a268675d7dcb1c214c46fef47a3fb09b31947f5d8a0b938d352295efe0249beb5007649c52187bf4c221b6ebf074d18dfe9bafd168cae09ee02ab608d
 WHIRLPOOL 
27e854fe465eb933dd8e27c5a09b063e4d3798b54e0914c79a9120dcdc34cc5d525a0c92da7b645ff7ab2ab4f34c7f7b2783012dfa5004407acd11150062b7ad
 DIST freebsd-libexec-9.1.tar.bz2 304592 SHA256 
71e6e9e41328c2148c54b81ad9b59f912a1d5f0d52e17ac07f223aa7a94b82be SHA512 
7baa4160dda2610250dd52f445e24478e0f1ea10bce21fcd0e5d1b856f399b896adc334114de0c7f61a5637e4349bb1688fdbe5c72798d8568ae791114710b92
 WHIRLPOOL 
d800f477ac5c9ad6dae3e0091c83e107609b5a1e3aa79e9533fcd10a8dd34ff7733ab9523eae7c292310fe94f6a529209cae6b9e8bac6b47244e59834593e74b
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-usbin-8.2.tar.bz2 2443024 SHA256 
aa7cabf10f5c3a9daabea32e4de24d04ec312247842981476da666eff5054603 SHA512 
bcb8ff3df54848b9107bbb52e5ced7a91e24bb181f06769b6997221729b8064ec17652eaf7500de3268cbcb63ff5760beb54d15fc78c27b02687b5b1067c74a6
 WHIRLPOOL 
20f5278e2a1dd387a75b44f10507958d6c0e84a2faa1bddbf808c14ab86d8dd14a956192911bbc1880f5f5f7bd05972dcbb4aec85d241f0dcf91bf4246883f0a

diff --git a/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-bsdxml2expat.patch 
b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-bsdxml2expat.patch
new file mode 100644
index 00000000..41a394b
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-bsdxml2expat.patch
@@ -0,0 +1,39 @@
+diff --git a/lib/libgeom/geom_xml2tree.c b/lib/libgeom/geom_xml2tree.c
+index 9dedb8e..d96420c 100644
+--- a/lib/libgeom/geom_xml2tree.c
++++ b/lib/libgeom/geom_xml2tree.c
+@@ -43,7 +43,7 @@
+ #include <sys/sbuf.h>
+ #include <sys/sysctl.h>
+ #include <err.h>
+-#include <bsdxml.h>
++#include <expat.h>
+ #include <libgeom.h>
+ 
+ struct mystate {
+diff --git a/lib/libmt/mtlib.c b/lib/libmt/mtlib.c
+index d1fc0b1..89ac55e 100644
+--- a/lib/libmt/mtlib.c
++++ b/lib/libmt/mtlib.c
+@@ -48,7 +48,7 @@ __FBSDID("$FreeBSD: stable/10/lib/libmt/mtlib.c 280438 
2015-03-24 14:36:10Z ken
+ #include <unistd.h>
+ #include <stdint.h>
+ #include <errno.h>
+-#include <bsdxml.h>
++#include <expat.h>
+ #include <mtlib.h>
+ 
+ /*
+diff --git a/lib/lib80211/lib80211_regdomain.c 
b/lib/lib80211/lib80211_regdomain.c
+index c500d3f..fe1d37e 100644
+--- a/lib/lib80211/lib80211_regdomain.c
++++ b/lib/lib80211/lib80211_regdomain.c
+@@ -40,7 +40,7 @@ static const char rcsid[] = "$FreeBSD: 
stable/11/lib/lib80211/lib80211_regdomain
+ #include <err.h>
+ #include <unistd.h>
+ 
+-#include <bsdxml.h>
++#include <expat.h>
+ 
+ #include "lib80211_regdomain.h"
+ 

diff --git a/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-liblink.patch 
b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-liblink.patch
new file mode 100644
index 00000000..da495e4
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-liblink.patch
@@ -0,0 +1,62 @@
+diff --git a/lib/libproc/Makefile b/lib/libproc/Makefile
+index 2dedf11..275f4c3 100644
+--- a/lib/libproc/Makefile
++++ b/lib/libproc/Makefile
+@@ -15,6 +15,7 @@ SRCS=        proc_bkpt.c             \
+ INCS= libproc.h
+ 
+ CFLAGS+=      -I${.CURDIR}
++CFLAGS+=      -I${.CURDIR}/../libelf
+ 
+ .if ${MK_CXX} == "no"
+ CFLAGS+=      -DNO_CXA_DEMANGLE
+@@ -28,6 +29,9 @@ LIBADD+=     elf rtld_db util
+ 
+ .if ${MK_CDDL} != "no"
+ LIBADD+=      ctf
++LDADD+=               -lelf
++LDFLAGS+=     -L${.OBJDIR}/../libelf
++
+ IGNORE_PRAGMA=        YES
+ CFLAGS+=      -I${.CURDIR}/../../cddl/contrib/opensolaris/lib/libctf/common \
+               -I${.CURDIR}/../../sys/cddl/contrib/opensolaris/uts/common \
+diff --git a/lib/libprocstat/Makefile b/lib/libprocstat/Makefile
+index 1829883..d0065a3 100644
+--- a/lib/libprocstat/Makefile
++++ b/lib/libprocstat/Makefile
+@@ -17,6 +17,8 @@ VERSION_DEF= ${.CURDIR}/Versions.def
+ SYMBOL_MAPS=  ${.CURDIR}/Symbol.map
+ 
+ INCS=         libprocstat.h
++CFLAGS+=      -I${.CURDIR}/../libelf
++LDFLAGS+=       -L${.OBJDIR}/../libelf
+ CFLAGS+=      -I. -I${.CURDIR} -D_KVM_VNODE
+ SHLIB_MAJOR=  1
+ 
+diff --git a/lib/librtld_db/Makefile b/lib/librtld_db/Makefile
+index 0a8ed95..11baf5b 100644
+--- a/lib/librtld_db/Makefile
++++ b/lib/librtld_db/Makefile
+@@ -11,6 +11,9 @@ SRCS=                rtld_db.c
+ INCS=         rtld_db.h
+ 
+ CFLAGS+= -I${.CURDIR}
++CFLAGS+= -I${.CURDIR}/../libelf
++LDADD+= -lutil -lproc
++LDFLAGS+= -L${.OBJDIR}/../libutil -L${.OBJDIR}/../libproc
+ # Avoid circular dependency, we only need the libproc.h header here.
+ CFLAGS+= -I${.CURDIR:H}/libproc
+ 
+diff --git a/lib/libtelnet/Makefile b/lib/libtelnet/Makefile
+index f84aee3..c36ade9 100644
+--- a/lib/libtelnet/Makefile
++++ b/lib/libtelnet/Makefile
+@@ -14,6 +14,8 @@ INTERNALLIB=
+ SRCS=         genget.c getent.c misc.c
+ CFLAGS+=      -I${TELNETDIR}
+ 
++CFLAGS+=      -I${.CURDIR}/../libmp
++
+ WARNS?=               2
+ 
+ .if ${MK_OPENSSL} != "no"

diff --git 
a/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libproc-libcxx.patch 
b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libproc-libcxx.patch
new file mode 100644
index 00000000..013ad20
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libproc-libcxx.patch
@@ -0,0 +1,13 @@
+diff --git a/lib/libproc/Makefile b/lib/libproc/Makefile
+index e3b2578..acd76e8 100644
+--- a/lib/libproc/Makefile
++++ b/lib/libproc/Makefile
+@@ -18,7 +18,7 @@ CFLAGS+=     -I${.CURDIR}
+ 
+ .if ${MK_CXX} == "no"
+ CFLAGS+=      -DNO_CXA_DEMANGLE
+-.elif ${MK_LIBCPLUSPLUS} != "no"
++.elif ${COMPILER_TYPE} == "clang"
+ LIBADD+=              cxxrt
+ .else
+ LIBADD+=      supcplusplus

diff --git a/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libsysdecode.patch 
b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libsysdecode.patch
new file mode 100644
index 00000000..d90aa31
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-libsysdecode.patch
@@ -0,0 +1,22 @@
+diff --git a/lib/libsysdecode/Makefile b/lib/libsysdecode/Makefile
+index e3bfe00..51fc5f0 100644
+--- a/lib/libsysdecode/Makefile
++++ b/lib/libsysdecode/Makefile
+@@ -8,7 +8,7 @@ LIB=   sysdecode
+ SRCS= errno.c ioctl.c syscallnames.c utrace.c
+ INCS= sysdecode.h
+ 
+-CFLAGS+= -I${.CURDIR}/../../sys
++CFLAGS+= -I${.CURDIR}/../../sys -I${.CURDIR}
+ 
+ MAN+= sysdecode.3 \
+       sysdecode_abi_to_freebsd_errno.3 \
+@@ -37,7 +37,7 @@ CFLAGS.gcc+= ${CFLAGS.gcc.${.IMPSRC}}
+ 
+ ioctl.c: mkioctls
+       env MACHINE=${MACHINE} CPP="${CPP}" \
+-              /bin/sh ${.CURDIR}/mkioctls ${DESTDIR}${INCLUDEDIR} > ${.TARGET}
++              /bin/sh ${.CURDIR}/mkioctls ${.CURDIR}/../../include > 
${.TARGET}
+ 
+ beforedepend: ioctl.c
+ 

diff --git a/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-workaround.patch 
b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-workaround.patch
new file mode 100644
index 00000000..05f817e
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/files/freebsd-lib-11.0-workaround.patch
@@ -0,0 +1,12 @@
+diff --git a/lib/libdevdctl/event.cc b/lib/libdevdctl/event.cc
+index a8cb447..d56df2e 100644
+--- a/lib/libdevdctl/event.cc
++++ b/lib/libdevdctl/event.cc
+@@ -50,6 +50,7 @@
+ #include <syslog.h>
+ #include <unistd.h>
+ 
++#include <cstdio>
+ #include <cstdarg>
+ #include <cstring>
+ #include <iostream>

diff --git a/sys-freebsd/freebsd-lib/freebsd-lib-11.0.ebuild 
b/sys-freebsd/freebsd-lib/freebsd-lib-11.0.ebuild
new file mode 100644
index 00000000..5265af2
--- /dev/null
+++ b/sys-freebsd/freebsd-lib/freebsd-lib-11.0.ebuild
@@ -0,0 +1,644 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd flag-o-matic multilib toolchain-funcs eutils multibuild 
multilib-build
+
+DESCRIPTION="FreeBSD's base system libraries"
+SLOT="0"
+LICENSE="BSD zfs? ( CDDL )"
+
+# Security Advisory and Errata patches.
+# UPSTREAM_PATCHES=()
+
+# Crypto is needed to have an internal OpenSSL header
+# sys is needed for libalias, probably we can just extract that instead of
+# extracting the whole tarball
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+       SRC_URI="${SRC_URI}
+                       $(freebsd_upstream_patches)"
+fi
+
+EXTRACTONLY="
+       lib/
+       contrib/
+       crypto/
+       libexec/
+       etc/
+       include/
+       usr.sbin/
+       gnu/
+       secure/
+"
+
+if [ "${CATEGORY#*cross-}" = "${CATEGORY}" ]; then
+       RDEPEND="ssl? ( dev-libs/openssl:0= )
+               hesiod? ( net-dns/hesiod )
+               kerberos? ( app-crypt/heimdal )
+               usb? ( !dev-libs/libusb )
+               zfs? ( =sys-freebsd/freebsd-cddl-${RV}* )
+               >=dev-libs/expat-2.0.1
+               >=dev-util/dialog-1.2.20150225
+               =sys-freebsd/freebsd-libexec-${RV}*
+               !sys-libs/libutempter
+               !dev-libs/libelf
+               !dev-libs/libexecinfo
+               !dev-libs/libiconv
+               !sys-freebsd/freebsd-headers"
+       DEPEND="${RDEPEND}
+               >=sys-devel/flex-2.5.31-r2
+               =sys-freebsd/freebsd-sources-${RV}*"
+       RDEPEND="${RDEPEND}
+               =sys-freebsd/freebsd-share-${RV}*
+               >=virtual/libiconv-0-r2"
+else
+       EXTRACTONLY+="sys/ "
+fi
+
+DEPEND="${DEPEND}
+               userland_GNU? ( sys-apps/mtree )
+               =sys-freebsd/freebsd-mk-defs-${RV}*"
+
+S="${WORKDIR}/lib"
+
+export CTARGET=${CTARGET:-${CHOST}}
+if [ "${CTARGET}" = "${CHOST}" -a "${CATEGORY#*cross-}" != "${CATEGORY}" ]; 
then
+       export CTARGET=${CATEGORY/cross-}
+fi
+
+IUSE="atm bluetooth ssl hesiod ipv6 kerberos usb netware
+       build crosscompile_opts_headers-only zfs
+       userland_GNU userland_BSD"
+
+QA_DT_NEEDED="lib/libc.so.7 usr/lib32/libc.so.7"
+
+pkg_setup() {
+       # Add the required source files.
+       use build && EXTRACTONLY+="sys/ "
+       use zfs && EXTRACTONLY+="cddl/ "
+
+       [ -c /dev/zero ] || \
+               die "You forgot to mount /dev; the compiled libc would break."
+
+       if ! use ssl && use kerberos; then
+               eerror "If you want kerberos support you need to enable ssl 
support, too."
+       fi
+
+       use atm || mymakeopts="${mymakeopts} WITHOUT_ATM= "
+       use bluetooth || mymakeopts="${mymakeopts} WITHOUT_BLUETOOTH= "
+       use hesiod || mymakeopts="${mymakeopts} WITHOUT_HESIOD= "
+       use ipv6 || mymakeopts="${mymakeopts} WITHOUT_INET6_SUPPORT= "
+       use kerberos || mymakeopts="${mymakeopts} WITHOUT_KERBEROS_SUPPORT= 
WITHOUT_GSSAPI= "
+       use netware || mymakeopts="${mymakeopts} WITHOUT_IPX= 
WITHOUT_IPX_SUPPORT= WITHOUT_NCP= "
+       use ssl || mymakeopts="${mymakeopts} WITHOUT_OPENSSL= "
+       use usb || mymakeopts="${mymakeopts} WITHOUT_USB= "
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_CDDL= "
+
+       mymakeopts="${mymakeopts} WITHOUT_SENDMAIL= WITHOUT_CLANG= 
WITHOUT_LIBCPLUSPLUS= WITHOUT_LDNS= WITHOUT_UNBOUND= "
+
+       if [ "${CTARGET}" != "${CHOST}" ]; then
+               mymakeopts="${mymakeopts} MACHINE=$(tc-arch-kernel ${CTARGET})"
+               mymakeopts="${mymakeopts} MACHINE_ARCH=$(tc-arch-kernel 
${CTARGET})"
+       fi
+}
+
+PATCHES=(
+       "${FILESDIR}/${PN}-6.0-pmc.patch"
+       "${FILESDIR}/${PN}-10.0-atfcxx.patch"
+       "${FILESDIR}/${PN}-9.0-bluetooth.patch"
+       "${FILESDIR}/${PN}-11.0-workaround.patch"
+       "${FILESDIR}/${PN}-11.0-bsdxml2expat.patch"
+       "${FILESDIR}/${PN}-11.0-libsysdecode.patch"
+       "${FILESDIR}/${PN}-11.0-libproc-libcxx.patch"
+       "${FILESDIR}/${PN}-add-nossp-cflags.patch"
+       )
+# Here we disable and remove source which we don't need or want
+# In order:
+# - ncurses stuff
+# - libexpat creates a bsdxml library which is the same as expat
+# - archiving libraries (have their own ebuild)
+# - sendmail libraries (they are installed by sendmail)
+# - SNMP library and dependency (have their own ebuilds)
+# - libstand: static library, 32bits on amd64 used for boot0, we build it from
+# boot0 instead.
+#
+# The rest are libraries we already have somewhere else because
+# they are contribution.
+REMOVE_SUBDIRS="ncurses \
+       libexpat \
+       libz libbz2 libarchive liblzma \
+       libsm libsmdb libsmutil \
+       libbegemot libbsnmp \
+       libpam libpcap libwrap libmagic \
+       libcom_err
+       libedit
+       libstand
+       libgssapi"
+
+# Are we building a cross-compiler?
+is_crosscompile() {
+       [ "${CATEGORY#*cross-}" != "${CATEGORY}" ]
+}
+
+src_prepare() {
+       # gcc-5.0 or later, Workaround for critical issue. bug 573358.
+       use x86-fbsd && [[ "$(gcc-major-version)" -ge 5 ]] && replace-flags -O? 
-O1
+
+       sed -i.bak -e 's:-o/dev/stdout:-t:' "${S}/libc/net/Makefile.inc"
+
+       # Upstream Display Managers default to using VT7
+       # We should make FreeBSD allow this by default
+       local x=
+       for x in "${WORKDIR}"/etc/etc.*/ttys ; do
+               sed -i.bak \
+                       -e '/ttyv5[[:space:]]/ a\
+# Display Managers default to VT7.\
+# If you use the xdm init script, keep ttyv6 commented out\
+# unless you force a different VT for the DM being used.' \
+                       -e '/^ttyv[678][[:space:]]/ s/^/# /' "${x}" \
+                       || die "Failed to sed ${x}"
+               rm "${x}".bak
+       done
+
+       # This one is here because it also
+       # patches "${WORKDIR}/include"
+       cd "${WORKDIR}"
+       epatch "${FILESDIR}/${PN}-includes.patch"
+
+       # Don't install the hesiod man page or header
+       rm "${WORKDIR}"/include/hesiod.h || die
+       sed -i.bak -e 's:hesiod.h::' "${WORKDIR}"/include/Makefile || die
+       sed -i.bak -e 's:hesiod.c::' -e 's:hesiod.3::' \
+       "${WORKDIR}"/lib/libc/net/Makefile.inc || die
+
+       # Fix the Makefiles of these few libraries that will overwrite our 
LDADD.
+       cd "${S}"
+       for dir in libradius libtacplus libcam libdevstat libfetch libgeom 
libmemstat libopie \
+               libsmb libprocstat libulog; do sed -i.bak -e 
's:LDADD=:LDADD+=:g' "${dir}/Makefile" || \
+               die "Problem fixing \"${dir}/Makefile"
+       done
+       # Call LD with LDFLAGS, rename them to RAW_LDFLAGS
+       sed -e 's/LDFLAGS/RAW_LDFLAGS/g' \
+               -i "${S}/csu/i386/Makefile" || die
+
+       if install --version 2> /dev/null | grep -q GNU; then
+               sed -i.bak -e 's:${INSTALL} -C:${INSTALL}:' 
"${WORKDIR}/include/Makefile"
+       fi
+
+       # Try to fix sed calls for GNU sed. Do it only with GNU userland and 
force
+       # BSD's sed on BSD.
+       cd "${S}"
+       if [[ ${CBUILD:-${CHOST}} != *bsd* ]]; then
+               find . -name Makefile -exec sed -ibak 's/sed -i /sed -i/' {} \;
+               sed -i -e 's/-i ""/-i""/' "${S}/csu/Makefile.inc" || die
+       fi
+
+       if use build; then
+               cd "${WORKDIR}"
+               # This patch has to be applied on ${WORKDIR}/sys, so we do it 
here since it
+               # shouldn't be a symlink to /usr/src/sys (which should be 
already patched)
+               epatch "${FILESDIR}"/freebsd-sources-9.0-sysctluint.patch
+               return 0
+       fi
+
+       if ! is_crosscompile ; then
+               if [[ ! -e "${WORKDIR}/sys" ]]; then
+                       ln -s "${SYSROOT}/usr/src/sys" "${WORKDIR}/sys" || die 
"Couldn't make sys symlink!"
+               fi
+       else
+               sed -i.bak -e "s:/usr/include:/usr/${CTARGET}/usr/include:g" \
+                       "${S}/libc/rpc/Makefile.inc" \
+                       "${S}/libc/yp/Makefile.inc"
+       fi
+}
+
+bootstrap_lib() {
+       for i ; do
+               cd "${WORKDIR}/${i}" || die "missing ${i}"
+               freebsd_src_compile
+               append-ldflags "-L${MAKEOBJDIRPREFIX}/${WORKDIR}/${i}"
+       done
+}
+
+get_csudir() {
+       if [ -d "${WORKDIR}/lib/csu/$1-elf" ]; then
+               echo "lib/csu/$1-elf"
+       else
+               echo "lib/csu/$1"
+       fi
+}
+
+bootstrap_csu() {
+       local csudir="$(get_csudir $(tc-arch-kernel ${CTARGET}))"
+       export RAW_LDFLAGS=$(raw-ldflags)
+       bootstrap_lib "${csudir}"
+
+       CFLAGS="${CFLAGS} -B ${MAKEOBJDIRPREFIX}/${WORKDIR}/${csudir}"
+       append-ldflags "-B ${MAKEOBJDIRPREFIX}/${WORKDIR}/${csudir}"
+
+       bootstrap_lib "gnu/lib/csu"
+
+       cd "${MAKEOBJDIRPREFIX}/${WORKDIR}/gnu/lib/csu"
+       for i in *.So ; do
+               ln -s $i ${i%.So}S.o
+       done
+       CFLAGS="${CFLAGS} -B ${MAKEOBJDIRPREFIX}/${WORKDIR}/gnu/lib/csu"
+       append-ldflags "-B ${MAKEOBJDIRPREFIX}/${WORKDIR}/gnu/lib/csu"
+}
+
+# Compile libssp_nonshared.a and add it's path to LDFLAGS.
+bootstrap_libssp_nonshared() {
+       bootstrap_lib "gnu/lib/libssp/libssp_nonshared"
+}
+
+bootstrap_libgcc() {
+       bootstrap_lib "lib/libcompiler_rt"
+       cd "${MAKEOBJDIRPREFIX}/${WORKDIR}/lib/libcompiler_rt" || die
+       ln -s libcompiler_rt.a libgcc.a || die
+
+       bootstrap_lib "lib/libc" "gnu/lib/libgcc"
+}
+
+bootstrap_libthr() {
+       bootstrap_lib "lib/libthr"
+       cd "${MAKEOBJDIRPREFIX}/${WORKDIR}/lib/libthr" || die
+       ln -s libthr.so libpthread.so
+}
+
+# What to build for a cross-compiler.
+# We also need the csu but this has to be handled separately.
+CROSS_SUBDIRS="lib/libc lib/msun gnu/lib/libssp/libssp_nonshared lib/libthr 
lib/libutil lib/librt lib/libc_nonshared"
+
+# What to build for non-default ABIs.
+NON_NATIVE_SUBDIRS="${CROSS_SUBDIRS} gnu/lib/csu lib/libcompiler_rt 
gnu/lib/libgcc lib/libmd lib/libcrypt lib/libsbuf lib/libcam lib/libelf 
lib/libiconv_modules"
+
+# Subdirs for a native build:
+NATIVE_SUBDIRS="lib gnu/lib/libssp/libssp_nonshared gnu/lib/libregex 
gnu/lib/csu gnu/lib/libgcc lib/libiconv_modules"
+
+# Is my $ABI native ?
+is_native_abi() {
+       is_crosscompile && return 1
+       multilib_is_native_abi
+}
+
+# Do we need to bootstrap the csu and libssp_nonshared?
+need_bootstrap() {
+       is_crosscompile || use build || { ! is_native_abi && ! has_version 
'>=sys-freebsd/freebsd-lib-9.1-r8[multilib]' && ! has_version 
">=sys-freebsd/freebsd-lib-9.1-r11[${MULTILIB_USEDEP}]" ; } || has_version 
"<${CATEGORY}/${P}"
+}
+
+# Get the subdirs we are building.
+get_subdirs() {
+       local ret=""
+       if is_native_abi ; then
+               # If we are building for the native ABI, build everything
+               ret="${NATIVE_SUBDIRS}"
+       elif is_crosscompile ; then
+               # With a cross-compiler we only build the very core parts.
+               ret="${CROSS_SUBDIRS}"
+               if [ "${EBUILD_PHASE}" = "install" ]; then
+                       # Add the csu dir first when installing. We treat it 
separately for
+                       # compiling.
+                       ret="$(get_csudir $(tc-arch-kernel ${CTARGET})) ${ret}"
+               fi
+       else
+               # For the non-native ABIs we only build the csu parts and very 
core
+               # libraries for now.
+               ret="${NON_NATIVE_SUBDIRS} $(get_csudir $(tc-arch-kernel 
${CHOST}))"
+       fi
+       echo "${ret}"
+}
+
+# Bootstrap the core libraries and setup the flags so that the other parts can
+# build against it.
+do_bootstrap() {
+       einfo "Bootstrapping on ${CHOST} for ${CTARGET}"
+       if ! is_crosscompile ; then
+               # Pre-install headers, but not when building a cross-compiler 
since we
+               # assume they have been installed in the previous pass.
+               einfo "Pre-installing includes in include_proper_${ABI}"
+               mkdir "${WORKDIR}/include_proper_${ABI}" || die
+               CTARGET="${CHOST}" install_includes "/include_proper_${ABI}"
+               CFLAGS="${CFLAGS} -isystem ${WORKDIR}/include_proper_${ABI}"
+               [[ $(tc-getCXX) = *clang++* ]] && CXXFLAGS="${CXXFLAGS} 
-isystem /usr/include/c++/v1"
+               CXXFLAGS="${CXXFLAGS} -isystem ${WORKDIR}/include_proper_${ABI}"
+               mymakeopts="${mymakeopts} 
RPCDIR=${WORKDIR}/include_proper_${ABI}/rpcsvc"
+       fi
+       bootstrap_csu
+       bootstrap_libssp_nonshared
+       is_crosscompile && bootstrap_lib "lib/libc"
+       is_crosscompile || is_native_abi || bootstrap_libgcc
+       is_native_abi   || bootstrap_libthr
+}
+
+# Compile it. Assume we have the toolchain setup correctly.
+do_compile() {
+       # Bootstrap if needed, otherwise assume the system headers are in
+       # /usr/include.
+       if need_bootstrap ; then
+               do_bootstrap
+       else
+               CFLAGS="${CFLAGS} -isystem /usr/include"
+               [[ $(tc-getCXX) = *clang++* ]] && CXXFLAGS="${CXXFLAGS} 
-isystem /usr/include/c++/v1"
+               CXXFLAGS="${CXXFLAGS} -isystem /usr/include"
+       fi
+
+       export RAW_LDFLAGS=$(raw-ldflags)
+
+       # Everything is now setup, build it!
+       for i in $(get_subdirs) ; do
+               einfo "Building in ${i}... with CC=${CC} and CFLAGS=${CFLAGS}"
+               cd "${WORKDIR}/${i}/" || die "missing ${i}."
+               freebsd_src_compile || die "make ${i} failed"
+       done
+}
+
+src_compile() {
+       # Does not work with GNU sed
+       # Force BSD's sed on BSD.
+       if [[ ${CBUILD:-${CHOST}} == *bsd* ]]; then
+               export ESED=/usr/bin/sed
+               unalias sed
+       fi
+
+       use usb && export NON_NATIVE_SUBDIRS="${NON_NATIVE_SUBDIRS} lib/libusb 
lib/libusbhid"
+
+       cd "${WORKDIR}/include"
+       $(freebsd_get_bmake) CC="$(tc-getCC)" SRCTOP="${WORKDIR}" || die "make 
include failed"
+
+       use crosscompile_opts_headers-only && return 0
+
+       # Bug #270098
+       append-flags $(test-flags -fno-strict-aliasing)
+
+       # Bug #324445
+       append-flags $(test-flags -fno-strict-overflow)
+
+       # strip flags and do not do it later, we only add safe, and in fact
+       # needed flags after all
+       strip-flags
+       export NOFLAGSTRIP=yes
+       if is_crosscompile ; then
+               export YACC='yacc -by'
+               CHOST=${CTARGET} tc-export CC LD CXX RANLIB
+               mymakeopts="${mymakeopts} NLS="
+               CFLAGS="${CFLAGS} -isystem /usr/${CTARGET}/usr/include"
+               CXXFLAGS="${CXXFLAGS} -isystem /usr/${CTARGET}/usr/include"
+               append-ldflags "-L${WORKDIR}/${CHOST}/${WORKDIR}/lib/libc"
+       fi
+
+       if is_crosscompile ; then
+               do_compile
+       else
+               local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+               multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
do_compile
+       fi
+}
+
+gen_libc_ldscript() {
+       # Parameters:
+       #   $1 = target libdir
+       #   $2 = source libc dir
+       #   $3 = source libssp_nonshared dir
+
+       # Clear the symlink.
+       rm -f "${DESTDIR}/$2/libc.so" || die
+
+       # Move the library if needed
+       if [ "$1" != "$2" ] ; then
+               mv "${DESTDIR}/$2/libc.so.7" "${DESTDIR}/$1/" || die
+       fi
+
+       # Generate libc.so ldscript for inclusion of libssp_nonshared.a when 
linking
+       # this is done to avoid having to touch gcc spec file as it is currently
+       # done on FreeBSD upstream, mostly because their binutils aren't able to
+       # cope with linker scripts yet.
+       # Taken from toolchain-funcs.eclass:
+       local output_format
+       output_format=$($(tc-getCC) ${CFLAGS} ${LDFLAGS} -Wl,--verbose 2>&1 | 
sed -n 's/^OUTPUT_FORMAT("\([^"]*\)",.*/\1/p')
+       [[ -n ${output_format} ]] && output_format="OUTPUT_FORMAT ( 
${output_format} )"
+
+       # iconv symbol provided by libc_nonshared.a.
+       # http://svnweb.freebsd.org/base?view=revision&amp;revision=258283
+       cat > "${DESTDIR}/$2/libc.so" <<-END_LDSCRIPT
+/* GNU ld script
+   SSP (-fstack-protector) requires __stack_chk_fail_local to be local.
+   GCC invokes this symbol in a non-PIC way, which results in TEXTRELs if
+   this symbol was provided by a shared libc. So we link in
+   libssp_nonshared.a from here.
+ */
+${output_format}
+GROUP ( /$1/libc.so.7 /$3/libc_nonshared.a /$3/libssp_nonshared.a )
+END_LDSCRIPT
+}
+
+header_list=""
+
+move_header() {
+       local dirname=$(dirname ${1})
+       local filename=$(basename ${1})
+
+       if [ ! -d "${dirname}/${ABI}" ] ; then
+               mkdir "${dirname}/${ABI}" || die
+       fi
+
+       mv "${1}" "${dirname}/${ABI}/" || die
+
+       export header_list="${header_list} ${1}"
+}
+
+make_header_template() {
+       cat <<-END_HEADER
+/*
+ * Wrapped header for multilib support.
+ * See the real headers included below.
+ */
+
+#if defined(__x86_64__)
+  @ABI_amd64_fbsd@
+#elif defined(__i386__)
+  @ABI_x86_fbsd@
+#else
+  @ABI_${DEFAULT_ABI}@
+#endif
+END_HEADER
+}
+
+wrap_header() {
+       local dirname=$(dirname ${1})
+       local filename=$(basename ${1})
+
+       if [ -n "${dirname#.}" ] ; then
+               dirname="${dirname}/${2}"
+       else
+               dirname="${2}"
+       fi
+
+       if [ -f "${dirname}/${filename}" ] ; then
+               sed -e "s:@ABI_${2}@:#include <${dirname}/${filename}>:" ${1}
+       else
+               cat ${1}
+       fi
+}
+
+wrap_header_end() {
+       sed -e "s:@ABI_.*@:#error \"Sorry, no support for your ABI.\":" ${1}
+}
+
+do_install() {
+       if is_crosscompile ; then
+               INCLUDEDIR="/usr/${CTARGET}/usr/include"
+       else
+               INCLUDEDIR="/usr/include"
+       fi
+
+       dodir ${INCLUDEDIR}
+       CTARGET="${CHOST}" \
+               install_includes ${INCLUDEDIR}
+
+       is_crosscompile && use crosscompile_opts_headers-only && return 0
+
+       # Install a libusb.pc for better compat with Linux's libusb
+       if use usb ; then
+               dodir /usr/$(get_libdir)/pkgconfig
+               sed -i.bkp "s:^libdir=.*:libdir=/usr/$(get_libdir):g" 
"${S}"/libusb/libusb-*.pc
+       fi
+
+       for i in $(get_subdirs) ; do
+               if [[ ${i} != *libiconv_modules* ]] ; then
+                       einfo "Installing in ${i}..."
+                       cd "${WORKDIR}/${i}/" || die "missing ${i}."
+                       freebsd_src_install || die "Install ${i} failed"
+               fi
+       done
+
+       if ! is_crosscompile; then
+               local mymakeopts_save="${mymakeopts}"
+               mymakeopts="${mymakeopts} SHLIBDIR=/usr/$(get_libdir)/i18n 
LIBDIR=/usr/$(get_libdir)/i18n"
+
+               einfo "Installing in lib/libiconv_modules..."
+               cd "${WORKDIR}/lib/libiconv_modules/" || die "missing 
libiconv_modules."
+               freebsd_src_install || die "Install lib/libiconv_modules failed"
+
+               mymakeopts="${mymakeopts_save}"
+       fi
+
+       if ! is_crosscompile ; then
+               if ! multilib_is_native_abi ; then
+                       DESTDIR="${D}" gen_libc_ldscript "usr/$(get_libdir)" 
"usr/$(get_libdir)" "usr/$(get_libdir)"
+               else
+                       dodir "$(get_libdir)"
+                       DESTDIR="${D}" gen_libc_ldscript "$(get_libdir)" 
"usr/$(get_libdir)" "usr/$(get_libdir)"
+               fi
+       else
+               CHOST=${CTARGET} DESTDIR="${D}/usr/${CTARGET}/" 
gen_libc_ldscript "usr/lib" "usr/lib" "usr/lib"
+               # We're done for the cross libc here.
+               return 0
+       fi
+
+       # Generate ldscripts for core libraries that will go in /
+       multilib_is_native_abi && \
+               gen_usr_ldscript -a alias cam geom ipsec jail kiconv \
+                       kvm m md procstat sbuf thr ufs util elf
+
+       if [[ ${#MULTIBUILD_VARIANTS[@]} -gt 1 ]] ; then
+               cd "${D}/usr/include"
+               for i in machine/*.h fenv.h ; do
+                       move_header ${i}
+               done
+               if multilib_is_native_abi ; then
+                       # Supposedly the last one!
+                       local uniq_headers="$(echo ${header_list} | tr ' ' '\n' 
| sort | uniq | tr '\n' ' ')"
+                       for j in ${uniq_headers} ; do
+                               make_header_template > ${j}
+                               for i in $(get_all_abis) ; do
+                                       wrap_header ${j} ${i} > ${j}.new
+                                       cp ${j}.new ${j}
+                                       rm -f ${j}.new
+                               done
+                               wrap_header_end ${j} > ${j}.new
+                               cp ${j}.new ${j}
+                               rm -f ${j}.new
+                       done
+               fi
+       fi
+}
+
+src_install() {
+       if is_crosscompile ; then
+               einfo "Installing for ${CTARGET} in ${CHOST}.."
+               # From this point we need to force: get stripped with the 
correct tools,
+               # get tc-arch-kernel to return the right value, etc.
+               export CHOST=${CTARGET}
+
+               mymakeopts="${mymakeopts} WITHOUT_MAN= \
+                       INCLUDEDIR=/usr/${CTARGET}/usr/include \
+                       SHLIBDIR=/usr/${CTARGET}/usr/lib \
+                       LIBDIR=/usr/${CTARGET}/usr/lib"
+
+               dosym "usr/include" "/usr/${CTARGET}/sys-include"
+               do_install
+
+               return 0
+       else
+               export STRIP_MASK="*/usr/lib*/*crt*.o"
+               local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+               multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
do_install
+       fi
+
+       cd "${WORKDIR}/etc/"
+       insinto /etc
+       doins nls.alias mac.conf netconfig
+
+       # Install ttys file
+       local MACHINE="$(tc-arch-kernel)"
+       doins "etc.${MACHINE}"/*
+}
+
+install_includes()
+{
+       local INCLUDEDIR="$1"
+
+       # The idea is to be called from either install or unpack.
+       # During unpack it's required to install them as portage's user.
+       if [[ "${EBUILD_PHASE}" == "install" ]]; then
+               local DESTDIR="${D}"
+               BINOWN="root"
+               BINGRP="wheel"
+       else
+               local DESTDIR="${WORKDIR}"
+               [[ -z "${USER}" ]] && USER="portage"
+               BINOWN="${USER}"
+               [[ -z "${GROUPS}" ]] && GROUPS="portage"
+               BINGRP="${GROUPS}"
+       fi
+
+       # Must exist before we use it.
+       [[ -d "${DESTDIR}${INCLUDEDIR}" ]] || die "dodir or mkdir ${INCLUDEDIR} 
before using install_includes."
+       cd "${WORKDIR}/include"
+
+       local MACHINE="$(tc-arch-kernel)"
+
+       einfo "Installing includes into ${INCLUDEDIR} as ${BINOWN}:${BINGRP}..."
+       $(freebsd_get_bmake) installincludes \
+               MACHINE=${MACHINE} MACHINE_ARCH=${MACHINE} \
+               DESTDIR="${DESTDIR}" \
+               INCLUDEDIR="${INCLUDEDIR}" BINOWN="${BINOWN}" \
+               BINGRP="${BINGRP}" \
+               WITHOUT_GSSAPI= \
+               SRCTOP="${WORKDIR}"|| die "install_includes() failed"
+       einfo "includes installed ok."
+       EXTRA_INCLUDES="lib/librtld_db lib/libutil lib/msun gnu/lib/libregex 
lib/libcasper lib/libmp"
+       for i in $EXTRA_INCLUDES; do
+               einfo "Installing $i includes into ${INCLUDEDIR} as 
${BINOWN}:${BINGRP}..."
+               cd "${WORKDIR}/$i" || die
+               $(freebsd_get_bmake) installincludes DESTDIR="${DESTDIR}" \
+                       MACHINE=${MACHINE} MACHINE_ARCH=${MACHINE} \
+                       INCLUDEDIR="${INCLUDEDIR}" BINOWN="${BINOWN}" \
+                       BINGRP="${BINGRP}" \
+                       SRCTOP="${WORKDIR}" || die "problem installing $i 
includes."
+               einfo "$i includes installed ok."
+       done
+}

diff --git a/sys-freebsd/freebsd-libexec/Manifest 
b/sys-freebsd/freebsd-libexec/Manifest
index 6291728..18e2999 100644
--- a/sys-freebsd/freebsd-libexec/Manifest
+++ b/sys-freebsd/freebsd-libexec/Manifest
@@ -9,6 +9,7 @@ DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f
 DIST freebsd-libexec-8.2.tar.bz2 289147 SHA256 
10b996d1d8cd044ee2e7a877e5e6ad2bf050cce9b3bd402a5e0dea7d290b595d SHA512 
abe6cf5a268675d7dcb1c214c46fef47a3fb09b31947f5d8a0b938d352295efe0249beb5007649c52187bf4c221b6ebf074d18dfe9bafd168cae09ee02ab608d
 WHIRLPOOL 
27e854fe465eb933dd8e27c5a09b063e4d3798b54e0914c79a9120dcdc34cc5d525a0c92da7b645ff7ab2ab4f34c7f7b2783012dfa5004407acd11150062b7ad
 DIST freebsd-libexec-9.1.tar.bz2 304592 SHA256 
71e6e9e41328c2148c54b81ad9b59f912a1d5f0d52e17ac07f223aa7a94b82be SHA512 
7baa4160dda2610250dd52f445e24478e0f1ea10bce21fcd0e5d1b856f399b896adc334114de0c7f61a5637e4349bb1688fdbe5c72798d8568ae791114710b92
 WHIRLPOOL 
d800f477ac5c9ad6dae3e0091c83e107609b5a1e3aa79e9533fcd10a8dd34ff7733ab9523eae7c292310fe94f6a529209cae6b9e8bac6b47244e59834593e74b
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c
 DIST freebsd-ubin-9.1.tar.bz2 1910472 SHA256 
ff6e586f213534b6ec2e65002c0dee64063d76ddad515c12221b1a80a1815e48 SHA512 
74ae0aceec8597aa66c3f1ab313f0685a3c63d7273c36ae7baf8794275ad9bca241c60c3f6281cccf6d531d250d7611099977d3b1a27279cef3586401b6af05e
 WHIRLPOOL 
c85a3c9cf2bceff2c60ff03556bcc81d3aca22b0bce3c9538990071ac0a907236eee5ae7743ad22c5fd309b047ebf392aaaf2fe177ef5790ea869aff3da7e2fe
 DIST freebsd-usbin-8.2.tar.bz2 2443024 SHA256 
aa7cabf10f5c3a9daabea32e4de24d04ec312247842981476da666eff5054603 SHA512 
bcb8ff3df54848b9107bbb52e5ced7a91e24bb181f06769b6997221729b8064ec17652eaf7500de3268cbcb63ff5760beb54d15fc78c27b02687b5b1067c74a6
 WHIRLPOOL 
20f5278e2a1dd387a75b44f10507958d6c0e84a2faa1bddbf808c14ab86d8dd14a956192911bbc1880f5f5f7bd05972dcbb4aec85d241f0dcf91bf4246883f0a

diff --git a/sys-freebsd/freebsd-libexec/freebsd-libexec-11.0.ebuild 
b/sys-freebsd/freebsd-libexec/freebsd-libexec-11.0.ebuild
new file mode 100644
index 00000000..8aea14d
--- /dev/null
+++ b/sys-freebsd/freebsd-libexec/freebsd-libexec-11.0.ebuild
@@ -0,0 +1,131 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd pam multilib multibuild multilib-build toolchain-funcs
+
+DESCRIPTION="FreeBSD libexec things"
+SLOT="0"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       libexec/
+       usr.bin/
+       bin/
+       contrib/blacklist/
+       contrib/dma/
+       contrib/hyperv/
+       contrib/telnet/
+       lib/
+       etc/
+       usr.sbin/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*
+       >=sys-freebsd/freebsd-lib-9.1-r11[${MULTILIB_USEDEP}]
+       pam? ( virtual/pam )"
+DEPEND="${RDEPEND}
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       =sys-freebsd/freebsd-sources-${RV}*"
+RDEPEND="${RDEPEND}
+       xinetd? ( sys-apps/xinetd )"
+
+S="${WORKDIR}/libexec"
+
+# Remove sendmail, tcp_wrapper and other useless stuff
+REMOVE_SUBDIRS="smrsh mail.local tcpd telnetd rshd rlogind ftpd"
+
+IUSE="pam ssl kerberos ipv6 nis xinetd"
+
+PATCHES=( "${FILESDIR}/${PN}-10.2-atf-check.patch" )
+
+pkg_setup() {
+       use ipv6 || mymakeopts="${mymakeopts} WITHOUT_INET6= 
WITHOUT_INET6_SUPPORT= "
+       use kerberos || mymakeopts="${mymakeopts} WITHOUT_KERBEROS_SUPPORT= "
+       use nis || mymakeopts="${mymakeopts} WITHOUT_NIS= "
+       use pam || mymakeopts="${mymakeopts} WITHOUT_PAM_SUPPORT= "
+       use ssl || mymakeopts="${mymakeopts} WITHOUT_OPENSSL= "
+
+       mymakeopts="${mymakeopts} WITHOUT_SENDMAIL= WITHOUT_PF= WITHOUT_RCMDS= "
+
+       if has_version "<sys-freebsd/freebsd-libexec-11.0"; then
+               REMOVE_SUBDIRS="${REMOVE_SUBDIRS} rpc.rstatd ulog-helper"
+       fi
+
+       if has_version "<sys-freebsd/freebsd-ubin-11.0"; then
+               mymakeopts="${mymakeopts} WITHOUT_MAN_UTILS= "
+       fi
+
+       if has_version "<sys-freebsd/freebsd-share-${RV}"; then
+               die ">=sys-freebsd/freebsd-share-${RV} is required."
+       fi
+}
+
+src_prepare() {
+       # gcc-5.0 or later, Workaround for critical issue. bug 573358.
+       [[ "$(gcc-major-version)" -ge 5 ]] && replace-flags -O? -O1
+
+       if [[ ! -e "${WORKDIR}/include" ]]; then
+               ln -s /usr/include "${WORKDIR}/include" || die "Symlinking 
/usr/include.."
+       fi
+       # allow upgrade directly from 9.x to 10.2.
+       if has_version "<sys-freebsd/freebsd-lib-${RV}"; then
+               # taken from sys/sys/elf_common.h
+               echo "#define DF_1_INTERPOSE 0x00000400" >> 
"${S}"/rtld-elf/rtld.h
+               echo "#define STT_GNU_IFUNC 10" >> "${S}"/rtld-elf/rtld.h
+               echo "#define R_386_IRELATIVE 42" >> "${S}"/rtld-elf/rtld.h
+               echo "#define PT_GNU_RELRO 0x6474e552" >> "${S}"/rtld-elf/rtld.h
+               echo "#define DF_1_NODEFLIB 0x00000800" >> 
"${S}"/rtld-elf/rtld.h
+               echo "#define NT_FREEBSD_ABI_TAG 1" >> "${S}"/rtld-elf/rtld.h
+               echo "#define NT_FREEBSD_NOINIT_TAG 2" >> "${S}"/rtld-elf/rtld.h
+               # taken from sys/sys/fcntl.h
+               echo "#define F_DUPFD_CLOEXEC 17" >> "${S}"/rtld-elf/rtld.h
+               echo "#define O_VERIFY 0x00200000" >> "${S}"/rtld-elf/rtld.h
+               # taken from sys/sys/cdefs.h
+               echo '#define __compiler_membar()  __asm __volatile(" " : : : 
"memory")' >> "${S}"/rtld-elf/rtld.h
+               # taken from sys/sys/mman.h
+               echo '#define MAP_ALIGNED(n) ((n) << MAP_ALIGNMENT_SHIFT)' >> 
"${S}"/rtld-elf/rtld.h
+               echo '#define MAP_ALIGNMENT_SHIFT 24' >> "${S}"/rtld-elf/rtld.h
+               echo '#define MAP_ALIGNMENT_MASK MAP_ALIGNED(0xff)' >> 
"${S}"/rtld-elf/rtld.h
+               echo '#define MAP_ALIGNED_SUPER MAP_ALIGNED(1)' >> 
"${S}"/rtld-elf/rtld.h
+
+               export mymakeopts="${mymakeopts} WITHOUT_SYMVER= 
WITHOUT_BLACKLIST_SUPPORT= "
+       fi
+}
+
+setup_multilib_vars() {
+       if ! multilib_is_native_abi ; then
+               cd "${WORKDIR}/libexec/rtld-elf" || die
+               export mymakeopts="${mymakeopts} PROG=ld-elf32.so.1"
+       else
+               cd "${S}" || die
+       fi
+       "$@"
+}
+
+src_compile() {
+       local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+       multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
setup_multilib_vars freebsd_src_compile
+}
+
+src_install() {
+       local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+       multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
setup_multilib_vars freebsd_src_install
+
+       insinto /etc
+       doins "${WORKDIR}/etc/gettytab"
+       newinitd "${FILESDIR}/bootpd.initd" bootpd
+       newconfd "${FILESDIR}/bootpd.confd" bootpd
+
+       if use xinetd; then
+               for rpcd in rstatd rusersd walld rquotad sprayd; do
+                       insinto /etc/xinetd.d
+                       newins "${FILESDIR}/${rpcd}.xinetd" ${rpcd}
+               done
+       fi
+}

diff --git a/sys-freebsd/freebsd-mk-defs/Manifest 
b/sys-freebsd/freebsd-mk-defs/Manifest
index 58c6aa0..99925b6 100644
--- a/sys-freebsd/freebsd-mk-defs/Manifest
+++ b/sys-freebsd/freebsd-mk-defs/Manifest
@@ -1,3 +1,4 @@
 DIST freebsd-share-8.2.tar.bz2 3797560 SHA256 
dd082c6ddbf8e08ec91d9810d51af4111339bed912b0f74d05be283780292ba0 SHA512 
b3f964253f80e58cde12f26e48a23aa75c17b9ab2810f91a4bd2d7efbe902af7c73c219f8373a4fc97ee0a35d25627b8815c79c136ef18620acc8bd0ee5bd6c4
 WHIRLPOOL 
42326ad6139feadf80509f5e810f6a86009ad3a69aad9550c6355389773c28d5b2f7930eaa852f8442808485d13e5b758ed3420e39048bb3966785e6953119ea
 DIST freebsd-share-9.1.tar.bz2 6733003 SHA256 
2bbd8aa05d52b18a1780772a8518d79d375c1eeae98f52fb6aded233ac2491d7 SHA512 
9665e3d5253f49a55921012bd21a8688210a1993ba6be4ad17b5ba5619104a50f3199d49a0eb83cf29db5a06c407beb15616bfe71338c680fe34ec47564c4b43
 WHIRLPOOL 
7d15596888ac42af1a0c125591283524ff794dccbf9f6592963602f046a45ca073b10bda43c2d0d662fd3414753de64c05293788e03c4eea67de55d9bc083c11
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827

diff --git 
a/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-drop-unsupport-cflags.patch
 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-drop-unsupport-cflags.patch
new file mode 100644
index 00000000..d12bbbe
--- /dev/null
+++ 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-drop-unsupport-cflags.patch
@@ -0,0 +1,13 @@
+diff --git a/share/mk/bsd.sys.mk b/share/mk/bsd.sys.mk
+index 37c4d01..e840a25 100644
+--- a/share/mk/bsd.sys.mk
++++ b/share/mk/bsd.sys.mk
+@@ -112,7 +112,7 @@ CWARNFLAGS+=       -Wno-error=unused-function 
-Wno-error=enum-compare -Wno-error=logic
+ .if ${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} >= 30600
+ FORMAT_EXTENSIONS=    -D__printf__=__freebsd_kprintf__
+ .else
+-FORMAT_EXTENSIONS=    -fformat-extensions
++FORMAT_EXTENSIONS=
+ .endif
+ 
+ .if defined(IGNORE_PRAGMA)

diff --git 
a/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gentoo.patch 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gentoo.patch
new file mode 100644
index 00000000..e87bdba
--- /dev/null
+++ b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gentoo.patch
@@ -0,0 +1,343 @@
+diff --git a/share/mk/bsd.doc.mk b/share/mk/bsd.doc.mk
+index 9f4ea2c..0f666bf 100644
+--- a/share/mk/bsd.doc.mk
++++ b/share/mk/bsd.doc.mk
+@@ -144,10 +144,12 @@ CLEANFILES+=     ${DOC}.ascii 
${DOC}.ascii${DCOMPRESS_EXT} \
+ realinstall:
+ .if ${PRINTERDEVICE:Mhtml}
+       cd ${SRCDIR}; \
++      ${INSTALL} -d ${DESTDIR}${BINDIR}/${VOLUME}; \
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},docs} -o ${BINOWN} -g ${BINGRP} -m 
${BINMODE} \
+           ${DOC}*.html ${DESTDIR}${BINDIR}/${VOLUME}/
+ .endif
+ .for _dev in ${PRINTERDEVICE:Nhtml}
++      ${INSTALL} -d ${DESTDIR}${BINDIR}/${VOLUME}; \
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},docs} -o ${BINOWN} -g ${BINGRP} -m 
${BINMODE} \
+           ${DFILE.${_dev}} ${DESTDIR}${BINDIR}/${VOLUME}/
+ .endfor
+diff --git a/share/mk/bsd.files.mk b/share/mk/bsd.files.mk
+index bc123e1..4707b84 100644
+--- a/share/mk/bsd.files.mk
++++ b/share/mk/bsd.files.mk
+@@ -63,6 +63,7 @@ stage_as.${file:T}: ${file}
+ 
+ installfiles-${group}: _${group}INS_${file:T}
+ _${group}INS_${file:T}: ${file}
++      ${INSTALL} -d ${DESTDIR}${${group}DIR_${.ALLSRC:T}}
+       ${INSTALL} ${${group}TAG_ARGS} -o ${${group}OWN_${.ALLSRC:T}} \
+           -g ${${group}GRP_${.ALLSRC:T}} -m ${${group}MODE_${.ALLSRC:T}} \
+           ${.ALLSRC} \
+@@ -77,10 +78,12 @@ stage_files.${group}: ${_${group}FILES}
+ installfiles-${group}: _${group}INS
+ _${group}INS: ${_${group}FILES}
+ .if defined(${group}NAME)
++      ${INSTALL} -d ${DESTDIR}${${group}DIR}/${${group}NAME}
+       ${INSTALL} ${${group}TAG_ARGS} -o ${${group}OWN} -g ${${group}GRP} \
+           -m ${${group}MODE} ${.ALLSRC} \
+           ${DESTDIR}${${group}DIR}/${${group}NAME}
+ .else
++      ${INSTALL} -d ${DESTDIR}${${group}DIR}
+       ${INSTALL} ${${group}TAG_ARGS} -o ${${group}OWN} -g ${${group}GRP} \
+           -m ${${group}MODE} ${.ALLSRC} ${DESTDIR}${${group}DIR}/
+ .endif
+diff --git a/share/mk/bsd.incs.mk b/share/mk/bsd.incs.mk
+index 9636e8c..fc2751a 100644
+--- a/share/mk/bsd.incs.mk
++++ b/share/mk/bsd.incs.mk
+@@ -62,6 +62,9 @@ stage_includes: stage_as.${header:T}
+ 
+ installincludes: _${group}INS_${header:T}
+ _${group}INS_${header:T}: ${header}
++      ${INSTALL} -d -o ${${group}OWN_${.ALLSRC:T}} \
++              -g ${${group}GRP_${.ALLSRC:T}} \
++              ${DESTDIR}${${group}DIR_${.ALLSRC:T}}
+       ${INSTALL} -C -o ${${group}OWN_${.ALLSRC:T}} \
+           -g ${${group}GRP_${.ALLSRC:T}} -m ${${group}MODE_${.ALLSRC:T}} \
+           ${.ALLSRC} \
+@@ -77,9 +80,13 @@ stage_includes: stage_files.${group}
+ installincludes: _${group}INS
+ _${group}INS: ${_${group}INCS}
+ .if defined(${group}NAME)
++      ${INSTALL} -d -o ${${group}OWN} -g ${${group}GRP} \
++              ${DESTDIR}${${group}DIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},development} -C -o ${${group}OWN} -g 
${${group}GRP} -m ${${group}MODE} \
+           ${.ALLSRC} ${DESTDIR}${${group}DIR}/${${group}NAME}
+ .else
++      ${INSTALL} -d -o ${${group}OWN} -g ${${group}GRP} \
++              ${DESTDIR}${${group}DIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},development} -C -o ${${group}OWN} -g 
${${group}GRP} -m ${${group}MODE} \
+           ${.ALLSRC} ${DESTDIR}${${group}DIR}/
+ .endif
+diff --git a/share/mk/bsd.info.mk b/share/mk/bsd.info.mk
+index 0544662..1a7aad7 100644
+--- a/share/mk/bsd.info.mk
++++ b/share/mk/bsd.info.mk
+@@ -83,6 +83,7 @@ INFO2HTML?=  info2html
+ TEX?=         tex
+ DVIPS?=               dvips
+ DVIPS2ASCII?= dvips2ascii
++INSTALL?=     install
+ 
+ .SUFFIXES: ${ICOMPRESS_EXT} .info .texi .texinfo .dvi .ps .latin1 .html
+ 
+@@ -141,15 +142,17 @@ ${x:S/$/${ICOMPRESS_EXT}/}:      ${x}
+ INSTALLINFODIRS+= ${x:S/$/-install/}
+ ${x:S/$/-install/}:
+ .if !empty(.MAKEFLAGS:M-j)
++      ${INSTALL} -d ${DESTDIR}${INFODIR}
+       lockf -k ${DESTDIR}${INFODIR}/${INFODIRFILE} \
+       ${INSTALLINFO} ${INSTALLINFOFLAGS} \
+-          --defsection=${INFOSECTION} \
+-          --defentry=${INFOENTRY_${x}} \
++          --section=${INFOSECTION} \
++          --entry=${INFOENTRY_${x}} \
+           ${x}.info ${DESTDIR}${INFODIR}/${INFODIRFILE}
+ .else
++      ${INSTALL} -d ${DESTDIR}${INFODIR}
+       ${INSTALLINFO} ${INSTALLINFOFLAGS} \
+-          --defsection=${INFOSECTION} \
+-          --defentry=${INFOENTRY_${x}} \
++          --section=${INFOSECTION} \
++          --entry=${INFOENTRY_${x}} \
+           ${x}.info ${DESTDIR}${INFODIR}/${INFODIRFILE}
+ .endif
+ .endfor
+diff --git a/share/mk/bsd.lib.mk b/share/mk/bsd.lib.mk
+index bd93e57..92df111 100644
+--- a/share/mk/bsd.lib.mk
++++ b/share/mk/bsd.lib.mk
+@@ -52,8 +52,6 @@ CFLAGS+= ${DEBUG_FLAGS}
+ .if ${MK_CTF} != "no" && ${DEBUG_FLAGS:M-g} != ""
+ CTFFLAGS+= -g
+ .endif
+-.else
+-STRIP?=       -s
+ .endif
+ 
+ .if ${SHLIBDIR:M*lib32*}
+@@ -335,14 +333,17 @@ realinstall: _libinstall
+ .ORDER: beforeinstall _libinstall
+ _libinstall:
+ .if defined(LIB) && !empty(LIB) && ${MK_INSTALLLIB} != "no"
++      ${INSTALL} -d ${DESTDIR}${_LIBDIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},development} -C -o ${LIBOWN} -g 
${LIBGRP} -m ${LIBMODE} \
+           ${_INSTALLFLAGS} lib${LIB_PRIVATE}${LIB}.a ${DESTDIR}${_LIBDIR}/
+ .endif
+ .if ${MK_PROFILE} != "no" && defined(LIB) && !empty(LIB)
++      ${INSTALL} -d ${DESTDIR}${_LIBDIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},profile} -C -o ${LIBOWN} -g 
${LIBGRP} -m ${LIBMODE} \
+           ${_INSTALLFLAGS} lib${LIB_PRIVATE}${LIB}_p.a ${DESTDIR}${_LIBDIR}/
+ .endif
+ .if defined(SHLIB_NAME)
++      ${INSTALL} -d ${DESTDIR}${_SHLIBDIR}
+       ${INSTALL} ${TAG_ARGS} ${STRIP} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} 
\
+           ${_INSTALLFLAGS} ${_SHLINSTALLFLAGS} \
+           ${SHLIB_NAME} ${DESTDIR}${_SHLIBDIR}/
+@@ -387,10 +388,12 @@ _libinstall:
+ .endif # SHLIB_LINK
+ .endif # SHIB_NAME
+ .if defined(INSTALL_PIC_ARCHIVE) && defined(LIB) && !empty(LIB) && 
${MK_TOOLCHAIN} != "no"
++      ${INSTALL} -d ${DESTDIR}${_LIBDIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},development} -o ${LIBOWN} -g 
${LIBGRP} -m ${LIBMODE} \
+           ${_INSTALLFLAGS} lib${LIB}_pic.a ${DESTDIR}${_LIBDIR}/
+ .endif
+ .if defined(WANT_LINT) && !defined(NO_LINT) && defined(LIB) && !empty(LIB)
++      ${INSTALL} -d ${DESTDIR}${LINTLIBDIR}
+       ${INSTALL} ${TAG_ARGS:D${TAG_ARGS},development} -o ${LIBOWN} -g 
${LIBGRP} -m ${LIBMODE} \
+           ${_INSTALLFLAGS} ${LINTLIB} ${DESTDIR}${LINTLIBDIR}/
+ .endif
+diff --git a/share/mk/bsd.libnames.mk b/share/mk/bsd.libnames.mk
+index 0844ae2..caec715 100644
+--- a/share/mk/bsd.libnames.mk
++++ b/share/mk/bsd.libnames.mk
+@@ -63,7 +63,7 @@ LIBELF?=     ${DESTDIR}${LIBDIR}/libelf.a
+ LIBEXECINFO?= ${DESTDIR}${LIBDIR}/libexecinfo.a
+ LIBFETCH?=    ${DESTDIR}${LIBDIR}/libfetch.a
+ LIBFIGPAR?=   ${DESTDIR}${LIBDIR}/libfigpar.a
+-LIBFL?=               "don't use LIBFL, use LIBL"
++LIBFL?=               ${DESTDIR}${LIBDIR}/libfl.a
+ LIBFORM?=     ${DESTDIR}${LIBDIR}/libform.a
+ LIBG2C?=      ${DESTDIR}${LIBDIR}/libg2c.a
+ LIBGEOM?=     ${DESTDIR}${LIBDIR}/libgeom.a
+@@ -92,7 +92,7 @@ LIBKEYCAP?=  ${DESTDIR}${LIBDIR}/libkeycap.a
+ LIBKICONV?=   ${DESTDIR}${LIBDIR}/libkiconv.a
+ LIBKRB5?=     ${DESTDIR}${LIBDIR}/libkrb5.a
+ LIBKVM?=      ${DESTDIR}${LIBDIR}/libkvm.a
+-LIBL?=                ${DESTDIR}${LIBDIR}/libl.a
++LIBL?=                ${DESTDIR}${LIBDIR}/libfl.a
+ LIBLN?=               "don't use LIBLN, use LIBL"
+ LIBLZMA?=     ${DESTDIR}${LIBDIR}/liblzma.a
+ LIBM?=                ${DESTDIR}${LIBDIR}/libm.a
+diff --git a/share/mk/bsd.links.mk b/share/mk/bsd.links.mk
+index 0c7d063..f5d1779 100644
+--- a/share/mk/bsd.links.mk
++++ b/share/mk/bsd.links.mk
+@@ -16,9 +16,11 @@ afterinstall: _installlinks
+ _installlinks:
+ .for s t in ${LINKS}
+       @${ECHO} "${t} -> ${s}" ;\
++      test -d ${DESTDIR}/`dirname ${t}` || mkdir ${DESTDIR}/`dirname ${t}`;\
+       ${INSTALL_LINK} ${TAG_ARGS} ${DESTDIR}${s} ${DESTDIR}${t}
+ .endfor
+ .for s t in ${SYMLINKS}
+       @${ECHO} "${t} -> ${s}" ;\
++      test -d ${DESTDIR}/`dirname ${t}` || mkdir ${DESTDIR}/`dirname ${t}`;\
+       ${INSTALL_SYMLINK} ${TAG_ARGS} ${s} ${DESTDIR}/${t}
+ .endfor
+diff --git a/share/mk/bsd.man.mk b/share/mk/bsd.man.mk
+index 6f78501..bc9a1a6 100644
+--- a/share/mk/bsd.man.mk
++++ b/share/mk/bsd.man.mk
+@@ -188,9 +188,11 @@ maninstall: ${MAN}
+ .if ${MK_MANCOMPRESS} == "no"
+ .if defined(MANFILTER)
+ .for __page in ${MAN}
++      ${INSTALL} -d ${DESTDIR}${MANDIR}${__page:E}${MANSUBDIR}/${__page}
+       ${MINSTALL} ${__page:T:S/$/${FILTEXTENSION}/g} \
+               ${DESTDIR}${MANDIR}${__page:E}${MANSUBDIR}/${__page}
+ .if defined(MANBUILDCAT) && !empty(MANBUILDCAT)
++      ${INSTALL} -d ${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page}
+       ${MINSTALL} ${__page:T:S/$/${CATEXT}${FILTEXTENSION}/g} \
+               ${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page}
+ .endif
+@@ -204,11 +206,14 @@ maninstall: ${MAN}
+               esac; \
+               page=$$1; shift; sect=$$1; shift; \
+               d=${DESTDIR}${MANDIR}$${sect}${MANSUBDIR}; \
++              ${ECHO} ${INSTALL} -d $${d}; \
++              ${INSTALL} -d $${d}; \
+               ${ECHO} ${MINSTALL} $${page} $${d}; \
+               ${MINSTALL} $${page} $${d}; \
+       done
+ .if defined(MANBUILDCAT) && !empty(MANBUILDCAT)
+ .for __page in ${MAN}
++      ${INSTALL} -d ${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page:T}
+       ${MINSTALL} ${__page:T:S/$/${CATEXT}/} \
+               ${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page:T}
+ .endfor
+@@ -216,9 +221,11 @@ maninstall: ${MAN}
+ .endif        # defined(MANFILTER)
+ .else # ${MK_MANCOMPRESS} == "yes"
+ .for __page in ${MAN}
++      ${INSTALL} -d ${DESTDIR}${MANDIR}${__page:E}${MANSUBDIR}
+       ${MINSTALL} ${__page:T:S/$/${MCOMPRESS_EXT}/g} \
+               ${DESTDIR}${MANDIR}${__page:E}${MANSUBDIR}/
+ .if defined(MANBUILDCAT) && !empty(MANBUILDCAT)
++      ${INSTALL} -d 
${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page:T:S/$/${MCOMPRESS_EXT}
+       ${MINSTALL} ${__page:T:S/$/${CATEXT}${MCOMPRESS_EXT}/g} \
+               
${DESTDIR}${CATDIR}${__page:E}${MANSUBDIR}/${__page:T:S/$/${MCOMPRESS_EXT}/}
+ .endif
+diff --git a/share/mk/bsd.nls.mk b/share/mk/bsd.nls.mk
+index 87a7347..c860c97 100644
+--- a/share/mk/bsd.nls.mk
++++ b/share/mk/bsd.nls.mk
+@@ -71,7 +71,8 @@ STAGE_SYMLINKS_DIR.NLS= ${STAGE_OBJTOP}
+ SYMLINKS+= ${NLSSYMLINKS}
+ .endif
+ .for file in ${NLS}
+-NLSNAME_${file:T}= ${file:T:R}/${NLSNAME}.cat
++NLSDIR_${file:T}= ${SHAREDIR}/nls/${file:T:R}/
++NLSNAME_${file:T}= ${NLSNAME}.cat
+ .if defined(NLSLINKS_${file:R}) && !empty(NLSLINKS_${file:R})
+ .if !empty(NLSLINKS_${file:R}:M${file:R})
+ .error NLSLINKS_${file:R} contains itself: ${file:R}
+diff --git a/share/mk/bsd.own.mk b/share/mk/bsd.own.mk
+index c10e492..5984215 100644
+--- a/share/mk/bsd.own.mk
++++ b/share/mk/bsd.own.mk
+@@ -233,9 +233,6 @@ INSTALL_SYMLINK?=  ${INSTALL} ${SYMLINK}
+ INSTALL_RSYMLINK?=    ${INSTALL} ${RSYMLINK}
+ 
+ # Common variables
+-.if !defined(DEBUG_FLAGS)
+-STRIP?=               -s
+-.endif
+ 
+ COMPRESS_CMD?=        gzip -cn
+ COMPRESS_EXT?=        .gz
+diff --git a/share/mk/bsd.prog.mk b/share/mk/bsd.prog.mk
+index f1a5c65..3b1ecf8 100644
+--- a/share/mk/bsd.prog.mk
++++ b/share/mk/bsd.prog.mk
+@@ -44,10 +44,6 @@ CTFFLAGS+= -g
+ .endif
+ .endif
+ 
+-.if !defined(DEBUG_FLAGS)
+-STRIP?=       -s
+-.endif
+-
+ .if defined(NO_ROOT)
+ .if !defined(TAGS) || ! ${TAGS:Mpackage=*}
+ TAGS+=                package=${PACKAGE:Uruntime}
+@@ -217,6 +213,7 @@ realinstall: _proginstall
+ .ORDER: beforeinstall _proginstall
+ _proginstall:
+ .if defined(PROG)
++      ${INSTALL} -d ${DESTDIR}${BINDIR}
+       ${INSTALL} ${TAG_ARGS} ${STRIP} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} 
\
+           ${_INSTALLFLAGS} ${PROG} ${DESTDIR}${BINDIR}/${PROGNAME}
+ .if ${MK_DEBUG_FILES} != "no"
+@@ -255,6 +252,7 @@ SCRIPTSMODE_${script:T}?=  ${SCRIPTSMODE}
+ STAGE_AS_${script:T}=         
${SCRIPTSDIR_${script:T}}/${SCRIPTSNAME_${script:T}}
+ _scriptsinstall: _SCRIPTSINS_${script:T}
+ _SCRIPTSINS_${script:T}: ${script}
++      ${INSTALL} -d ${DESTDIR}${SCRIPTSDIR_${.ALLSRC:T}}
+       ${INSTALL} ${TAG_ARGS} -o ${SCRIPTSOWN_${.ALLSRC:T}} \
+           -g ${SCRIPTSGRP_${.ALLSRC:T}} -m ${SCRIPTSMODE_${.ALLSRC:T}} \
+           ${.ALLSRC} \
+diff --git a/share/mk/bsd.sys.mk b/share/mk/bsd.sys.mk
+index 0ae45c5..37c4d01 100644
+--- a/share/mk/bsd.sys.mk
++++ b/share/mk/bsd.sys.mk
+@@ -29,9 +29,6 @@ CFLAGS+=     -std=${CSTD}
+ .if defined(WARNS)
+ .if ${WARNS} >= 1
+ CWARNFLAGS+=  -Wsystem-headers
+-.if !defined(NO_WERROR) && !defined(NO_WERROR.${COMPILER_TYPE})
+-CWARNFLAGS+=  -Werror
+-.endif # !NO_WERROR && !NO_WERROR.${COMPILER_TYPE}
+ .endif # WARNS >= 1
+ .if ${WARNS} >= 2
+ CWARNFLAGS+=  -Wall -Wno-format-y2k
+@@ -100,9 +97,6 @@ CWARNFLAGS+=        -Wformat=2 -Wno-format-extra-args
+ .if ${WARNS} <= 3
+ CWARNFLAGS.clang+=    -Wno-format-nonliteral
+ .endif # WARNS <= 3
+-.if !defined(NO_WERROR) && !defined(NO_WERROR.${COMPILER_TYPE})
+-CWARNFLAGS+=  -Werror
+-.endif # !NO_WERROR && !NO_WERROR.${COMPILER_TYPE}
+ .endif # WFORMAT > 0
+ .endif # WFORMAT
+ .if defined(NO_WFORMAT) || defined(NO_WFORMAT.${COMPILER_TYPE})
+@@ -151,6 +145,13 @@ CFLAGS.clang+=     -fno-dwarf2-cfi-asm
+ # but not yet.
+ CXXFLAGS.clang+=       -Wno-c++11-extensions
+ 
++.if ${MK_SSP} == "no"
++# gcc-4.9, -fstack-protector-strong is enabled by default.
++# Add -fno-stack-protector to disable it. Gentoo Bug #511698.
++SSP_CFLAGS?=    -fno-stack-protector
++CFLAGS+=      ${SSP_CFLAGS}
++.endif
++
+ .if ${MK_SSP} != "no" && \
+     ${MACHINE_CPUARCH} != "arm" && ${MACHINE_CPUARCH} != "mips"
+ .if (${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} >= 30500) || \
+diff --git a/share/mk/sys.mk b/share/mk/sys.mk
+index 5cfd0bb..25abf8e 100644
+--- a/share/mk/sys.mk
++++ b/share/mk/sys.mk
+@@ -418,12 +418,6 @@ YFLAGS            ?=      -d
+       rm -f ${.PREFIX}.tmp.c
+       ${CTFCONVERT_CMD}
+ 
+-# Pull in global settings.
+-__MAKE_CONF?=/etc/make.conf
+-.if exists(${__MAKE_CONF})
+-.include "${__MAKE_CONF}"
+-.endif
+-
+ # late include for customization
+ .sinclude <local.sys.mk>
+ 

diff --git a/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gnu.patch 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gnu.patch
new file mode 100644
index 00000000..97e882d
--- /dev/null
+++ b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-gnu.patch
@@ -0,0 +1,63 @@
+diff --git a/share/mk/bsd.lib.mk b/share/mk/bsd.lib.mk
+index 92df111..88c75d9 100644
+--- a/share/mk/bsd.lib.mk
++++ b/share/mk/bsd.lib.mk
+@@ -184,7 +184,7 @@ _LIBS=             lib${LIB_PRIVATE}${LIB}.a
+ lib${LIB_PRIVATE}${LIB}.a: ${OBJS} ${STATICOBJS}
+       @${ECHO} building static ${LIB} library
+       @rm -f ${.TARGET}
+-      ${AR} ${ARFLAGS} ${.TARGET} `NM='${NM}' NMFLAGS='${NMFLAGS}' lorder 
${OBJS} ${STATICOBJS} | tsort -q` ${ARADD}
++      ${AR} ${ARFLAGS} ${.TARGET} ${OBJS} ${STATICOBJS} ${ARADD}
+       ${RANLIB} ${RANLIBFLAGS} ${.TARGET}
+ .endif
+ 
+@@ -199,7 +199,7 @@ CLEANFILES+=       ${POBJS}
+ lib${LIB_PRIVATE}${LIB}_p.a: ${POBJS}
+       @${ECHO} building profiled ${LIB} library
+       @rm -f ${.TARGET}
+-      ${AR} ${ARFLAGS} ${.TARGET} `NM='${NM}' NMFLAGS='${NMFLAGS}' lorder 
${POBJS} | tsort -q` ${ARADD}
++      ${AR} ${ARFLAGS} ${.TARGET} {POBJS} ${ARADD}
+       ${RANLIB} ${RANLIBFLAGS} ${.TARGET}
+ .endif
+ 
+@@ -247,7 +247,7 @@ ${SHLIB_NAME_FULL}: ${SOBJS}
+ .endif
+       ${_LD:N${CCACHE_BIN}} ${LDFLAGS} ${SSP_CFLAGS} ${SOLINKOPTS} \
+           -o ${.TARGET} -Wl,-soname,${SONAME} \
+-          `NM='${NM}' NMFLAGS='${NMFLAGS}' lorder ${SOBJS} | tsort -q` 
${LDADD}
++          `echo ${SOBJS} | xargs -n 1 echo | sort -u` ${LDADD}
+ .if ${MK_CTF} != "no"
+       ${CTFMERGE} ${CTFFLAGS} -o ${.TARGET} ${SOBJS}
+ .endif
+@@ -312,13 +312,6 @@ _EXTRADEPEND:
+ 
+ .if !target(install)
+ 
+-.if defined(PRECIOUSLIB)
+-.if !defined(NO_FSCHG)
+-SHLINSTALLFLAGS+= -fschg
+-.endif
+-SHLINSTALLFLAGS+= -S
+-.endif
+-
+ _INSTALLFLAGS:=       ${INSTALLFLAGS}
+ .for ie in ${INSTALLFLAGS_EDIT}
+ _INSTALLFLAGS:=       ${_INSTALLFLAGS${ie}}
+diff --git a/share/mk/bsd.prog.mk b/share/mk/bsd.prog.mk
+index 3b1ecf8..26ac9c5 100644
+--- a/share/mk/bsd.prog.mk
++++ b/share/mk/bsd.prog.mk
+@@ -196,13 +196,6 @@ _EXTRADEPEND:
+ 
+ .if !target(install)
+ 
+-.if defined(PRECIOUSPROG)
+-.if !defined(NO_FSCHG)
+-INSTALLFLAGS+= -fschg
+-.endif
+-INSTALLFLAGS+= -S
+-.endif
+-
+ _INSTALLFLAGS:=       ${INSTALLFLAGS}
+ .for ie in ${INSTALLFLAGS_EDIT}
+ _INSTALLFLAGS:=       ${_INSTALLFLAGS${ie}}

diff --git 
a/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-libproc-libcxx.patch 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-libproc-libcxx.patch
new file mode 100644
index 00000000..5da025d
--- /dev/null
+++ 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-libproc-libcxx.patch
@@ -0,0 +1,13 @@
+diff --git a/share/mk/src.libnames.mk b/share/mk/src.libnames.mk
+index 14489a8..c993f7c 100644
+--- a/share/mk/src.libnames.mk
++++ b/share/mk/src.libnames.mk
+@@ -245,7 +245,7 @@ _DP_radius=        crypto
+ .endif
+ _DP_procstat= kvm util elf
+ .if ${MK_CXX} == "yes"
+-.if ${MK_LIBCPLUSPLUS} != "no"
++.if ${COMPILER_TYPE} == "clang"
+ _DP_proc=     cxxrt
+ .else
+ _DP_proc=     supcplusplus

diff --git 
a/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-rename-libs.patch 
b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-rename-libs.patch
new file mode 100644
index 00000000..fd72f1f
--- /dev/null
+++ b/sys-freebsd/freebsd-mk-defs/files/freebsd-mk-defs-11.0-rename-libs.patch
@@ -0,0 +1,16 @@
+diff --git a/share/mk/src.libnames.mk b/share/mk/src.libnames.mk
+index 249ac52..14489a8 100644
+--- a/share/mk/src.libnames.mk
++++ b/share/mk/src.libnames.mk
+@@ -343,6 +343,11 @@ LIBATF_CXX=       ${DESTDIR}${LIBDIR}/libprivateatf-c++.a
+ LDADD_atf_c=  -lprivateatf-c
+ LDADD_atf_cxx=        -lprivateatf-c++
+ 
++LDADD_bsdxml= -lexpat
++LDADD_l=      -lfl
++LDADD_termcap=        -lncurses
++LDADD_termcapw=       -lncursesw
++
+ .for _l in ${_PRIVATELIBS}
+ LIB${_l:tu}?= ${DESTDIR}${LIBDIR}/libprivate${_l}.a
+ .endfor

diff --git a/sys-freebsd/freebsd-mk-defs/freebsd-mk-defs-11.0.ebuild 
b/sys-freebsd/freebsd-mk-defs/freebsd-mk-defs-11.0.ebuild
new file mode 100644
index 00000000..e1eb27a
--- /dev/null
+++ b/sys-freebsd/freebsd-mk-defs/freebsd-mk-defs-11.0.ebuild
@@ -0,0 +1,55 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd
+
+DESCRIPTION="Makefiles definitions used for building and installing libraries 
and system files"
+SLOT="0"
+
+IUSE="userland_GNU"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64 ~x86 ~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="share/"
+
+RDEPEND=""
+DEPEND=""
+
+RESTRICT="strip"
+
+S="${WORKDIR}/share/mk"
+
+src_prepare() {
+       local installdir
+
+       epatch "${FILESDIR}/${PN}-11.0-gentoo.patch"
+       epatch "${FILESDIR}/${PN}-11.0-rename-libs.patch"
+       epatch "${FILESDIR}/${PN}-11.0-libproc-libcxx.patch"
+       epatch "${FILESDIR}/${PN}-11.0-drop-unsupport-cflags.patch"
+       use userland_GNU && epatch "${FILESDIR}/${PN}-11.0-gnu.patch"
+
+       if [[ ${CHOST} != *-freebsd* ]]; then
+               installdir="/usr/share/mk/freebsd"
+       else
+               installdir="/usr/share/mk"
+       fi
+
+       sed -i -e "s:FILESDIR=.*:FILESDIR= ${installdir}:" "${S}"/Makefile || 
die
+}
+
+src_compile() { :; }
+
+src_install() {
+       freebsd_src_install
+       if [[ ${CHOST} != *-freebsd* ]]; then
+               insinto /usr/share/mk/freebsd/system
+       else
+               insinto /usr/share/mk/system
+       fi
+       doins *.mk *.awk
+}

diff --git a/sys-freebsd/freebsd-pam-modules/Manifest 
b/sys-freebsd/freebsd-pam-modules/Manifest
index 2b08f19..e9b8f7f 100644
--- a/sys-freebsd/freebsd-pam-modules/Manifest
+++ b/sys-freebsd/freebsd-pam-modules/Manifest
@@ -1,3 +1,4 @@
 DIST freebsd-lib-8.2.tar.bz2 3323878 SHA256 
e3590c12794fcb5ba8eb7a1f58b497587cf19f9200b3254c194a793da3b5bfb0 SHA512 
c059cfdd1099bb519b2a5c43fb7e7104c500ef8906229ed7eb9e420cb3a217cdaf8655e9e7a9f45cfadc5491f8115e0e738fd49251d9f0c3a83780845b09f007
 WHIRLPOOL 
95f98a372f44a89bc8ac3029ec065dbbfec338e6f889d057d75644bfcdfb9d27fdc0421d7e392cad5a823712b97f0857297ec3d321580254c63032c22b95792e
 DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f51bcc3b14a1e9e90bb0e7cc4a35d SHA512 
40d0c36b6b889c404fa0e0afa38ba4e84a55bc88ffa2f98a70afbd7a32c4f32c158617ba770567d082a986d62c09b3ec8db3dc5ab853ee1c9bbe0b90bb82396e
 WHIRLPOOL 
581878bf9c43184b043b4293409b85901c9ed1f9bd279e965414aca41ba50950848ebda3ee10a503a028135dfd2765e95a11acd4e62a11c528e104392bbbd8d0
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827

diff --git a/sys-freebsd/freebsd-pam-modules/freebsd-pam-modules-11.0.ebuild 
b/sys-freebsd/freebsd-pam-modules/freebsd-pam-modules-11.0.ebuild
new file mode 100644
index 00000000..0172c4e
--- /dev/null
+++ b/sys-freebsd/freebsd-pam-modules/freebsd-pam-modules-11.0.ebuild
@@ -0,0 +1,46 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd multilib pam
+
+DESCRIPTION="FreeBSD's PAM authentication modules"
+SLOT="0"
+
+IUSE="kerberos nis"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="lib/"
+
+RDEPEND=">=sys-auth/openpam-20050201-r1
+       kerberos? ( dev-libs/openssl:0=
+               virtual/krb5 )"
+DEPEND="${RDEPEND}
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       =sys-freebsd/freebsd-sources-${RV}*"
+
+S=${WORKDIR}/lib/libpam/modules
+
+pkg_setup() {
+       # Avoid installing pam_ssh as that has its own ebuild.
+       mymakeopts="${mymakeopts} WITHOUT_OPENSSH= "
+       use kerberos || mymakeopts="${mymakeopts} WITHOUT_KERBEROS= "
+       use nis || mymakeopts="${mymakeopts} WITHOUT_NIS= "
+}
+
+src_prepare() {
+       for module in pam_deny pam_passwdqc pam_permit pam_krb5; do
+               sed -i -e "s:${module}::" "${S}"/modules.inc || die
+       done
+}
+
+src_install() {
+       freebsd_src_install "LIBDIR=/$(get_libdir)/security"
+
+       dodoc "${FILESDIR}/README.pamd"
+}

diff --git a/sys-freebsd/freebsd-pf/Manifest b/sys-freebsd/freebsd-pf/Manifest
index 79cfc36..5c4e450 100644
--- a/sys-freebsd/freebsd-pf/Manifest
+++ b/sys-freebsd/freebsd-pf/Manifest
@@ -5,5 +5,6 @@ DIST freebsd-etc-9.1.tar.bz2 207776 SHA256 
a317bf85532d6192f5506e8d7bd5d5c201fe2
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-usbin-8.2.tar.bz2 2443024 SHA256 
aa7cabf10f5c3a9daabea32e4de24d04ec312247842981476da666eff5054603 SHA512 
bcb8ff3df54848b9107bbb52e5ced7a91e24bb181f06769b6997221729b8064ec17652eaf7500de3268cbcb63ff5760beb54d15fc78c27b02687b5b1067c74a6
 WHIRLPOOL 
20f5278e2a1dd387a75b44f10507958d6c0e84a2faa1bddbf808c14ab86d8dd14a956192911bbc1880f5f5f7bd05972dcbb4aec85d241f0dcf91bf4246883f0a
 DIST freebsd-usbin-9.1.tar.bz2 2670916 SHA256 
b938c20b8c09aa9a610e13b69b9afeea72f561ab3636a59fba2bdac290f4db75 SHA512 
21c234312f70eb35cd2926519efc1f61592892f5d0940786dbeb959c3c5ec7819a51ae95c6e8a1a06aa01f669350fe0fd3dd7c4ec8a84dd6b90f24cb192356ca
 WHIRLPOOL 
7f6ad2eb5410cc5e685881654a788807848af026b1277a974682755ab7c9db28f576bfd1576441ea10c5f1e9edb7d30a4a23fb8eccd6d69d86ecc9ce4c9adc7e

diff --git a/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-libevent.patch 
b/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-libevent.patch
new file mode 100644
index 00000000..0f3ecb1
--- /dev/null
+++ b/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-libevent.patch
@@ -0,0 +1,13 @@
+diff --git a/usr.sbin/ftp-proxy/Makefile b/usr.sbin/ftp-proxy/Makefile
+index 941505f..df5ccb2 100644
+--- a/usr.sbin/ftp-proxy/Makefile
++++ b/usr.sbin/ftp-proxy/Makefile
+@@ -7,8 +7,6 @@ MAN=   ftp-proxy.8
+ 
+ SRCS= ftp-proxy.c filter.c
+ 
+-CFLAGS+=-I${.CURDIR}/../../contrib/pf/libevent
+-
+ LIBADD=       event
+ 
+ WARNS?=       3

diff --git a/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-pflogd.patch 
b/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-pflogd.patch
new file mode 100644
index 00000000..6435280
--- /dev/null
+++ b/sys-freebsd/freebsd-pf/files/freebsd-pf-11.0-pflogd.patch
@@ -0,0 +1,13 @@
+diff --git a/sbin/pflogd/Makefile b/sbin/pflogd/Makefile
+index b3822dd..5912ad2 100644
+--- a/sbin/pflogd/Makefile
++++ b/sbin/pflogd/Makefile
+@@ -7,8 +7,6 @@ PROG=  pflogd
+ SRCS=         pflogd.c pidfile.c privsep.c privsep_fdpass.c
+ MAN=  pflogd.8
+ 
+-CFLAGS+=-include ${.CURDIR}/../../lib/libpcap/config.h
+-
+ LIBADD=       pcap
+ 
+ WARNS?=       2

diff --git a/sys-freebsd/freebsd-pf/freebsd-pf-11.0.ebuild 
b/sys-freebsd/freebsd-pf/freebsd-pf-11.0.ebuild
new file mode 100644
index 00000000..914cfe1
--- /dev/null
+++ b/sys-freebsd/freebsd-pf/freebsd-pf-11.0.ebuild
@@ -0,0 +1,71 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd user
+
+DESCRIPTION="FreeBSD's base system libraries"
+SLOT="0"
+
+IUSE=""
+
+# Crypto is needed to have an internal OpenSSL header
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       usr.sbin/
+       sbin/
+       contrib/pf/
+       etc/
+"
+
+RDEPEND="net-libs/libpcap"
+DEPEND="${RDEPEND}
+       dev-libs/libevent
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       =sys-freebsd/freebsd-sources-${RV}*"
+
+S="${WORKDIR}"
+
+SUBDIRS="usr.sbin/authpf sbin/pfctl sbin/pflogd usr.sbin/ftp-proxy"
+
+pkg_setup() {
+       enewgroup authpf 63
+}
+
+src_prepare() {
+       # pcap-int.h redefines snprintf as pcap_snprintf
+       epatch "${FILESDIR}/${PN}-9.0-pcap_pollution.patch"
+       # Use system's libevent
+       epatch "${FILESDIR}/${PN}-11.0-libevent.patch"
+       epatch "${FILESDIR}/${PN}-11.0-pflogd.patch"
+       epatch "${FILESDIR}/${PN}-9.0-bpf.patch"
+       # Link in kernel sources
+       [[ ! -e "${WORKDIR}/sys" ]] && ln -s "/usr/src/sys" "${WORKDIR}/sys"
+}
+
+src_compile() {
+       for dir in ${SUBDIRS}; do
+               einfo "Starting make in ${dir}"
+               cd "${S}/${dir}" || die
+               freebsd_src_compile || die "Make ${dir} failed"
+       done
+}
+
+src_install() {
+       for dir in ${SUBDIRS}; do
+               einfo "Starting install in ${dir}"
+               cd "${S}/${dir}" || die
+               freebsd_src_install || die "Install ${dir} failed"
+       done
+
+       cd "${WORKDIR}"/etc
+       insinto /etc
+       doins pf.os
+       # pf.initd provided by openrc, but no pf.confd
+       newconfd "${FILESDIR}/pf.confd" pf
+}

diff --git a/sys-freebsd/freebsd-rescue/Manifest 
b/sys-freebsd/freebsd-rescue/Manifest
index e4c4149..49010aa 100644
--- a/sys-freebsd/freebsd-rescue/Manifest
+++ b/sys-freebsd/freebsd-rescue/Manifest
@@ -15,6 +15,7 @@ DIST freebsd-rescue-9.1.tar.bz2 3939 SHA256 
15794c65e2977a2623f0a09090f835c67e6e
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c

diff --git 
a/sys-freebsd/freebsd-rescue/files/freebsd-rescue-11.0-rename-libs.patch 
b/sys-freebsd/freebsd-rescue/files/freebsd-rescue-11.0-rename-libs.patch
new file mode 100644
index 00000000..3103574
--- /dev/null
+++ b/sys-freebsd/freebsd-rescue/files/freebsd-rescue-11.0-rename-libs.patch
@@ -0,0 +1,22 @@
+diff --git a/rescue/rescue/Makefile b/rescue/rescue/Makefile
+index e747c02..a061436 100644
+--- a/rescue/rescue/Makefile
++++ b/rescue/rescue/Makefile
+@@ -54,7 +54,7 @@ CRUNCH_PROGS_bin= cat chflags chio chmod cp date dd df echo  
\
+        ed expr getfacl hostname kenv kill ln ls mkdir mv      \
+        pkill ps pwd realpath rm rmdir setfacl sh sleep stty   \
+        sync test
+-CRUNCH_LIBS+= -lcrypt -ledit -ljail -lkvm -lelf -ll -ltermcapw -lutil -lxo
++CRUNCH_LIBS+= -lcrypt -ledit -ljail -lkvm -lelf -lfl -lncursesw -lutil -lxo
+ CRUNCH_BUILDTOOLS+= bin/sh
+ 
+ # Additional options for specific programs
+@@ -128,7 +128,7 @@ CRUNCH_LIBS+= -lavl -lzpool -lzfs_core -lzfs -lnvpair 
-lpthread -luutil -lumem
+ # liblzma needs pthread
+ CRUNCH_LIBS+= -lpthread
+ .endif
+-CRUNCH_LIBS+= -lgeom -lbsdxml -lkiconv
++CRUNCH_LIBS+= -lgeom -lexpat -lkiconv
+ .if ${MK_OPENSSL} == "no"
+ CRUNCH_LIBS+= -lmd
+ .endif

diff --git a/sys-freebsd/freebsd-rescue/freebsd-rescue-11.0.ebuild 
b/sys-freebsd/freebsd-rescue/freebsd-rescue-11.0.ebuild
new file mode 100644
index 00000000..f473264
--- /dev/null
+++ b/sys-freebsd/freebsd-rescue/freebsd-rescue-11.0.ebuild
@@ -0,0 +1,85 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd toolchain-funcs
+
+DESCRIPTION="FreeBSD's rescue binaries"
+SLOT="0"
+LICENSE="BSD zfs? ( CDDL )"
+
+IUSE="atm netware nis zfs"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       usr.bin/
+       contrib/
+       lib/
+       bin/
+       sbin/
+       usr.sbin/
+       gnu/
+       sys/
+       libexec/
+       rescue/
+"
+
+RDEPEND=""
+DEPEND="sys-devel/flex
+       app-arch/xz-utils[static-libs]
+       sys-libs/ncurses[static-libs]
+       dev-libs/expat[static-libs]
+       app-arch/bzip2[static-libs]
+       dev-libs/libedit[static-libs]
+       dev-libs/libxml2:2[static-libs]
+       dev-libs/openssl:0=[static-libs]
+       sys-libs/zlib[static-libs]
+       sys-libs/readline[static-libs]
+       =sys-freebsd/freebsd-lib-${RV}*[atm?,netware?]
+       =sys-freebsd/freebsd-sources-${RV}*
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       zfs? ( =sys-freebsd/freebsd-cddl-${RV}* )"
+
+S="${WORKDIR}/rescue"
+
+pkg_setup() {
+       # Add the required source files.
+       use zfs && EXTRACTONLY+="cddl/ "
+
+       use atm || mymakeopts="${mymakeopts} WITHOUT_ATM= "
+       use netware || mymakeopts="${mymakeopts} WITHOUT_IPX= "
+       use nis || mymakeopts="${mymakeopts} WITHOUT_NIS= "
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_CDDL= "
+       mymakeopts="${mymakeopts} NO_PIC= "
+}
+
+src_prepare() {
+       # As they are patches from ${WORKDIR} apply them by hand
+       cd "${WORKDIR}" || die
+       epatch "${FILESDIR}/${PN}-10.0-zlib.patch"
+       epatch "${FILESDIR}/${PN}-11.0-rename-libs.patch"
+       epatch "${FILESDIR}/freebsd-ubin-10.2-bsdxml.patch"
+}
+
+src_compile() {
+       export ESED=/usr/bin/sed
+       unalias sed
+
+       tc-export CC
+       # crunchgen is now checks env MAKE.
+       # Use to force BSD's make
+       export MAKE=/usr/bin/make
+
+       cd "${WORKDIR}/lib/libarchive" || die
+       echo "#include <expat.h>" > bsdxml.h
+       freebsd_src_compile
+       export CC="${CC} -L${WORKDIR}/lib/libarchive"
+
+       cd "${S}" || die
+       freebsd_src_compile
+}

diff --git a/sys-freebsd/freebsd-sbin/Manifest 
b/sys-freebsd/freebsd-sbin/Manifest
index 321d698..37092fc 100644
--- a/sys-freebsd/freebsd-sbin/Manifest
+++ b/sys-freebsd/freebsd-sbin/Manifest
@@ -9,6 +9,7 @@ DIST freebsd-libexec-9.1.tar.bz2 304592 SHA256 
71e6e9e41328c2148c54b81ad9b59f912
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-usbin-8.2.tar.bz2 2443024 SHA256 
aa7cabf10f5c3a9daabea32e4de24d04ec312247842981476da666eff5054603 SHA512 
bcb8ff3df54848b9107bbb52e5ced7a91e24bb181f06769b6997221729b8064ec17652eaf7500de3268cbcb63ff5760beb54d15fc78c27b02687b5b1067c74a6
 WHIRLPOOL 
20f5278e2a1dd387a75b44f10507958d6c0e84a2faa1bddbf808c14ab86d8dd14a956192911bbc1880f5f5f7bd05972dcbb4aec85d241f0dcf91bf4246883f0a

diff --git a/sys-freebsd/freebsd-sbin/freebsd-sbin-11.0.ebuild 
b/sys-freebsd/freebsd-sbin/freebsd-sbin-11.0.ebuild
new file mode 100644
index 00000000..b9ccdc5
--- /dev/null
+++ b/sys-freebsd/freebsd-sbin/freebsd-sbin-11.0.ebuild
@@ -0,0 +1,100 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd multilib
+
+DESCRIPTION="FreeBSD sbin utils"
+SLOT="0"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       sbin/
+       contrib/
+       lib/
+       libexec/
+       usr.sbin/
+       etc/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*[ipv6?,atm?,netware?]
+       =sys-freebsd/freebsd-libexec-${RV}*
+       >=dev-libs/expat-2.0.1
+       ssl? ( dev-libs/openssl:0= )
+       >=dev-libs/libedit-20120311.3.0-r1
+       sys-libs/readline:0=
+       || (
+               sys-process/cronie
+               sys-process/vixie-cron
+       )
+       atm? ( net-analyzer/bsnmp )"
+DEPEND="${RDEPEND}
+       !build? ( =sys-freebsd/freebsd-sources-${RV}* )
+       =sys-freebsd/freebsd-mk-defs-${RV}*"
+
+S="${WORKDIR}/sbin"
+
+IUSE="atm ipfilter +pf ipv6 build ssl +cxx netware"
+
+pkg_setup() {
+       # Add the required source files.
+       use build && EXTRACTONLY+="sys/ "
+
+       use atm || mymakeopts="${mymakeopts} WITHOUT_ATM= "
+       use cxx || mymakeopts="${mymakeopts} WITHOUT_CXX="
+       use ipfilter || mymakeopts="${mymakeopts} WITHOUT_IPFILTER= "
+       use ipv6 || mymakeopts="${mymakeopts} WITHOUT_INET6= 
WITHOUT_INET6_SUPPORT="
+       use netware || mymakeopts="${mymakeopts} WITHOUT_IPX= 
WITHOUT_IPX_SUPPORT= WITHOUT_NCP= "
+       use pf || mymakeopts="${mymakeopts} WITHOUT_PF= "
+       use ssl || mymakeopts="${mymakeopts} WITHOUT_OPENSSL="
+}
+
+REMOVE_SUBDIRS="dhclient pfctl pflogd rcorder resolvconf"
+
+PATCHES=( "${FILESDIR}/${PN}-setXid.patch"
+       "${FILESDIR}/${PN}-10.0-zlib.patch"
+       "${FILESDIR}/${PN}-6.2-ldconfig.patch"
+       "${FILESDIR}/${PN}-6.1-pr102701.patch" )
+
+src_prepare() {
+       if [[ ! -e "${WORKDIR}/sys" ]]; then
+               use build || ln -s "/usr/src/sys" "${WORKDIR}/sys"
+       fi
+}
+
+src_install() {
+       mymakeopts="${mymakeopts} GEOM_CLASS_DIR=/$(get_libdir)/geom "
+       freebsd_src_install
+       keepdir /var/log
+       # Needed by ldconfig:
+       keepdir /var/run
+
+       # Maybe ship our own sysctl.conf so things like radvd work out of the 
box.
+       # New wireless config method requires regdomain.xml in /etc
+       cd "${WORKDIR}/etc/" || die
+       insinto /etc
+       doins minfree sysctl.conf regdomain.xml || die
+
+       # Install a crontab for adjkerntz
+       insinto /etc/cron.d
+       newins "${FILESDIR}/adjkerntz-crontab" adjkerntz
+
+       # Install the periodic stuff (needs probably to be ported in a more
+       # gentooish way)
+       cd "${WORKDIR}/etc/periodic" || die
+
+       doperiodic security \
+               security/*.ipfwlimit \
+               security/*.ipfwdenied || die
+
+       use ipfilter && { doperiodic security \
+               security/*.ipfdenied || die ; }
+
+       use pf && { doperiodic security \
+               security/*.pfdenied || die ; }
+}

diff --git a/sys-freebsd/freebsd-share/Manifest 
b/sys-freebsd/freebsd-share/Manifest
index 92a7ada..44560fd 100644
--- a/sys-freebsd/freebsd-share/Manifest
+++ b/sys-freebsd/freebsd-share/Manifest
@@ -13,6 +13,7 @@ DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3
 DIST freebsd-share-8.2.tar.bz2 3797560 SHA256 
dd082c6ddbf8e08ec91d9810d51af4111339bed912b0f74d05be283780292ba0 SHA512 
b3f964253f80e58cde12f26e48a23aa75c17b9ab2810f91a4bd2d7efbe902af7c73c219f8373a4fc97ee0a35d25627b8815c79c136ef18620acc8bd0ee5bd6c4
 WHIRLPOOL 
42326ad6139feadf80509f5e810f6a86009ad3a69aad9550c6355389773c28d5b2f7930eaa852f8442808485d13e5b758ed3420e39048bb3966785e6953119ea
 DIST freebsd-share-9.1.tar.bz2 6733003 SHA256 
2bbd8aa05d52b18a1780772a8518d79d375c1eeae98f52fb6aded233ac2491d7 SHA512 
9665e3d5253f49a55921012bd21a8688210a1993ba6be4ad17b5ba5619104a50f3199d49a0eb83cf29db5a06c407beb15616bfe71338c680fe34ec47564c4b43
 WHIRLPOOL 
7d15596888ac42af1a0c125591283524ff794dccbf9f6592963602f046a45ca073b10bda43c2d0d662fd3414753de64c05293788e03c4eea67de55d9bc083c11
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c
 DIST freebsd-ubin-9.1.tar.bz2 1910472 SHA256 
ff6e586f213534b6ec2e65002c0dee64063d76ddad515c12221b1a80a1815e48 SHA512 
74ae0aceec8597aa66c3f1ab313f0685a3c63d7273c36ae7baf8794275ad9bca241c60c3f6281cccf6d531d250d7611099977d3b1a27279cef3586401b6af05e
 WHIRLPOOL 
c85a3c9cf2bceff2c60ff03556bcc81d3aca22b0bce3c9538990071ac0a907236eee5ae7743ad22c5fd309b047ebf392aaaf2fe177ef5790ea869aff3da7e2fe
 DIST freebsd-usbin-8.2.tar.bz2 2443024 SHA256 
aa7cabf10f5c3a9daabea32e4de24d04ec312247842981476da666eff5054603 SHA512 
bcb8ff3df54848b9107bbb52e5ced7a91e24bb181f06769b6997221729b8064ec17652eaf7500de3268cbcb63ff5760beb54d15fc78c27b02687b5b1067c74a6
 WHIRLPOOL 
20f5278e2a1dd387a75b44f10507958d6c0e84a2faa1bddbf808c14ab86d8dd14a956192911bbc1880f5f5f7bd05972dcbb4aec85d241f0dcf91bf4246883f0a

diff --git a/sys-freebsd/freebsd-share/freebsd-share-11.0.ebuild 
b/sys-freebsd/freebsd-share/freebsd-share-11.0.ebuild
new file mode 100644
index 00000000..75cbfc0
--- /dev/null
+++ b/sys-freebsd/freebsd-share/freebsd-share-11.0.ebuild
@@ -0,0 +1,114 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd
+
+DESCRIPTION="FreeBSD shared tools/files"
+SLOT="0"
+LICENSE="BSD zfs? ( CDDL )"
+
+IUSE="doc usb zfs"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+fi
+
+EXTRACTONLY="
+       share/
+       contrib/
+       gnu/
+       usr.bin/
+       usr.sbin/
+       sbin/
+       bin/
+       lib/
+       etc/
+       tools/tools/locale/
+"
+
+DEPEND="=sys-freebsd/freebsd-mk-defs-${RV}*
+               =sys-freebsd/freebsd-sources-${RV}*"
+RDEPEND="sys-apps/miscfiles"
+
+RESTRICT="strip"
+
+S="${WORKDIR}/share"
+
+pkg_setup() {
+       # Add the required source files.
+       use zfs && EXTRACTONLY+="cddl/ "
+
+       use doc || mymakeopts="${mymakeopts} WITHOUT_SHAREDOCS= "
+       use usb || mymakeopts="${mymakeopts} WITHOUT_USB= "
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_CDDL= "
+       [[ ! -e /usr/bin/vtfontcvt ]] && mymakeopts="${mymakeopts} WITHOUT_VT= "
+       [[ ! -e /usr/bin/localedef ]] && mymakeopts="${mymakeopts} 
WITHOUT_LOCALES= "
+       mymakeopts="${mymakeopts} WITHOUT_SENDMAIL= WITHOUT_CLANG= "
+}
+
+REMOVE_SUBDIRS="mk termcap zoneinfo tabset"
+
+PATCHES=( "${FILESDIR}/${PN}-10.3-gentoo-skel.patch"
+       "${FILESDIR}/${PN}-10.0-gentoo-eapi3.patch"
+       "${FILESDIR}/${PN}-10.2-gnu-miscfiles.patch" )
+
+src_prepare() {
+       # Remove make.conf manpage as it describes bsdmk's make.conf.
+       sed -i -e 's:make.conf.5::' "${S}/man/man5/Makefile"
+       # Remove rc.conf manpage as it describes bsd's rc.conf.
+       sed -i -e 's:\brc.conf.5::' "${S}/man/man5/Makefile"
+       sed -i -e 's:\brc.conf.local.5::' "${S}/man/man5/Makefile"
+       # Remove mailer.conf manpage
+       sed -i -e 's:mailer.conf.5::' "${S}/man/man5/Makefile"
+       # Remove pbm and moduli(ssh) manpages
+       sed -i -e 's:pbm.5::' -e 's:moduli.5::' "${S}/man/man5/Makefile"
+       # Remove builtins manpage
+       sed -i -e '/builtins\.1/d' "${S}/man/man1/Makefile"
+       # Remove rc manpages
+       sed -i -e '/rc.8/d' "${S}/man/man8/Makefile"
+       # Remove hv_kvp_daemon.8 manpage. It's provided by freebsd-usbin.
+       sed -i -e '/hv_kvp_daemon.8/d' "${S}/man/man8/Makefile"
+
+       # Don't install the arch-specific directories in subdirectories
+       sed -i -e '/MANSUBDIR/d' "${S}"/man/man4/man4.{i386,sparc64}/Makefile
+
+       # Remove them so that they can't be included by error
+       rm -rf "${S}"/mk/*.mk
+
+       # Make proper symlinks by defining the full target.
+       local sdir
+       for sdir in colldef monetdef msgdef numericdef timedef
+       do
+               sed -e 's:\${enc2}$:\${enc2}/\${FILESNAME}:g' -i \
+                       "${S}/${sdir}/Makefile" || \
+                       die "Error fixing ${sdir}/Makefile"
+       done
+       if [[ ! -e "${WORKDIR}/sys" ]]; then
+               ln -s "/usr/src/sys" "${WORKDIR}/sys" || die "failed to set sys 
symlink"
+       fi
+}
+
+src_compile() {
+       export ESED="/usr/bin/sed"
+
+       # libiconv support.
+       # i18n/csmapper/APPLE requires mkcsmapper_static
+       # i18n/esdb/APPLE requires mkesdb_static
+       for pkg in mkcsmapper_static mkesdb_static
+       do
+               cd "${WORKDIR}"/usr.bin/${pkg} || die
+               freebsd_src_compile
+       done
+
+       # This is a groff problem and not a -shared problem.
+       cd "${S}" || die
+       export GROFF_TMAC_PATH="/usr/share/tmac/:/usr/share/groff/1.22.2/tmac/"
+       freebsd_src_compile -j1 || die "emake failed"
+}
+
+src_install() {
+       freebsd_src_install -j1 DOCDIR=/usr/share/doc/${PF}
+}

diff --git a/sys-freebsd/freebsd-sources/Manifest 
b/sys-freebsd/freebsd-sources/Manifest
index adb7ab4..46d0fff 100644
--- a/sys-freebsd/freebsd-sources/Manifest
+++ b/sys-freebsd/freebsd-sources/Manifest
@@ -12,5 +12,6 @@ DIST freebsd-sources-SA-1619-sendmsg.patch 247 SHA256 
d847e42634e26e29b3ce1d68d2
 DIST freebsd-sources-SA-1620-linux.patch 492 SHA256 
a62f5402b2a3d2b73b684854eaed45864dade33f7b04d6469b556776866380a9 SHA512 
1fb28b25ac5f89e2f7fa9a1f74ba83b4c949f2175217b669b5fcd2062c54307dcb50ad072acbe18162272b9bc29ba40ac4e19db1564a2959e885ac826a332ae5
 WHIRLPOOL 
7ba8da63513a495418a7e6433c4814eedb43e0305ada423057d2df27e90a51ce8b3caa7a06665fe114185c6335426ed12dbb346ef2a2c2c0d168a04707aa6395
 DIST freebsd-sources-SA-1621-stat.patch 223 SHA256 
dd924b1f983ff653edb6676cb5f02621309c3493501c9741a35a2cbcc021cbbf SHA512 
501244c0831d2aeb37c8a8aaa762cc6c8c39929355e6695df23dc83c78d6bb499dcb903f50c17e3f7774306d53836a0633d65e284167590c015aa1f8e10e5e4a
 WHIRLPOOL 
cd17cd613a2bb234224a21b491d4bfee6e9d9c43126689a8600f9d46eccf835661078fc926fd8a73599d30db770cb9fa0baa2817dcfb6ab3b06c1e39374bd946
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3

diff --git 
a/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo-gcc.patch 
b/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo-gcc.patch
new file mode 100644
index 00000000..1d3c8d6
--- /dev/null
+++ b/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo-gcc.patch
@@ -0,0 +1,13 @@
+diff --git a/sys/conf/newvers.sh b/sys/conf/newvers.sh
+index e4b2ad4..411bedf 100644
+--- a/sys/conf/newvers.sh
++++ b/sys/conf/newvers.sh
+@@ -110,7 +110,7 @@ else
+       t=`date`
+ fi
+ i=`${MAKE:-make} -V KERN_IDENT`
+-compiler_v=$($(${MAKE:-make} -V CC) -v 2>&1 | grep -w 'version')
++compiler_v=$($(${MAKE:-make} -V CC) -v 2>&1 | grep 'version' | tail -n 1)
+ 
+ for dir in /usr/bin /usr/local/bin; do
+       if [ ! -z "${svnversion}" ] ; then

diff --git 
a/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo.patch 
b/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo.patch
new file mode 100644
index 00000000..6acd6aa
--- /dev/null
+++ b/sys-freebsd/freebsd-sources/files/freebsd-sources-11.0-gentoo.patch
@@ -0,0 +1,22 @@
+diff --git a/sys/conf/kern.mk b/sys/conf/kern.mk
+index e27ea93..615dbac 100644
+--- a/sys/conf/kern.mk
++++ b/sys/conf/kern.mk
+@@ -5,7 +5,7 @@
+ #
+ CWARNFLAGS?=  -Wall -Wredundant-decls -Wnested-externs -Wstrict-prototypes \
+               -Wmissing-prototypes -Wpointer-arith -Winline -Wcast-qual \
+-              -Wundef -Wno-pointer-sign ${FORMAT_EXTENSIONS} \
++              -Wundef -Wno-pointer-sign \
+               -Wmissing-include-dirs -fdiagnostics-show-option \
+               -Wno-unknown-pragmas \
+               ${CWARNEXTRA}
+@@ -86,7 +86,7 @@ FORMAT_EXTENSIONS=   -fformat-extensions
+ # Setting -mno-sse implies -mno-sse2, -mno-sse3, -mno-ssse3, -mno-sse41 and 
-mno-sse42
+ #
+ .if ${MACHINE_CPUARCH} == "i386"
+-CFLAGS.gcc+=  -mno-align-long-strings -mpreferred-stack-boundary=2
++CFLAGS.gcc+=  -mpreferred-stack-boundary=2
+ CFLAGS.clang+=        -mno-aes -mno-avx
+ CFLAGS+=      -mno-mmx -mno-sse -msoft-float
+ INLINE_LIMIT?=        8000

diff --git a/sys-freebsd/freebsd-sources/freebsd-sources-11.0.ebuild 
b/sys-freebsd/freebsd-sources/freebsd-sources-11.0.ebuild
new file mode 100644
index 00000000..aebc8cf
--- /dev/null
+++ b/sys-freebsd/freebsd-sources/freebsd-sources-11.0.ebuild
@@ -0,0 +1,170 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd flag-o-matic toolchain-funcs
+
+DESCRIPTION="FreeBSD kernel sources"
+SLOT="0"
+LICENSE="BSD dtrace? ( CDDL ) zfs? ( CDDL )"
+
+IUSE="+build-kernel debug dtrace zfs"
+
+# Security Advisory and Errata patches.
+# UPSTREAM_PATCHES=()
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+       SRC_URI="${SRC_URI}
+               $(freebsd_upstream_patches)"
+fi
+
+EXTRACTONLY="
+       sys/
+       contrib/bmake/
+       usr.bin/bmake/
+"
+
+RDEPEND="dtrace? ( >=sys-freebsd/freebsd-cddl-9.2_rc1 )
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       !sys-freebsd/virtio-kmod
+       !sys-fs/fuse4bsd
+       !<sys-freebsd/freebsd-sources-9.2_beta1"
+DEPEND="build-kernel? (
+               dtrace? ( >=sys-freebsd/freebsd-cddl-9.2_rc1 )
+               >=sys-freebsd/freebsd-usbin-9.1
+               =sys-freebsd/freebsd-mk-defs-${RV}*
+       )"
+
+RESTRICT="strip binchecks"
+
+S="${WORKDIR}/sys"
+
+KERN_BUILD=GENTOO
+
+PATCHES=( "${FILESDIR}/${PN}-9.0-disable-optimization.patch"
+       "${FILESDIR}/${PN}-6.0-flex-2.5.31.patch"
+       "${FILESDIR}/${PN}-8.0-subnet-route-pr40133.patch"
+       "${FILESDIR}/${PN}-7.1-includes.patch"
+       "${FILESDIR}/${PN}-9.0-sysctluint.patch"
+       "${FILESDIR}/${PN}-11.0-gentoo.patch"
+       "${FILESDIR}/${PN}-11.0-gentoo-gcc.patch"
+       "${FILESDIR}/${PN}-10.1-gcc48.patch" )
+
+pkg_setup() {
+       # Add the required source files.
+       use dtrace && EXTRACTONLY+="cddl/ "
+
+       # WITHOUT_SSP= is required to boot kernel that compiled with newer gcc, 
bug #477914
+       [[ $(tc-getCC) == *gcc* ]] && mymakeopts="${mymakeopts} WITHOUT_SSP= 
WITHOUT_FORMAT_EXTENSIONS="
+       use dtrace || mymakeopts="${mymakeopts} WITHOUT_CDDL="
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_ZFS="
+}
+
+src_prepare() {
+       local conf="${S}/$(tc-arch-kernel)/conf/${KERN_BUILD}"
+
+       cd "${WORKDIR}" || die
+       epatch "${FILESDIR}/freebsd-ubin-10.3-bmake-workaround.patch"
+       cd "${S}" || die
+
+       # This replaces the gentoover patch, it doesn't need reapply every time.
+       sed -i -e 's:^REVISION=.*:REVISION="'${PVR}'":' \
+               -e 's:^BRANCH=.*:BRANCH="Gentoo":' \
+               -e 's:^VERSION=.*:VERSION="${TYPE} ${BRANCH} ${REVISION}":' \
+               "${S}/conf/newvers.sh"
+
+       # __FreeBSD_cc_version comes from FreeBSD's gcc.
+       # on 11.0-RELEASE it's 1100001.
+       # FYI, can get it from gnu/usr.bin/cc/cc_tools/freebsd-native.h.
+       sed -e "s:-D_KERNEL:-D_KERNEL -D__FreeBSD_cc_version=1100001:g" \
+               -i "${S}/conf/kern.pre.mk" \
+               -i "${S}/conf/kmod.mk" || die "Couldn't set 
__FreeBSD_cc_version"
+
+       # Remove -Werror
+       sed -e "s:-Werror:-Wno-error:g" \
+               -i "${S}/conf/kern.pre.mk" \
+               -i "${S}/conf/kmod.mk" || die
+
+       # Set the kernel configuration using USE flags.
+       cp -f "${FILESDIR}/config-GENTOO" "${conf}" || die
+       use debug || echo 'nomakeoptions DEBUG' >> "${conf}"
+       use dtrace || echo 'nomakeoptions WITH_CTF' >> "${conf}"
+
+       # hyperv fails to compile on x86-fbsd.
+       if use x86-fbsd && [[ $(tc-getCC) == *gcc* ]] ; then
+               echo 'nodevice hyperv' >> "${conf}"
+               dummy_mk modules/hyperv
+       fi
+
+       # Only used with USE=build-kernel, let the kernel build with its own 
flags, its safer.
+       unset LDFLAGS CFLAGS CXXFLAGS ASFLAGS KERNEL
+}
+
+src_configure() {
+       if use build-kernel ; then
+               tc-export CC
+               cd "${S}/$(tc-arch-kernel)/conf" || die
+               config ${KERN_BUILD} || die
+       fi
+}
+
+src_compile() {
+       if use build-kernel ; then
+               if has_version "<sys-freebsd/freebsd-ubin-10.0"; then
+                       cd "${WORKDIR}"/usr.bin/bmake || die
+                       CC=${CHOST}-gcc freebsd_src_compile
+                       export BMAKE="${WORKDIR}/usr.bin/bmake/make"
+               fi
+               cd "${S}/$(tc-arch-kernel)/compile/${KERN_BUILD}" || die
+               freebsd_src_compile depend
+               freebsd_src_compile
+       else
+               einfo "Nothing to compile.."
+       fi
+}
+
+src_install() {
+       if use build-kernel ; then
+               cd "${S}/$(tc-arch-kernel)/compile/${KERN_BUILD}" || die
+               freebsd_src_install
+               rm -rf "${S}/$(tc-arch-kernel)/compile/${KERN_BUILD}"
+               cd "${S}"
+       fi
+
+       insinto "/usr/src/sys"
+       doins -r "${S}/".
+       if use zfs ; then
+               insinto "/usr/src/cddl"
+               doins -r "${WORKDIR}/cddl/".
+       fi
+}
+
+pkg_preinst() {
+       if [[ -L "${ROOT}/usr/src/sys" ]]; then
+               einfo "/usr/src/sys is a symlink, removing it..."
+               rm -f "${ROOT}/usr/src/sys"
+       fi
+
+       if use sparc-fbsd ; then
+               ewarn "WARNING: kldload currently causes kernel panics"
+               ewarn "on sparc64. This is probably a gcc-4.1 issue, but"
+               ewarn "we need gcc-4.1 to compile the kernel correctly :/"
+               ewarn "Please compile all modules you need into the kernel"
+       fi
+
+       ewarn "If you want manual compile (not recommended), please don't 
forget the following step."
+       if ! use sparc-fbsd ; then
+               ewarn "export CC=clang"
+               ewarn "export CXX=clang++"
+       fi
+       if ! use zfs ; then
+               ewarn "export WITHOUT_CDDL="
+               ewarn "Note, Please set USE=zfs if you want to enable modules 
of CDDL license."
+       fi
+       if ! use dtrace && ! has_version '>=sys-freebsd/freebsd-cddl-9.2_beta1' 
; then
+               ewarn "GENERIC config require sys-freebsd/freebsd-cddl. Please 
emerge it."
+       fi
+}

diff --git a/sys-freebsd/freebsd-ubin/Manifest 
b/sys-freebsd/freebsd-ubin/Manifest
index 18826f5..67bbfb2 100644
--- a/sys-freebsd/freebsd-ubin/Manifest
+++ b/sys-freebsd/freebsd-ubin/Manifest
@@ -11,6 +11,7 @@ DIST freebsd-include-9.1.tar.bz2 146881 SHA256 
861dce3f39e6806762b102361017cbe14
 DIST freebsd-lib-8.2.tar.bz2 3323878 SHA256 
e3590c12794fcb5ba8eb7a1f58b497587cf19f9200b3254c194a793da3b5bfb0 SHA512 
c059cfdd1099bb519b2a5c43fb7e7104c500ef8906229ed7eb9e420cb3a217cdaf8655e9e7a9f45cfadc5491f8115e0e738fd49251d9f0c3a83780845b09f007
 WHIRLPOOL 
95f98a372f44a89bc8ac3029ec065dbbfec338e6f889d057d75644bfcdfb9d27fdc0421d7e392cad5a823712b97f0857297ec3d321580254c63032c22b95792e
 DIST freebsd-lib-9.1.tar.bz2 3206685 SHA256 
f31fa8107b4de711c548f6d0c1bb1f81d09f51bcc3b14a1e9e90bb0e7cc4a35d SHA512 
40d0c36b6b889c404fa0e0afa38ba4e84a55bc88ffa2f98a70afbd7a32c4f32c158617ba770567d082a986d62c09b3ec8db3dc5ab853ee1c9bbe0b90bb82396e
 WHIRLPOOL 
581878bf9c43184b043b4293409b85901c9ed1f9bd279e965414aca41ba50950848ebda3ee10a503a028135dfd2765e95a11acd4e62a11c528e104392bbbd8d0
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c

diff --git a/sys-freebsd/freebsd-ubin/files/freebsd-ubin-11.0-setXid.patch 
b/sys-freebsd/freebsd-ubin/files/freebsd-ubin-11.0-setXid.patch
new file mode 100644
index 00000000..946cc5b
--- /dev/null
+++ b/sys-freebsd/freebsd-ubin/files/freebsd-ubin-11.0-setXid.patch
@@ -0,0 +1,147 @@
+diff --git a/usr.bin/at/Makefile b/usr.bin/at/Makefile
+index d199a85..dc5cafd 100644
+--- a/usr.bin/at/Makefile
++++ b/usr.bin/at/Makefile
+@@ -17,6 +17,8 @@ BINOWN=      root
+ BINMODE= 4555
+ CLEANFILES+= at.1
+ 
++LDFLAGS+=-Wl,-z,now
++
+ at.1: at.man
+       @${ECHO} Making ${.TARGET:T} from ${.ALLSRC:T}; \
+       sed -e \
+diff --git a/usr.bin/chpass/Makefile b/usr.bin/chpass/Makefile
+index 4427417..4f774a1 100644
+--- a/usr.bin/chpass/Makefile
++++ b/usr.bin/chpass/Makefile
+@@ -17,6 +17,8 @@ CFLAGS+= -DYP
+ #CFLAGS+=-DRESTRICT_FULLNAME_CHANGE
+ CFLAGS+=-I${.CURDIR}/../../usr.sbin/pwd_mkdb -I${.CURDIR}/../../lib/libc/gen 
-I.
+ 
++LDFLAGS+=-Wl,-z,now
++
+ LIBADD=       crypt util
+ .if ${MK_NIS} != "no"
+ LIBADD+=      ypclnt
+diff --git a/usr.bin/fstat/Makefile b/usr.bin/fstat/Makefile
+index cd03a51..9a0fe6e 100644
+--- a/usr.bin/fstat/Makefile
++++ b/usr.bin/fstat/Makefile
+@@ -9,3 +9,5 @@ LIBADD=        procstat
+ MAN1= fuser.1 fstat.1
+ 
+ .include <bsd.prog.mk>
++LDFLAGS+=-Wl,-z,now
++
+diff --git a/usr.bin/lock/Makefile b/usr.bin/lock/Makefile
+index 07321f7..ed2c786 100644
+--- a/usr.bin/lock/Makefile
++++ b/usr.bin/lock/Makefile
+@@ -7,4 +7,6 @@ BINMODE=4555
+ 
+ LIBADD=       crypt
+ 
++LDFLAGS+=-Wl,-z,now
++
+ .include <bsd.prog.mk>
+diff --git a/usr.bin/login/Makefile b/usr.bin/login/Makefile
+index 3499575..62a7356 100644
+--- a/usr.bin/login/Makefile
++++ b/usr.bin/login/Makefile
+@@ -16,6 +16,8 @@ CFLAGS+= -DUSE_BSM_AUDIT
+ LIBADD+=      bsm
+ .endif
+ 
++LDFLAGS+=-Wl,-z,now
++
+ .if ${MK_SETUID_LOGIN} != "no"
+ BINOWN=       root
+ BINMODE=4555
+diff --git a/usr.bin/netstat/Makefile b/usr.bin/netstat/Makefile
+index 52cc3c7..11ebb2f 100644
+--- a/usr.bin/netstat/Makefile
++++ b/usr.bin/netstat/Makefile
+@@ -57,6 +57,8 @@ BINGRP=      kmem
+ BINMODE=2555
+ LIBADD=       kvm memstat xo util
+ 
++LDFLAGS+=-Wl,-z,now
++
+ .if ${MK_NETGRAPH_SUPPORT} != "no"
+ SRCS+=        netgraph.c
+ LIBADD+=      netgraph
+diff --git a/usr.bin/opieinfo/Makefile b/usr.bin/opieinfo/Makefile
+index 3114a92..5c41213 100644
+--- a/usr.bin/opieinfo/Makefile
++++ b/usr.bin/opieinfo/Makefile
+@@ -12,6 +12,8 @@ WARNS?=      0
+ 
+ LIBADD=       opie
+ 
++LDFLAGS+=-Wl,-z,now
++
+ BINOWN=       root
+ BINMODE=4555
+ PRECIOUSPROG=
+diff --git a/usr.bin/opiepasswd/Makefile b/usr.bin/opiepasswd/Makefile
+index ae35b20..32ba59b 100644
+--- a/usr.bin/opiepasswd/Makefile
++++ b/usr.bin/opiepasswd/Makefile
+@@ -12,6 +12,8 @@ WARNS?=      0
+ 
+ LIBADD=       opie
+ 
++LDFLAGS+=-Wl,-z,now
++
+ BINOWN=       root
+ BINMODE=4555
+ PRECIOUSPROG=
+diff --git a/usr.bin/passwd/Makefile b/usr.bin/passwd/Makefile
+index 758be2d..ebde1a6 100644
+--- a/usr.bin/passwd/Makefile
++++ b/usr.bin/passwd/Makefile
+@@ -13,6 +13,8 @@ SYMLINKS = ${BINDIR}/passwd ${BINDIR}/yppasswd
+ MLINKS         = passwd.1 yppasswd.1
+ .endif
+ 
++LDFLAGS+=-Wl,-z,now
++
+ beforeinstall:
+ .for i in passwd yppasswd
+       [ ! -e ${DESTDIR}${BINDIR}/$i ] || \
+diff --git a/usr.bin/su/Makefile b/usr.bin/su/Makefile
+index b3dd829..26eaa63 100644
+--- a/usr.bin/su/Makefile
++++ b/usr.bin/su/Makefile
+@@ -10,6 +10,8 @@ WARNS?=      5
+ LIBADD=       util pam
+ 
+ .if ${MK_AUDIT} != "no"
++LDFLAGS+=-Wl,-z,now
++
+ CFLAGS+= -DUSE_BSM_AUDIT
+ LIBADD+=      bsm
+ .endif
+diff --git a/usr.bin/wall/Makefile b/usr.bin/wall/Makefile
+index 0579add..571be8d 100644
+--- a/usr.bin/wall/Makefile
++++ b/usr.bin/wall/Makefile
+@@ -6,4 +6,6 @@ SRCS=  ttymsg.c wall.c
+ BINGRP=       tty
+ BINMODE=2555
+ 
++LDFLAGS+=-Wl,-z,now
++
+ .include <bsd.prog.mk>
+diff --git a/usr.bin/write/Makefile b/usr.bin/write/Makefile
+index ba06110..ba6ce04 100644
+--- a/usr.bin/write/Makefile
++++ b/usr.bin/write/Makefile
+@@ -5,4 +5,6 @@ PROG=  write
+ BINMODE=2555
+ BINGRP=       tty
+ 
++LDFLAGS+=-Wl,-z,now
++
+ .include <bsd.prog.mk>

diff --git a/sys-freebsd/freebsd-ubin/freebsd-ubin-11.0.ebuild 
b/sys-freebsd/freebsd-ubin/freebsd-ubin-11.0.ebuild
new file mode 100644
index 00000000..537aad0
--- /dev/null
+++ b/sys-freebsd/freebsd-ubin/freebsd-ubin-11.0.ebuild
@@ -0,0 +1,209 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd flag-o-matic pam multilib multibuild multilib-build
+
+DESCRIPTION="FreeBSD's base system source for /usr/bin"
+SLOT="0"
+IUSE="ar atm audit bluetooth ipv6 kerberos netware nis ssl usb build zfs"
+LICENSE="BSD zfs? ( CDDL )"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+       SRC_URI="${SRC_URI}
+               $(freebsd_upstream_patches)"
+fi
+
+EXTRACTONLY="
+       usr.bin/
+       contrib/
+       lib/
+       etc/
+       bin/
+       include/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*[usb?,bluetooth?,${MULTILIB_USEDEP}]
+       ssl? ( dev-libs/openssl:0= )
+       kerberos? ( virtual/krb5 )
+       ar? ( >=app-arch/libarchive-3 )
+       virtual/pam
+       sys-libs/zlib
+       >=sys-libs/ncurses-5.9:0=
+       !sys-process/fuser-bsd
+       !dev-util/csup
+       !dev-libs/libiconv
+       !sys-freebsd/freebsd-contrib"
+
+DEPEND="${RDEPEND}
+       sys-devel/flex
+       !build? ( =sys-freebsd/freebsd-sources-${RV}* )
+       =sys-freebsd/freebsd-sbin-${RV}*
+       =sys-freebsd/freebsd-mk-defs-${RV}*"
+
+RDEPEND="${RDEPEND}
+       >=sys-auth/pambase-20080219.1
+       sys-process/cronbase"
+
+S="${WORKDIR}/usr.bin"
+
+PATCHES=( "${FILESDIR}/${PN}-6.0-bsdcmp.patch"
+       "${FILESDIR}/${PN}-9.0-fixmakefiles.patch"
+       "${FILESDIR}/${PN}-11.0-setXid.patch"
+       "${FILESDIR}/${PN}-lint-stdarg.patch"
+       "${FILESDIR}/${PN}-9.1-bsdar.patch"
+       "${FILESDIR}/${PN}-9.1-minigzip.patch"
+       "${FILESDIR}/${PN}-10.0-dtc-gcc46.patch"
+       "${FILESDIR}/${PN}-10.2-talk-workaround.patch"
+       "${FILESDIR}/${PN}-10.2-bsdxml.patch" )
+
+# Here we remove some sources we don't need because they are already
+# provided by portage's packages or similar. In order:
+# - Archiving tools, provided by their own ebuilds
+# - ncurses stuff
+# - less stuff
+# - bind utils
+# - rsh stuff
+# - binutils gprof
+# - dc stuff
+# and the rest are misc utils we already provide somewhere else.
+REMOVE_SUBDIRS="bzip2 bzip2recover tar cpio
+       gzip gprof
+       lzmainfo xz xzdec
+       unzip
+       tput tset tabs
+       less lessecho lesskey
+       hesinfo host
+       rsh rlogin rusers rwho ruptime
+       compile_et lex vi smbutil file vacation nc ftp telnet
+       c99 c89
+       bc dc
+       whois tftp man
+       addr2line bsdcat cxxfilt cxxfilt elfcopy nm readelf sdiff size soelim 
strings"
+
+pkg_setup() {
+       # Add the required source files.
+       use zfs && EXTRACTONLY+="cddl/ "
+       use build && EXTRACTONLY+="sys/ "
+
+       use atm || mymakeopts="${mymakeopts} WITHOUT_ATM= "
+       use audit || mymakeopts="${mymakeopts} WITHOUT_AUDIT= "
+       use bluetooth || mymakeopts="${mymakeopts} WITHOUT_BLUETOOTH= "
+       use ipv6 || mymakeopts="${mymakeopts} WITHOUT_INET6= 
WITHOUT_INET6_SUPPORT= "
+       use kerberos || mymakeopts="${mymakeopts} WITHOUT_KERBEROS_SUPPORT= "
+       use netware || mymakeopts="${mymakeopts} WITHOUT_IPX= 
WITHOUT_IPX_SUPPORT= WITHOUT_NCP= "
+       use nis || mymakeopts="${mymakeopts} WITHOUT_NIS= "
+       use ssl || mymakeopts="${mymakeopts} WITHOUT_OPENSSL= "
+       use usb || mymakeopts="${mymakeopts} WITHOUT_USB= "
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_CDDL= "
+       mymakeopts="${mymakeopts} WITHOUT_CLANG= WITHOUT_LZMA_SUPPORT= 
WITHOUT_SVN= WITHOUT_SVNLITE= WITHOUT_OPENSSH= WITHOUT_LDNS_UTILS= 
WITHOUT_MANDOCDB= "
+}
+
+pkg_preinst() {
+       # bison installs a /usr/bin/yacc symlink ...
+       # we need to remove it to avoid triggering
+       # collision-protect errors
+       if [[ -L ${ROOT}/usr/bin/yacc ]] ; then
+               rm -f "${ROOT}"/usr/bin/yacc
+       fi
+}
+
+src_prepare() {
+       if [[ ! -e "${WORKDIR}/sys" ]]; then
+               use build || ln -s "/usr/src/sys" "${WORKDIR}/sys"
+       fi
+
+       # Rename manpage for renamed cmp
+       mv "${S}"/cmp/cmp.1 "${S}"/cmp/bsdcmp.1 || die
+       # Rename manpage for renamed ar
+       mv "${S}"/ar/ar.1 "${S}"/ar/freebsd-ar.1 || die
+       # Fix whereis(1) manpath search.
+       sed -i -e 's:"manpath -q":"manpath":' "${S}/whereis/pathnames.h"
+
+       # Build a dynamic make
+       sed -i -e '/^NO_SHARED/ s/^/#/' "${S}"/bmake/Makefile.inc || die
+
+       # Disable it here otherwise our patch wont apply
+       use ar || dummy_mk ar
+
+       # Preparing to build xlint
+       export LINT=xlint
+}
+
+setup_multilib_vars() {
+       if ! multilib_is_native_abi ; then
+               cd "${WORKDIR}/usr.bin/ldd" || die
+               export mymakeopts="${mymakeopts} PROG=ldd32 WITHOUT_MAN="
+       else
+               cd "${S}" || die
+       fi
+       "$@"
+}
+
+src_compile() {
+       # Preparing to build addr2line, elfcopy, m4
+       for dir in libelftc libpe libopenbsd ; do
+               cd "${WORKDIR}/lib/${dir}" || die
+               freebsd_src_compile -j1
+       done
+
+       local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+       multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
setup_multilib_vars freebsd_src_compile -j1
+}
+
+src_install() {
+       cd "${S}"/calendar/calendars || die
+       for dir in $(find . -type d ! -name "." ) ; do
+               dodir /usr/share/calendar/"$(basename ${dir})"
+       done
+
+       local MULTIBUILD_VARIANTS=( $(multilib_get_enabled_abis) )
+       multibuild_foreach_variant freebsd_multilib_multibuild_wrapper 
setup_multilib_vars freebsd_src_install
+
+       # baselayout requires these in /bin
+       dodir /bin
+       for bin in sed printf ; do
+               mv "${D}/usr/bin/${bin}" "${D}/bin/" || die "mv ${bin} failed"
+               dosym /bin/${bin} /usr/bin/${bin} || die "dosym ${bin} failed"
+       done
+
+       for pamdfile in login passwd su; do
+               newpamd "${FILESDIR}/${pamdfile}.1.pamd" ${pamdfile} || die
+       done
+
+       cd "${WORKDIR}/etc" || die
+       insinto /etc
+       doins remote phones opieaccess fbtab || die
+
+       exeinto /etc/cron.daily
+       newexe "${FILESDIR}/locate-updatedb-cron" locate.updatedb || die
+
+       # tip requires /var/spool/lock/, bug #200700
+       keepdir /var/spool/lock
+
+       # create locate database #472468
+       local f=/var/db/locate.database
+       mkdir "${ED}${f%/*}" || die
+       touch "${ED}${f}" || die
+       fowners nobody:nobody ${f}
+}
+
+pkg_postinst() {
+       # We need to ensure that login.conf.db is up-to-date.
+       if [[ -e "${ROOT}"etc/login.conf ]] ; then
+               einfo "Updating ${ROOT}etc/login.conf.db"
+               "${ROOT}"usr/bin/cap_mkdb       -f "${ROOT}"etc/login.conf 
"${ROOT}"etc/login.conf
+               elog "Remember to run cap_mkdb /etc/login.conf after making 
changes to it"
+       fi
+}
+
+pkg_postrm() {
+       # and if we uninstall yacc but keep bison,
+       # lets restore the /usr/bin/yacc symlink
+       if [[ ! -e ${ROOT}/usr/bin/yacc ]] && [[ -e ${ROOT}/usr/bin/yacc.bison 
]] ; then
+               ln -s yacc.bison "${ROOT}"/usr/bin/yacc
+       fi
+}

diff --git a/sys-freebsd/freebsd-usbin/Manifest 
b/sys-freebsd/freebsd-usbin/Manifest
index 455eb71..a566584 100644
--- a/sys-freebsd/freebsd-usbin/Manifest
+++ b/sys-freebsd/freebsd-usbin/Manifest
@@ -13,6 +13,7 @@ DIST freebsd-libexec-9.1.tar.bz2 304592 SHA256 
71e6e9e41328c2148c54b81ad9b59f912
 DIST freebsd-sbin-8.2.tar.bz2 1211665 SHA256 
8b7e21a66b4696e8763d29b8b02b2d35f29fc51820a194d1e469e7cace84c527 SHA512 
c6643c29ab62344c98d8991708798730ee1c17e6478071718beeaa79788300a1f4ed2e6aeb8e39e3c216877d4ed2ac85b2a9531d534f1ac5125a508927898959
 WHIRLPOOL 
2a21cd0f15f95d66718031680ac87f1fe73f1e1b03cb012e1db1dd1bd2fe2bb7897457a8ba2f5a28c8806775611dca542cbadec16566c47ab9efa673e2cb53f3
 DIST freebsd-sbin-9.1.tar.bz2 1273913 SHA256 
45008b0733b232ef03707ef5fa3e5c889e3b3728393d736bd9a869ea83be6447 SHA512 
9f186602b7de96f268c352ca386986652fddf5570e7eca1afa8c0d2bdc83b57df1198efe47f36dd5c7a6abf4f9c935f1c8207a4a12a6b2153bd6c3c6292719dc
 WHIRLPOOL 
20920dfa9607a0ce854319cef29bbd77fb1b31f6f6cfd5ac60cbd678169e43929e215743fe636d0c224443f3e6149a8f07c292d647f7f901592795ac292699f9
 DIST freebsd-src-10.3.tar.xz 126900216 SHA256 
f50763dcac88e9b7ec616b77d537bf338f470350e2c85e0cc7decfcc8372b54d SHA512 
a0c95fc4bbc5ad7599d0a83651a497e85cd85a5c433e5e175c57480b466c9eb5aa0390804d6336da8301c75ad499484399d39b8f7efbcfda8cafb09b1aa12d8f
 WHIRLPOOL 
bf5320bc506fb73a63d0fb324b60667a196ca2fef5d0215637a657c613f2052d76d002deb205e258f6d4e2aaea15490b26679e59a102606a34b58ab1f6b755ad
+DIST freebsd-src-11.0.tar.xz 140252356 SHA256 
0725a7f1d3e8985f4b2e31a2ad714334463a5016b203073a8fc196649f3d5a27 SHA512 
ee1271bb38ee46fbab3d49b33f5b5afd76f9402b2e792581d63f02272df8e2a4011fac97ad550434f0c2fc5fe241940276629bde55e75f8638896a81339870cd
 WHIRLPOOL 
e1cda77189990c1d2187ab2d9e842ff3c619d8235f1ade56819fadc52f680a871de17cf05f8119614557c615ad19d41d1b6080c4b3768e7252889546b865d827
 DIST freebsd-sys-8.2.tar.bz2 25835329 SHA256 
0c6c7b61aae94db2931f985d5899f3bca78fc8ffab6b598fbaa158142d676f16 SHA512 
6ea4516a5c52e25c4f993f7acb875463a5caea93dbdf250c5d48eee95fff226956e9f030cab7e341b5e6a132325bc3dbf93dcb4b1185acb011918e50b1a22be3
 WHIRLPOOL 
870deeff877c6b9fc812a4260e4fdbb6715a5dc2065cab3bfbf2a42d876f6654703ccb124275a4e2c410cef48f3db02b63cc76059eccf9cf90244826f35b7a15
 DIST freebsd-sys-9.1.tar.bz2 32588103 SHA256 
b93a7ac8334ac16cc9f60665048e5ef812c0a6c62f10d0b0a674aec3f56516a8 SHA512 
7dc9d9e00dde8f592bb171f4386d02b655b73cb4f153fe5ec063d010a148ef0639eae0dcdb3eeb09ecd1e3653c69e49a2d261329fa6d0381d2ddabe258ddde6d
 WHIRLPOOL 
c8348344dfb14bad64bd3a78ee615ddd29203175b292233254f8ba175e7a3fb7218af6f95f7b4dbf394c0354bafe9d8bb0c21cdf0ceaeb697214964b280469b3
 DIST freebsd-ubin-8.2.tar.bz2 1808012 SHA256 
6b99554f3ad6ee052069b347eb6e6219b71598d7b222acb90a24cbfc805c7b68 SHA512 
48d0103323e820c431aa4f62d3be40cb3b200fb62e3de01f36c88760395bf2ba3367c51f3fa72da4dbccc2812176a051a12ca5cb7e84125c3e0fc78d4cab2c29
 WHIRLPOOL 
ea8f3a29a37b42c2b5bcc0f2c343fa1538522157ef075363c94606a4620a590e9a03f856ce2494e3e727935b62431991d0aa9fde71de699e78b4fe225bdf1c2c

diff --git 
a/sys-freebsd/freebsd-usbin/files/freebsd-usbin-11.0-workaround.patch 
b/sys-freebsd/freebsd-usbin/files/freebsd-usbin-11.0-workaround.patch
new file mode 100644
index 00000000..04ba75a
--- /dev/null
+++ b/sys-freebsd/freebsd-usbin/files/freebsd-usbin-11.0-workaround.patch
@@ -0,0 +1,13 @@
+diff --git a/usr.sbin/nmtree/Makefile b/usr.sbin/nmtree/Makefile
+index 033002c..d198f10 100644
+--- a/usr.sbin/nmtree/Makefile
++++ b/usr.sbin/nmtree/Makefile
+@@ -5,7 +5,7 @@
+ .PATH: ${.CURDIR}/../../contrib/mtree
+ 
+ PROG=         mtree
+-MAN=          mtree.5 mtree.8
++MAN=          mtree.8
+ SRCS=         compare.c crc.c create.c excludes.c getid.c misc.c mtree.c \
+               only.c spec.c specspec.c verify.c
+ 

diff --git a/sys-freebsd/freebsd-usbin/freebsd-usbin-11.0.ebuild 
b/sys-freebsd/freebsd-usbin/freebsd-usbin-11.0.ebuild
new file mode 100644
index 00000000..31ca603
--- /dev/null
+++ b/sys-freebsd/freebsd-usbin/freebsd-usbin-11.0.ebuild
@@ -0,0 +1,186 @@
+# Copyright 1999-2016 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+EAPI=5
+
+inherit bsdmk freebsd flag-o-matic eutils
+
+DESCRIPTION="FreeBSD /usr/sbin tools"
+SLOT="0"
+LICENSE="BSD zfs? ( CDDL )"
+
+if [[ ${PV} != *9999* ]]; then
+       KEYWORDS="~amd64-fbsd ~sparc-fbsd ~x86-fbsd"
+       SRC_URI="${SRC_URI}
+               $(freebsd_upstream_patches)"
+fi
+
+EXTRACTONLY="
+       usr.sbin/
+       contrib/
+       usr.bin/
+       lib/
+       sbin/
+       etc/
+       gnu/
+"
+
+RDEPEND="=sys-freebsd/freebsd-lib-${RV}*[usb?,bluetooth?,netware?]
+       =sys-freebsd/freebsd-libexec-${RV}*
+       build? ( sys-apps/baselayout )
+       ssl? ( dev-libs/openssl:0 )
+       >=app-arch/libarchive-3
+       sys-apps/tcp-wrappers
+       dev-util/dialog
+       >=dev-libs/libedit-20120311.3.0-r1
+       net-libs/libpcap
+       kerberos? ( app-crypt/heimdal )"
+DEPEND="${RDEPEND}
+       =sys-freebsd/freebsd-mk-defs-${RV}*
+       =sys-freebsd/freebsd-ubin-${RV}*
+       zfs? ( =sys-freebsd/freebsd-cddl-${RV}* )
+       !build? ( =sys-freebsd/freebsd-sources-${RV}* )
+       sys-apps/texinfo
+       sys-devel/flex"
+
+S="${WORKDIR}/usr.sbin"
+
+IUSE="acpi atm audit bluetooth floppy ipv6 kerberos minimal netware nis pam 
ssl usb build zfs"
+
+pkg_setup() {
+       # Add the required source files.
+       use nis && EXTRACTONLY+="libexec/ "
+       use build && EXTRACTONLY+="sys/ include/ "
+       use zfs && EXTRACTONLY+="cddl/ "
+
+       # Release crunch is something like minimal. It seems to remove 
everything
+       # which is not needed to work.
+       use minimal && mymakeopts="${mymakeopts} RELEASE_CRUNCH= "
+
+       use acpi || mymakeopts="${mymakeopts} WITHOUT_ACPI= "
+       use atm || mymakeopts="${mymakeopts} WITHOUT_ATM= "
+       use audit || mymakeopts="${mymakeopts} WITHOUT_AUDIT= "
+       use bluetooth || mymakeopts="${mymakeopts} WITHOUT_BLUETOOTH= "
+       use ipv6 || mymakeopts="${mymakeopts} WITHOUT_INET6= 
WITHOUT_INET6_SUPPORT= "
+       use netware || mymakeopts="${mymakeopts} WITHOUT_IPX= 
WITHOUT_IPX_SUPPORT= WITHOUT_NCP= "
+       use nis || mymakeopts="${mymakeopts} WITHOUT_NIS= "
+       use pam || mymakeopts="${mymakeopts} WITHOUT_PAM_SUPPORT= "
+       use ssl || mymakeopts="${mymakeopts} WITHOUT_OPENSSL= "
+       use usb || mymakeopts="${mymakeopts} WITHOUT_USB= "
+       use floppy || mymakeopts="${mymakeopts} WITHOUT_FLOPPY= "
+       use kerberos || mymakeopts="${mymakeopts} WITHOUT_GSSAPI= "
+       use zfs || mymakeopts="${mymakeopts} WITHOUT_CDDL= "
+
+       mymakeopts="${mymakeopts} WITHOUT_PF= WITHOUT_LPR= WITHOUT_SENDMAIL= 
WITHOUT_AUTHPF= WITHOUT_MAILWRAPPER= WITHOUT_UNBOUND= "
+
+       append-flags $(test-flags -fno-strict-aliasing)
+}
+
+PATCHES=(
+       "${FILESDIR}/${PN}-adduser.patch"
+       "${FILESDIR}/${PN}-9.0-newsyslog.patch"
+       "${FILESDIR}/${PN}-10.0-bsdxml2expat.patch"
+       "${FILESDIR}/${PN}-10.3-bsdxml2expat.patch"
+       "${FILESDIR}/${PN}-11.0-workaround.patch"
+       )
+
+REMOVE_SUBDIRS="
+       tcpdchk tcpdmatch
+       sendmail praliases editmap mailstats makemap
+       pc-sysinstall cron mailwrapper ntp bsnmpd
+       tcpdump ndp inetd
+       wpa/wpa_supplicant wpa/hostapd wpa/hostapd_cli wpa/wpa_cli 
wpa/wpa_passphrase
+       zic amd
+       pkg freebsd-update service sysrc bsdinstall"
+
+src_prepare() {
+       if ! use build; then
+               [[ ! -e "${WORKDIR}/sys" ]] && ln -s "/usr/src/sys" 
"${WORKDIR}/sys"
+               [[ ! -e "${WORKDIR}/include" ]] && ln -s "/usr/include" 
"${WORKDIR}/include"
+       else
+               dummy_mk mount_smbfs
+       fi
+}
+
+src_compile() {
+       # Preparing to build nmtree
+       cd "${WORKDIR}/lib/libnetbsd" || die
+       freebsd_src_compile
+
+       cd "${S}" || die
+       freebsd_src_compile
+}
+
+src_install() {
+       # By creating these directories we avoid having to do a
+       # more complex hack
+       dodir /usr/share/doc
+       dodir /sbin
+       dodir /usr/libexec
+       dodir /usr/bin
+
+       # FILESDIR is used by some makefiles which will install files
+       # in the wrong place, just put it in the doc directory.
+       freebsd_src_install DOCDIR=/usr/share/doc/${PF}
+
+       # Most of these now come from openrc.
+       for util in iscsid nfs nfsuserd rpc.statd rpc.lockd; do
+               newinitd "${FILESDIR}/"${util}.initd ${util} || die
+               if [[ -e "${FILESDIR}"/${util}.confd ]]; then \
+                       newconfd "${FILESDIR}"/${util}.confd ${util} || die
+               fi
+       done
+
+       for class in daily monthly weekly; do
+               cat - > "${T}/periodic.${class}" <<EOS
+#!/bin/sh
+/usr/sbin/periodic ${class}
+EOS
+               exeinto /etc/cron.${class}
+               newexe "${T}/periodic.${class}" periodic
+       done
+
+       # Install the pw.conf file to let pw use Gentoo's skel location
+       insinto /etc
+       doins "${FILESDIR}/pw.conf" || die
+
+       cd "${WORKDIR}/etc" || die
+       doins apmd.conf syslog.conf newsyslog.conf nscd.conf || die
+
+       if use bluetooth; then
+               insinto /etc/bluetooth
+               doins bluetooth/* || die
+               rm -f "${D}"/etc/bluetooth/Makefile
+       fi
+
+       cd "${S}"/ppp || die
+       insinto /etc/ppp
+       doins ppp.conf || die
+
+       # Install the periodic stuff (needs probably to be ported in a more
+       # gentooish way)
+       cd "${WORKDIR}/etc/periodic" || die
+
+       doperiodic daily daily/*.accounting
+       doperiodic monthly monthly/*.accounting
+}
+
+pkg_postinst() {
+       # We need to run pwd_mkdb if key files are not present
+       # If they are, then there is no need to run pwd_mkdb
+       if [[ ! -e "${ROOT}etc/passwd" || ! -e "${ROOT}etc/pwd.db" || ! -e 
"${ROOT}etc/spwd.db" ]] ; then
+               if [[ -e "${ROOT}etc/master.passwd" ]] ; then
+                       einfo "Generating passwd files from 
${ROOT}etc/master.passwd"
+                       "${ROOT}"usr/sbin/pwd_mkdb -p -d "${ROOT}etc" 
"${ROOT}etc/master.passwd"
+               else
+                       eerror "${ROOT}etc/master.passwd does not exist!"
+                       eerror "You will no be able to log into your system!"
+               fi
+       fi
+
+       for logfile in messages security auth.log maillog lpd-errs xferlog cron 
\
+               debug.log slip.log ppp.log; do
+               [[ -f "${ROOT}/var/log/${logfile}" ]] || touch 
"${ROOT}/var/log/${logfile}"
+       done
+}

Reply via email to