summaryrefslogtreecommitdiffstats
path: root/meta-oe/recipes-support/nss/nss_3.119.bb
diff options
context:
space:
mode:
authorWang Mingyu <wangmy@fujitsu.com>2025-12-09 17:55:28 +0800
committerKhem Raj <raj.khem@gmail.com>2025-12-09 15:11:00 -0800
commit1645c5e5187e4611c0e6c151f31ee8ecef71456c (patch)
tree94604e347e03e1256394f536b9f0dbcf30966150 /meta-oe/recipes-support/nss/nss_3.119.bb
parent573a77680e8c2ac43eb5827be040bc8e3e21f954 (diff)
downloadmeta-openembedded-1645c5e5187e4611c0e6c151f31ee8ecef71456c.tar.gz
nss: upgrade 3.118.1 -> 3.119
Signed-off-by: Wang Mingyu <wangmy@fujitsu.com> Signed-off-by: Khem Raj <raj.khem@gmail.com>
Diffstat (limited to 'meta-oe/recipes-support/nss/nss_3.119.bb')
-rw-r--r--meta-oe/recipes-support/nss/nss_3.119.bb291
1 files changed, 291 insertions, 0 deletions
diff --git a/meta-oe/recipes-support/nss/nss_3.119.bb b/meta-oe/recipes-support/nss/nss_3.119.bb
new file mode 100644
index 0000000000..a0345eb8aa
--- /dev/null
+++ b/meta-oe/recipes-support/nss/nss_3.119.bb
@@ -0,0 +1,291 @@
1SUMMARY = "Mozilla's SSL and TLS implementation"
2DESCRIPTION = "Network Security Services (NSS) is a set of libraries \
3designed to support cross-platform development of \
4security-enabled client and server applications. \
5Applications built with NSS can support SSL v2 and v3, \
6TLS, PKCS 5, PKCS 7, PKCS 11, PKCS 12, S/MIME, X.509 \
7v3 certificates, and other security standards."
8HOMEPAGE = "https://firefox-source-docs.mozilla.org/security/nss/index.html"
9SECTION = "libs"
10
11DEPENDS = "sqlite3 nspr zlib nss-native"
12DEPENDS:class-native = "sqlite3-native nspr-native zlib-native"
13
14LICENSE = "(MPL-2.0 & MIT) | (MPL-2.0 & GPL-2.0-or-later & MIT) | (MPL-2.0 & LGPL-2.1-or-later & MIT)"
15
16LIC_FILES_CHKSUM = "file://nss/COPYING;md5=3b1e88e1b9c0b5a4b2881d46cce06a18 \
17 file://nss/lib/freebl/mpi/doc/LICENSE;md5=491f158d09d948466afce85d6f1fe18f \
18 file://nss/lib/freebl/mpi/doc/LICENSE-MPL;md5=5d425c8f3157dbf212db2ec53d9e5132 \
19 file://nss/lib/freebl/verified/Hacl_Poly1305_256.c;beginline=1;endline=22;md5=cc22f07b95d28d56baeb757df46ee7c8"
20
21VERSION_DIR = "${@d.getVar('BP').upper().replace('-', '_').replace('.', '_') + '_RTM'}"
22
23SRC_URI = "https://ftp.mozilla.org/pub/security/nss/releases/${VERSION_DIR}/src/${BP}.tar.gz \
24 file://nss.pc.in \
25 file://blank-cert9.db \
26 file://blank-key4.db \
27 file://system-pkcs11.txt \
28 file://0001-nss-fix-support-cross-compiling.patch \
29 file://0002-nss-no-rpath-for-cross-compiling.patch \
30 file://0003-nss-fix-incorrect-shebang-of-perl.patch \
31 file://0004-nss-disable-Wvarargs-with-clang.patch \
32 file://0005-nss-does-not-build-on-mips-with-clang-because-wrong-.patch \
33 file://0006-Fix-nss-multilib-build-on-openSUSE-11.x-32bit.patch \
34 file://0007-freebl-add-a-configure-option-to-disable-ARM-HW-cryp.patch \
35 "
36SRC_URI[sha256sum] = "e8412db6c9d6f531e8adfe8a122ec33a8fae920681ff47231a1349bdd399f0e9"
37
38UPSTREAM_CHECK_URI = "https://ftp.mozilla.org/pub/security/nss/releases/"
39UPSTREAM_CHECK_REGEX = "NSS_(?P<pver>\d+(\_\d+)+)"
40
41inherit siteinfo
42
43TD = "${S}/tentative-dist"
44TDS = "${S}/tentative-dist-staging"
45
46TARGET_CC_ARCH += "${LDFLAGS}"
47
48CFLAGS:append:class-native = " -D_XOPEN_SOURCE "
49
50do_configure:prepend:libc-musl () {
51 sed -i -e '/-DHAVE_SYS_CDEFS_H/d' ${S}/nss/lib/dbm/config/config.mk
52}
53
54do_configure:prepend:powerpc64le:toolchain-clang () {
55 sed -i -e 's/\-std=c99/\-std=gnu99/g' ${S}/nss/coreconf/command.mk
56}
57
58do_configure:prepend:powerpc64:toolchain-clang () {
59 sed -i -e 's/\-std=c99/\-std=gnu99/g' ${S}/nss/coreconf/command.mk
60}
61
62do_compile:prepend:class-native() {
63 export NSPR_INCLUDE_DIR=${STAGING_INCDIR_NATIVE}/nspr
64 export NSPR_LIB_DIR=${STAGING_LIBDIR_NATIVE}
65}
66
67do_compile:prepend:class-nativesdk() {
68 export LDFLAGS=""
69}
70
71do_compile:prepend:class-native() {
72 # Need to set RPATH so that chrpath will do its job correctly
73 RPATH="-Wl,-rpath-link,${STAGING_LIBDIR_NATIVE} -Wl,-rpath-link,${STAGING_BASE_LIBDIR_NATIVE} -Wl,-rpath,${STAGING_LIBDIR_NATIVE} -Wl,-rpath,${STAGING_BASE_LIBDIR_NATIVE}"
74}
75
76NATIVE_CC:class-target:toolchain-clang = "clang --rtlib=libgcc --unwindlib=libgcc"
77NATIVE_CC:class-nativesdk:toolchain-clang = "clang --rtlib=libgcc --unwindlib=libgcc"
78NATIVE_CC ?= "${BUILD_CC}"
79
80do_compile() {
81 export NSPR_INCLUDE_DIR=${STAGING_INCDIR}/nspr
82
83 export CROSS_COMPILE=1
84 export NATIVE_CC="${NATIVE_CC}"
85 # Additional defines needed on Centos 7
86 export NATIVE_FLAGS="${BUILD_CFLAGS} -DLINUX -Dlinux"
87 export BUILD_OPT=1
88
89 # POSIX.1-2001 states that the behaviour of getcwd() when passing a null
90 # pointer as the buf argument, is unspecified.
91 export NATIVE_FLAGS="${NATIVE_FLAGS} -DGETCWD_CANT_MALLOC"
92
93 export FREEBL_NO_DEPEND=1
94 export FREEBL_LOWHASH=1
95
96 export LIBDIR=${libdir}
97 export MOZILLA_CLIENT=1
98 export NSS_USE_SYSTEM_SQLITE=1
99 export NSS_ENABLE_ECC=1
100 export NSS_ENABLE_WERROR=0
101
102 ${@bb.utils.contains("TUNE_FEATURES", "crypto", "export NSS_USE_ARM_HW_CRYPTO=1", "", d)}
103
104 export OS_RELEASE=3.4
105 export OS_TARGET=Linux
106 export OS_ARCH=Linux
107
108 if [ "${TARGET_ARCH}" = "powerpc" ]; then
109 OS_TEST=ppc
110 elif [ "${TARGET_ARCH}" = "powerpc64" -o "${TARGET_ARCH}" = "powerpc64le" ]; then
111 OS_TEST=ppc64
112 elif [ "${TARGET_ARCH}" = "mips" -o "${TARGET_ARCH}" = "mipsel" -o "${TARGET_ARCH}" = "mips64" -o "${TARGET_ARCH}" = "mips64el" ]; then
113 OS_TEST=mips
114 elif [ "${TARGET_ARCH}" = "aarch64_be" ]; then
115 OS_TEST="aarch64"
116 else
117 OS_TEST="${TARGET_ARCH}"
118 fi
119
120 if [ "${SITEINFO_BITS}" = "64" ]; then
121 export USE_64=1
122 elif [ "${TARGET_ARCH}" = "x86_64" -a "${SITEINFO_BITS}" = "32" ]; then
123 export USE_X32=1
124 fi
125
126 export NSS_DISABLE_GTESTS=1
127 # We can modify CC in the environment, but if we set it via an
128 # argument to make, nsinstall, a host program, will also build with it!
129 #
130 # nss pretty much does its own thing with CFLAGS, so we put them into CC.
131 # Optimization will get clobbered, but most of the stuff will survive.
132 # The motivation for this is to point to the correct place for debug
133 # source files and CFLAGS does that. Nothing uses CCC.
134 #
135 export CC="${CC} ${CFLAGS}"
136 make -C ./nss CCC="${CXX} -g" \
137 OS_TEST=${OS_TEST} \
138 RPATH="${RPATH}" \
139 autobuild
140}
141
142do_compile[vardepsexclude] += "SITEINFO_BITS"
143
144do_install:prepend:class-nativesdk() {
145 export LDFLAGS=""
146}
147
148do_install() {
149 export CROSS_COMPILE=1
150 export NATIVE_CC="${NATIVE_CC}"
151 export BUILD_OPT=1
152
153 export FREEBL_NO_DEPEND=1
154
155 export LIBDIR=${libdir}
156 export MOZILLA_CLIENT=1
157 export NSS_USE_SYSTEM_SQLITE=1
158 export NSS_ENABLE_ECC=1
159
160 export OS_RELEASE=3.4
161 export OS_TARGET=Linux
162 export OS_ARCH=Linux
163
164 if [ "${TARGET_ARCH}" = "powerpc" ]; then
165 OS_TEST=ppc
166 elif [ "${TARGET_ARCH}" = "powerpc64" -o "${TARGET_ARCH}" = "powerpc64le" ]; then
167 OS_TEST=ppc64
168 elif [ "${TARGET_ARCH}" = "mips" -o "${TARGET_ARCH}" = "mipsel" -o "${TARGET_ARCH}" = "mips64" -o "${TARGET_ARCH}" = "mips64el" ]; then
169 OS_TEST=mips
170 elif [ "${TARGET_ARCH}" = "aarch64_be" ]; then
171 CPU_ARCH=aarch64
172 OS_TEST="aarch64"
173 else
174 OS_TEST="${TARGET_ARCH}"
175 fi
176 if [ "${SITEINFO_BITS}" = "64" ]; then
177 export USE_64=1
178 elif [ "${TARGET_ARCH}" = "x86_64" -a "${SITEINFO_BITS}" = "32" ]; then
179 export USE_X32=1
180 fi
181
182 export NSS_DISABLE_GTESTS=1
183
184 make -C ./nss \
185 CCC="${CXX}" \
186 OS_TEST=${OS_TEST} \
187 SOURCE_LIB_DIR="${TD}/${libdir}" \
188 SOURCE_BIN_DIR="${TD}/${bindir}" \
189 install
190
191 install -d ${D}/${libdir}/
192 for file in ${S}/dist/*.OBJ/lib/*.so; do
193 echo "Installing `basename $file`..."
194 cp $file ${D}/${libdir}/
195 done
196
197 for shared_lib in ${TD}/${libdir}/*.so.*; do
198 if [ -f $shared_lib ]; then
199 cp $shared_lib ${D}/${libdir}
200 ln -sf $(basename $shared_lib) ${D}/${libdir}/$(basename $shared_lib .1oe)
201 fi
202 done
203 for shared_lib in ${TD}/${libdir}/*.so; do
204 if [ -f $shared_lib -a ! -e ${D}/${libdir}/$shared_lib ]; then
205 cp $shared_lib ${D}/${libdir}
206 fi
207 done
208
209 install -d ${D}/${includedir}/nss3
210 install -m 644 -t ${D}/${includedir}/nss3 dist/public/nss/*
211
212 install -d ${D}/${bindir}
213 for binary in ${TD}/${bindir}/*; do
214 install -m 755 -t ${D}/${bindir} $binary
215 done
216}
217
218do_install[vardepsexclude] += "SITEINFO_BITS"
219
220do_install:append() {
221 # Create empty .chk files for the NSS libraries at build time. They could
222 # be regenerated at target's boot time.
223 for file in libsoftokn3.chk libfreebl3.chk libnssdbm3.chk; do
224 touch ${D}/${libdir}/$file
225 chmod 755 ${D}/${libdir}/$file
226 done
227
228 install -d ${D}${libdir}/pkgconfig/
229 sed 's/%NSS_VERSION%/${PV}/' ${UNPACKDIR}/nss.pc.in | sed 's/%NSPR_VERSION%/4.9.2/' > ${D}${libdir}/pkgconfig/nss.pc
230 sed -i s:OEPREFIX:${prefix}:g ${D}${libdir}/pkgconfig/nss.pc
231 sed -i s:OEEXECPREFIX:${exec_prefix}:g ${D}${libdir}/pkgconfig/nss.pc
232 sed -i s:OELIBDIR:${libdir}:g ${D}${libdir}/pkgconfig/nss.pc
233 sed -i s:OEINCDIR:${includedir}/nss3:g ${D}${libdir}/pkgconfig/nss.pc
234}
235
236do_install:append:class-target() {
237 # It used to call certutil to create a blank certificate with empty password at
238 # build time, but the checksum of key4.db changes every time when certutil is called.
239 # It causes non-determinism issue, so provide databases with a blank certificate
240 # which are originally from output of nss in qemux86-64 build. You can get these
241 # databases by:
242 # certutil -N -d sql:/database/path/ --empty-password
243 install -d ${D}${sysconfdir}/pki/nssdb/
244 install -m 0644 ${UNPACKDIR}/blank-cert9.db ${D}${sysconfdir}/pki/nssdb/cert9.db
245 install -m 0644 ${UNPACKDIR}/blank-key4.db ${D}${sysconfdir}/pki/nssdb/key4.db
246 install -m 0644 ${UNPACKDIR}/system-pkcs11.txt ${D}${sysconfdir}/pki/nssdb/pkcs11.txt
247}
248
249PACKAGE_WRITE_DEPS += "nss-native"
250
251pkg_postinst:${PN} () {
252 for I in $D${libdir}/lib*.chk; do
253 DN=`dirname $I`
254 BN=`basename $I .chk`
255 FN=$DN/$BN.so
256 shlibsign -i $FN
257 if [ $? -ne 0 ]; then
258 echo "shlibsign -i $FN failed"
259 fi
260 done
261}
262
263PACKAGES =+ "${PN}-smime"
264FILES:${PN}-smime = "\
265 ${bindir}/smime \
266"
267
268FILES:${PN} = "\
269 ${sysconfdir} \
270 ${bindir} \
271 ${libdir}/lib*.chk \
272 ${libdir}/lib*.so \
273 "
274
275FILES:${PN}-dev = "\
276 ${libdir}/nss \
277 ${libdir}/pkgconfig/* \
278 ${includedir}/* \
279 "
280
281RDEPENDS:${PN}-smime = "perl"
282
283BBCLASSEXTEND = "native nativesdk"
284
285CVE_PRODUCT += "network_security_services"
286
287CVE_STATUS_GROUPS += "CVE_STATUS_NSS"
288CVE_STATUS_NSS[status] = "not-applicable-config: This only affect the legacy db (libnssdbm), only compiled with --enable-legacy-db"
289CVE_STATUS_NSS = "CVE-2017-11695 CVE-2017-11696 CVE-2017-11697 CVE-2017-11698"
290
291CVE_STATUS[CVE-2022-3479] = "not-applicable-config: vulnerability was introduced in 3.77 and fixed in 3.87"