Date: Fri, 27 Mar 2015 05:50:31 -0700 From: Mark Millard <markmi@dsl-only.net> To: freebsd-current@freebsd.org, jkim@FreeBSD.org Cc: FreeBSD PowerPC ML <freebsd-ppc@freebsd.org> Subject: 11.0-CURRENT: DTLS1_VERSION_MAJOR, /head/crypto/openssl/ssl/ssl_asn1.c -r280297 vs. updating to head snaphot -r280598 Message-ID: <CF6F193D-0612-491E-BBAD-970E460E6102@dsl-only.net> In-Reply-To: <2D2B8572-425D-42EC-AD9D-8975E9B9CBFA@dsl-only.net> References: <24B7C687-9147-42F1-AE49-92F93DC85AA8@dsl-only.net> <2D2B8572-425D-42EC-AD9D-8975E9B9CBFA@dsl-only.net>
next in thread | previous in thread | raw e-mail | index | archive | help
/head/crypto/openssl/ssl/ssl_asn1.c has a similar issue to = /head/crypto/openssl/crypto/bio/bio_err.c but relative to: > /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc -fpic -DPIC -O2 = -pipe -DTERMIOS -DANSI_SOURCE = -I/usr/src/secure/lib/libssl/../../../crypto/openssl = -I/usr/src/secure/lib/libssl/../../../crypto/openssl/crypto = -I/usr/obj/usr/src/secure/lib/libssl -DOPENSSL_THREADS -DDSO_DLFCN = -DHAVE_DLFCN_H -std=3Dgnu99 -fstack-protector -Wno-pointer-sign -c = /usr/src/secure/lib/libssl/../../../crypto/openssl/ssl/ssl_asn1.c -o = ssl_asn1.So > /usr/src/secure/lib/libssl/../../../crypto/openssl/ssl/ssl_asn1.c: In = function 'd2i_SSL_SESSION': > = /usr/src/secure/lib/libssl/../../../crypto/openssl/ssl/ssl_asn1.c:425:34: = error: 'DTLS1_VERSION_MAJOR' undeclared (first use in this function) > || (ssl_version >> 8) =3D=3D DTLS1_VERSION_MAJOR > ^ > # pwd > /usr/src > # find . \( -type d -name .svn -prune \) -or \( -type f -exec grep = DTLS1_VERSION_MAJOR {} \; -print \) | more > # define DTLS1_VERSION_MAJOR 0xFE > ./crypto/openssl/ssl/dtls1.h > || (ssl_version >> 8) =3D=3D DTLS1_VERSION_MAJOR > ./crypto/openssl/ssl/ssl_asn1.c > # find / \( -type d -name .svn -prune \) -or \( -type f -name dtls1.h = -print \) | more > /usr/src/crypto/openssl/ssl/dtls1.h > /usr/obj/usr/src/tmp/usr/include/openssl/dtls1.h > /usr/include/openssl/dtls1.h > #include <stdio.h> > #include <stdlib.h> > #include "ssl_locl.h" > #include <openssl/asn1_mac.h> > #include <openssl/objects.h> > #include <openssl/x509.h> So the crypto/openssl/ssl/dtls1.h or = /usr/obj/usr/src/tmp/usr/include/openssl/dtls1.h file is not directly = included at all. Finding where it is included... Omitting most Makefile lines... > # find . \( -type d -name .svn -prune \) -or \( -type f -exec grep = "dtls1\.h" {} \; -print \) | more > INCS=3D dtls1.h kssl.h srtp.h ssl.h ssl2.h ssl23.h ssl3.h tls1.h > ./secure/lib/libssl/Makefile > ... > ./crypto/openssl/apps/Makefile > /* ssl/dtls1.h */ > ./crypto/openssl/ssl/dtls1.h > ... > ./crypto/openssl/ssl/Makefile > # include <openssl/dtls1.h> /* Datagram TLS */ > ./crypto/openssl/ssl/ssl.h crypto/openssl/ssl/ssl.h is not directly included. (I will stop here as = far as the include sequence goes since a dtls1.h was found.) The <openssl/dtls1.h> reference is finding /usr/include/openssl/dtls1.h = (old) instead of /usr/obj/usr/src/tmp/usr/include/openssl/dtls1.h or = /usr/src/crypto/openssl/ssl/dtls1.h (new): > # diff -w /usr/include/openssl/dtls1.h = /usr/obj/usr/src/tmp/usr/include/openssl/dtls1.h | more > 87a88 > > # define DTLS1_VERSION_MAJOR 0xFE > 123,129c124,128 > ... =3D=3D=3D Mark Millard markmi at dsl-only.net On 2015-Mar-27, at 02:44 AM, Mark Millard <markmi at dsl-only.net> = wrote: Basic context: # freebsd-version -ku; uname -apKU 11.0-CURRENT 11.0-CURRENT FreeBSD FBSDG5C0 11.0-CURRENT FreeBSD 11.0-CURRENT #1 r279514M: Sat Mar = 21 05:15:23 PDT 2015 = root@FBSDG5C0:/usr/obj/usr/srcC/sys/GENERIC64vtsc-NODEBUG powerpc = powerpc64 1100062 1100062 The problem: Summary of the details that are listed later. All of the following = exist: > /usr/src/crypto/openssl/crypto/bio/bio.h > /usr/obj/usr/src/tmp/usr/include/openssl/bio.h > /usr/include/openssl/bio.h The first two can be newer than the last during buildworld. The buildworld compile of /head/crypto/openssl/crypto/bio/bio_err.c from = an updated /usr/src can/does end up using the last instead of one of the = first two, at least for the powerpc64-xtoolchain-gcc style of buildworld = activity that I am trying. The recent addition of BIO_F_DGRAM_SCTP_WRITE ends up with its = definition missing because of this: during the build = /usr/include/openssl/bio.h ends up being the file included and the = compile fails from the missing additional definition. Either the #include paths in /head/crypto/openssl/crypto/bio/bio_err.c = or the command line arguments should force the = /usr/obj/usr/src/tmp/usr/include/openssl/bio.h (or = /usr/src/crypto/openssl/crypto/bio/bio.h ) vintage file to be found. The = bio.h relevant includes are shown below... > #include <stdio.h> > #include <openssl/err.h> > #include <openssl/bio.h> More than bio.h might have such issues since there is an openssl/err.h = include path in /head/crypto/openssl/crypto/bio/bio_err.c . I have not checked for other .c files with similar issues for = <openssl/...> usage during buildworld. The problem details: /head/crypto/openssl/crypto/bio/bio_err.c -r280297 added: > {ERR_FUNC(BIO_F_DGRAM_SCTP_WRITE), "DGRAM_SCTP_WRITE"}, and head (20150325 r280598) contains it. But the BIO_F_DGRAM_SCTP_WRITE reference blocks buildworld (for at least = /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc = (powerpc64-xtoolchain=3Dgcc) use): > /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc -fpic -DPIC -O2 = -pipe -DTERMIOS -DANSI_SOURCE = -I/usr/src/secure/lib/libcrypto/../../../crypto/openssl = -I/usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto = -I/usr/obj/usr/src/secure/lib/libcrypto -DOPENSSL_THREADS -DDSO_DLFCN = -DHAVE_DLFCN_H = -I/usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/asn1 = -I/usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/evp = -I/usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/modes = -std=3Dgnu89 -fstack-protector -Wno-pointer-sign -c = /usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/bio/bio_err.c= -o bio_err.So > In file included from = /usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/bio/bio_err.c= :63:0: > = /usr/src/secure/lib/libcrypto/../../../crypto/openssl/crypto/bio/bio_err.c= :99:15: error: 'BIO_F_DGRAM_SCTP_WRITE' undeclared here (not in a = function) > {ERR_FUNC(BIO_F_DGRAM_SCTP_WRITE), "DGRAM_SCTP_WRITE"}, > ^ Looking to see where usage and definitions might be in /usr/src for = -r280598 ... > # pwd > /usr/src > $ find . \( -type d -name .svn -prune \) -or \( -type f -exec grep = BIO_F_DGRAM_SCTP_WRITE {} \; -print \) | more > # define BIO_F_DGRAM_SCTP_WRITE 133 > ./crypto/openssl/crypto/bio/bio.h > BIOerr(BIO_F_DGRAM_SCTP_WRITE, ERR_R_MALLOC_ERROR); > ./crypto/openssl/crypto/bio/bss_dgram.c > {ERR_FUNC(BIO_F_DGRAM_SCTP_WRITE), "DGRAM_SCTP_WRITE"}, > ./crypto/openssl/crypto/bio/bio_err.c And looking at the list of includes in = /head/crypto/openssl/crypto/bio/bio_err.c -r280297 shows: > #include <stdio.h> > #include <openssl/err.h> > #include <openssl/bio.h> That there was no complaint about bio.h being missing suggests that a = <openssl/bio.h> was found but did not contain a BIO_F_DGRAM_SCTP_WRITE = definition: so a different one than a copy of what the above find/grep = reported. Using a find to report other bio.h files shows: > # find / \( -type d -name .svn -prune \) -or \( -type f -name bio.h = -print \) | more > /usr/src/crypto/openssl/crypto/bio/bio.h > /usr/src/sys/sys/bio.h > /usr/obj/usr/src/tmp/usr/include/openssl/bio.h > /usr/include/openssl/bio.h > /usr/include/sys/bio.h (Ignoring .../sys/bio.h as distinct by content and by path prefix...) The diff of /usr/obj/usr/src/tmp/usr/include/openssl/bio.h and = /usr/include/openssl/bio.h shows the problem if the wrong file is found = and used: > diff -w /usr/src/crypto/openssl/crypto/bio/bio.h = /usr/include/openssl/bio.h | less > ... > 797,798c775 > < /* > < * The following lines are auto generated by the script mkerr.pl. = Any changes > --- >> /* The following lines are auto generated by the script mkerr.pl. Any = changes > 832d808 > < # define BIO_F_DGRAM_SCTP_WRITE 133 Context details: > make -j 8 CROSS_TOOLCHAIN=3Dpowerpc64-gcc=20 > WITHOUT_CLANG_BOOTSTRAP=3D WITHOUT_CLANG=3D WITHOUT_CLANG_IS_CC=3D \ > WITHOUT_LLDB=3D \ > WITH_GCC_BOOTSTRAP=3D WITH_GCC=3D WITHOUT_GNUCXX=3D \ > WITHOUT_BOOT=3D WITHOUT_LIB32=3D \ > buildworld buildkernel \ > KERNCONF=3DGENERIC64vtsc-NODEBUG > TARGET=3Dpowerpc TARGET_ARCH=3Dpowerpc64 > # svnlite info /usr/src > Path: . > Working Copy Root Path: /usr/src > URL: https://svn0.us-west.freebsd.org/base/head > Relative URL: ^/head > Repository Root: https://svn0.us-west.freebsd.org/base > Repository UUID: ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f > Revision: 280615 > Node Kind: directory > Schedule: normal > Last Changed Author: hselasky > Last Changed Rev: 280598 > Last Changed Date: 2015-03-25 06:32:27 -0700 (Wed, 25 Mar 2015) signals.h and pthread.h have been updated to more recent than -r280598 = in order to avoid the __nonnull issues that exist as of -r280598. > # svnlite st /usr/src --no-ignore > ? /usr/src/.snap > ? /usr/src/restoresymtable > M /usr/src/sys/ddb/db_main.c > M /usr/src/sys/ddb/db_script.c > ? /usr/src/sys/powerpc/conf/GENERIC64vtsc > ? /usr/src/sys/powerpc/conf/GENERIC64vtsc-NODEBUG > ? /usr/src/sys/powerpc/conf/GENERICvtsc > ? /usr/src/sys/powerpc/conf/GENERICvtsc-NODEBUG > M /usr/src/sys/powerpc/ofw/ofw_machdep.c > M /usr/src/sys/powerpc/ofw/ofwcall64.S (The .c/.S changes are tied to a PowerMac-G5-specific boot-problem fix = and getting information from early boot failures if I get any more. The = GENERIC<?>'s remove ps3 in order to have both vt and sc at the same = time.) > # more /etc/src.conf=20 > NO_WERROR=3D > WITH_LIBCPLUSPLUS=3D > CC=3D/usr/local/bin/powerpc64-portbld-freebsd11.0-gcc > CXX=3D/usr/local/bin/powerpc64-portbld-freebsd11.0-g++ > CPP=3D/usr/local/bin/powerpc64-portbld-freebsd11.0-cpp > CROSS_BINUTILS_PREFIX=3D/usr/local/powerpc64-freebsd/bin/ > X_COMPILER_TYPE=3Dgcc > CXXFLAGS+=3D-I/usr/obj/usr/srcC/tmp/usr/include/c++/v1/. -std=3Dgnu++11 = -L/usr/obj/usr/srcC/lib/libc++/. > CXXFLAGS+=3D-I/usr/include/c++/v1/. -std=3Dgnu++11 -L/usr/lib/. (The above and just below experiments with mostly(?) avoiding use of gcc = 4.2.1, even for CC/CXX/CPP contexts.) > # ls -FPal /usr/bin/g[+c]* > lrwxr-xr-x 1 root wheel 48 Mar 20 02:03 /usr/bin/g++@ -> = /usr/local/bin/powerpc64-portbld-freebsd11.0-g++ > lrwxr-xr-x 1 root wheel 48 Mar 19 04:20 /usr/bin/gcc@ -> = /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc > # more /etc/make.conf > WRKDIRPREFIX=3D/usr/obj/portswork > #WITH_DEBUG=3D > MALLOC_PRODUCTION=3D =3D=3D=3D Mark Millard markmi at dsl-only.net
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CF6F193D-0612-491E-BBAD-970E460E6102>