[oe] [meta-oe][PATCH 1/2] mariadb: Upgrade to 10.3.13

Yu, Mingli mingli.yu at windriver.com
Wed Mar 6 06:05:16 UTC 2019



On 2019年03月06日 13:40, Khem Raj wrote:
> On Tue, Mar 5, 2019 at 9:35 PM Khem Raj <raj.khem at gmail.com> wrote:
>>
>> On Tue, Mar 5, 2019 at 8:23 PM Yu, Mingli <mingli.yu at windriver.com> wrote:
>>>
>>>
>>>
>>> On 2019年03月06日 02:26, Khem Raj wrote:
>>>> On Mon, Mar 4, 2019 at 9:29 PM <mingli.yu at windriver.com> wrote:
>>>>>
>>>>> From: Mingli Yu <mingli.yu at windriver.com>
>>>>>
>>>>> Per https://mariadb.org/about/maintenance-policy/,
>>>>> mariadb 5.5.x series only supported until next year
>>>>> April 2020, so upgrade it to 10.3.13.
>>>>>
>>>>> Remove some deprecated patches, add some
>>>>> new patches to fix build failure and rework
>>>>> two patches to avoid fuzz warnings.
>>>>>
>>>>
>>>> I think we need to add
>>>>
>>>> LDFLAGS += "-pthread"
>>>>
>>>> this helps it linking on some arches where libatomics might be
>>>> required.
>>>
>>> Thanks Khem! And I notice you make a patch as
>>> http://cgit.openembedded.org/meta-openembedded/commit/?h=master-next&id=7337b759132baa7bb421fdb904e12a278dbe0662
>>> to fix the atomics issue.
>>>
>>> If so, do I need to resend V2 to cover the above logic as you suggested?
>
> But I am seeing couple of other packages failing after this upgrade
>
> https://errors.yoctoproject.org/Errors/Details/231648/
> https://errors.yoctoproject.org/Errors/Details/231645/

I will look into this.

Thanks,

>
>>>
>>
>> No need, I have fixed it locally, there was another failure on mips
>> arch which is also fixed in master-next
>>
>>> Thanks,
>>>
>>>>
>>>>> Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>>>>> ---
>>>>>    ...ve_5.5.62.bb => mariadb-native_10.3.13.bb} |   1 +
>>>>>    meta-oe/recipes-dbs/mysql/mariadb.inc         |  29 ++--
>>>>>    .../0001-disable-ucontext-on-musl.patch       |   8 +-
>>>>>    .../mariadb/change-cc-to-cc-version.patch     |  26 ---
>>>>>    .../configure.cmake-fix-valgrind.patch        |  27 ++-
>>>>>    .../mariadb/fix-a-building-failure.patch      |  16 +-
>>>>>    .../mysql/mariadb/fix-cmake-module-path.patch |  29 ----
>>>>>    .../mariadb/fix-mysqlclient-r-version.patch   | 160 ------------------
>>>>>    .../mysql/mariadb/remove-bad-path.patch       |  18 --
>>>>>    ...Lists.txt-fix-gen_lex_hash-not-found.patch |  65 +++++++
>>>>>    ...akeLists.txt-fix-do_populate_sysroot.patch |  34 ++++
>>>>>    .../{mariadb_5.5.62.bb => mariadb_10.3.13.bb} |   2 +-
>>>>>    12 files changed, 145 insertions(+), 270 deletions(-)
>>>>>    rename meta-oe/recipes-dbs/mysql/{mariadb-native_5.5.62.bb => mariadb-native_10.3.13.bb} (88%)
>>>>>    delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>>>>>    delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>>>>>    delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>>>>>    delete mode 100644 meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>>>>>    create mode 100644 meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>>>>>    create mode 100644 meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>>>>>    rename meta-oe/recipes-dbs/mysql/{mariadb_5.5.62.bb => mariadb_10.3.13.bb} (88%)
>>>>>
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb b/meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>>>>> similarity index 88%
>>>>> rename from meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb
>>>>> rename to meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>>>>> index 4ce960d7d..e1a038dfa 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb-native_5.5.62.bb
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb-native_10.3.13.bb
>>>>> @@ -13,6 +13,7 @@ do_install() {
>>>>>
>>>>>        install -d ${D}${bindir}
>>>>>        install -m 0755 sql/gen_lex_hash ${D}${bindir}/
>>>>> +    install -m 0755 sql/gen_lex_token ${D}${bindir}/
>>>>>        install -m 0755 extra/comp_err ${D}${bindir}/
>>>>>        install -m 0755 scripts/comp_sql ${D}${bindir}/
>>>>>    }
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb.inc b/meta-oe/recipes-dbs/mysql/mariadb.inc
>>>>> index 8ca5b2ba4..65f98bd3b 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb.inc
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb.inc
>>>>> @@ -4,10 +4,7 @@ SECTION = "libs"
>>>>>    LICENSE = "GPLv2"
>>>>>    LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe"
>>>>>
>>>>> -SRC_URI = "https://downloads.mariadb.org/f/${BP}/source/${BP}.tar.gz \
>>>>> -           file://fix-cmake-module-path.patch \
>>>>> -           file://remove-bad-path.patch \
>>>>> -           file://fix-mysqlclient-r-version.patch \
>>>>> +SRC_URI = "https://downloads.mariadb.org/interstitial/${BPN}-${PV}/source/${BPN}-${PV}.tar.gz \
>>>>>               file://my.cnf \
>>>>>               file://mysqld.service \
>>>>>               file://install_db.service \
>>>>> @@ -15,11 +12,12 @@ SRC_URI = "https://downloads.mariadb.org/f/${BP}/source/${BP}.tar.gz \
>>>>>               file://mysql-systemd-start \
>>>>>               file://configure.cmake-fix-valgrind.patch \
>>>>>               file://fix-a-building-failure.patch \
>>>>> -           file://change-cc-to-cc-version.patch \
>>>>> +           file://support-files-CMakeLists.txt-fix-do_populate_sysroot.patch \
>>>>> +           file://sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch \
>>>>>               file://0001-disable-ucontext-on-musl.patch \
>>>>>              "
>>>>> -SRC_URI[md5sum] = "6375d577e9539b839f44d857e70f82b9"
>>>>> -SRC_URI[sha256sum] = "56a365af71b8a9ec8bfee0801e2dec95011da8ee7507986ca329be11296411db"
>>>>> +SRC_URI[md5sum] = "603ce42e35b9a688f2cca05275acb5cb"
>>>>> +SRC_URI[sha256sum] = "b2aa857ef5b84f85a7ea60a1eac7b34c0ca5151c71a0d44ce2d7fb028d71459a"
>>>>>
>>>>>    UPSTREAM_CHECK_URI = "https://github.com/MariaDB/server/releases"
>>>>>
>>>>> @@ -120,6 +118,11 @@ do_compile_prepend_class-target () {
>>>>>                echo "#endif" >>${B}/include/openssl/kssl.h
>>>>>            fi
>>>>>        fi
>>>>> +    # workaround to handle out-of-source build from source package
>>>>> +    yacc_files="sql_yacc.hh sql_yacc.cc sql_yacc_ora.hh sql_yacc_ora.cc"
>>>>> +    for yacc_file in ${yacc_files}; do
>>>>> +        cp ${S}/sql/${yacc_file} ${B}/sql/${yacc_file}
>>>>> +    done
>>>>>    }
>>>>>
>>>>>    SYSROOT_PREPROCESS_FUNCS += "mariadb_sysroot_preprocess"
>>>>> @@ -181,13 +184,13 @@ RDEPENDS_${PN}-client = "perl perl-module-getopt-long perl-module-file-temp \
>>>>>    RDEPENDS_${PN}-server = "perl perl-module-getopt-long perl-module-data-dumper \
>>>>>        perl-module-file-basename perl-module-file-path perl-module-sys-hostname \
>>>>>        perl-module-file-copy perl-module-file-temp perl-module-posix \
>>>>> -    ${PN}-client libdbi-perl libdbd-mysql-perl"
>>>>> +    ${PN}-client ${PN}-setupdb libdbi-perl libdbd-mysql-perl"
>>>>>    RDEPENDS_${PN}-leftovers = "perl perl-module-cwd perl-module-benchmark perl-module-getopt-long \
>>>>>        perl-module-posix perl-module-data-dumper perl-module-sigtrap perl-module-threads \
>>>>>        perl-module-threads-shared perl-module-io-socket perl-module-sys-hostname perl-module-file-copy \
>>>>>        perl-module-file-spec perl-module-file-find perl-module-file-basename perl-module-file-path \
>>>>>        perl-module-constant perl-module-lib perl-module-file-temp perl-module-file-spec-functions \
>>>>> -    perl-module-io-socket-inet perl-module-io-select"
>>>>> +    perl-module-io-socket-inet perl-module-io-select bash"
>>>>>    RDEPENDS_${PN}-setupdb = "coreutils"
>>>>>
>>>>>    # Allow old code to link to the backward compatible library
>>>>> @@ -195,10 +198,12 @@ RDEPENDS_libmysqlclient-dev = "libmysqlclient-r-dev"
>>>>>
>>>>>    FILES_libmysqlclient = "\
>>>>>        ${libdir}/libmysqlclient.so.* \
>>>>> +    ${libdir}/libmariadb.so.* \
>>>>>        ${sysconfdir}/my.cnf.d/client.cnf"
>>>>>    FILES_libmysqlclient-dev = " \
>>>>>        ${includedir}/mysql/ \
>>>>>        ${libdir}/libmysqlclient.so \
>>>>> +    ${libdir}/libmariadb.so \
>>>>>        ${sysconfdir}/aclocal \
>>>>>        ${bindir}/mysql_config"
>>>>>    FILES_libmysqlclient-staticdev = "\
>>>>> @@ -215,9 +220,11 @@ FILES_libmysqlclient-r-dev = "\
>>>>>    FILES_libmysqlclient-r-staticdev = "${libdir}/libmysqlclient_r.a"
>>>>>
>>>>>    FILES_libmysqld = "\
>>>>> -    ${libdir}/libmysqld.so.*"
>>>>> +    ${libdir}/libmysqld.so.* \
>>>>> +    ${libdir}/libmariadbd.so.*"
>>>>>    FILES_libmysqld-dev = "\
>>>>> -    ${libdir}/libmysqld.so"
>>>>> +    ${libdir}/libmysqld.so \
>>>>> +    ${libdir}/libmariadbd.so"
>>>>>
>>>>>    FILES_${PN}-client = "\
>>>>>        ${bindir}/myisam_ftdump \
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch b/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>>>>> index 60e9199f9..daf2432a5 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/0001-disable-ucontext-on-musl.patch
>>>>> @@ -1,4 +1,4 @@
>>>>> -From 5bc3e7ef9700d12054e0125a126f1bb093f01ef9 Mon Sep 17 00:00:00 2001
>>>>> +From b658bdb38b7ff6a78915fd0ac390fc224e4006cb Mon Sep 17 00:00:00 2001
>>>>>    From: Khem Raj <raj.khem at gmail.com>
>>>>>    Date: Sun, 26 Mar 2017 14:30:33 -0700
>>>>>    Subject: [PATCH] disable ucontext on musl
>>>>> @@ -6,12 +6,13 @@ Subject: [PATCH] disable ucontext on musl
>>>>>    musl does not have *contex() APIs even though it has ucontext.h header
>>>>>
>>>>>    Signed-off-by: Khem Raj <raj.khem at gmail.com>
>>>>> +
>>>>>    ---
>>>>>     include/my_context.h | 2 +-
>>>>>     1 file changed, 1 insertion(+), 1 deletion(-)
>>>>>
>>>>>    diff --git a/include/my_context.h b/include/my_context.h
>>>>> -index dd44103..9b28c17 100644
>>>>> +index ea0e3496..4c9b37dc 100644
>>>>>    --- a/include/my_context.h
>>>>>    +++ b/include/my_context.h
>>>>>    @@ -31,7 +31,7 @@
>>>>> @@ -23,6 +24,3 @@ index dd44103..9b28c17 100644
>>>>>     #define MY_CONTEXT_USE_UCONTEXT
>>>>>     #else
>>>>>     #define MY_CONTEXT_DISABLE
>>>>> ---
>>>>> -2.12.1
>>>>> -
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch b/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>>>>> deleted file mode 100644
>>>>> index 02bda24f7..000000000
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/change-cc-to-cc-version.patch
>>>>> +++ /dev/null
>>>>> @@ -1,26 +0,0 @@
>>>>> -mariadb: replace the CC with CC_VERSION and CXX with CXX_VERSION
>>>>> -
>>>>> -mysqlbug.sh is a bug report script. It makes a report with the build information,
>>>>> -including gcc version. The CC is the local path of gcc, which is useless for bug
>>>>> -report, and the path may expose private information, so change it to CC_VERSION.
>>>>> -
>>>>> -Upstream-Status: Pending
>>>>> -
>>>>> -Signed-off-by: Yue Tao <Yue.Tao at windriver.com>
>>>>> -Signed-off-by: Wenzong Fan <wenzong.fan at windriver.com>
>>>>> -================================
>>>>> -diff --git a/scripts/mysqlbug.sh.old b/scripts/mysqlbug.sh
>>>>> -index e9df210..d4b8d53 100644
>>>>> ---- a/scripts/mysqlbug.sh.old
>>>>> -+++ b/scripts/mysqlbug.sh
>>>>> -@@ -24,8 +24,8 @@ VERSION="@VERSION@@MYSQL_SERVER_SUFFIX@"
>>>>> - COMPILATION_COMMENT="@COMPILATION_COMMENT@"
>>>>> - BUGmysql="maria-developers at lists.launchpad.net"
>>>>> - # This is set by configure
>>>>> --COMP_CALL_INFO="CC='@SAVE_CC@'  CFLAGS='@SAVE_CFLAGS@'  CXX='@SAVE_CXX@'  CXXFLAGS='@SAVE_CXXFLAGS@'  LDFLAGS='@SAVE_LDFLAGS@'  ASFLAGS='@SAVE_ASFLAGS@'"
>>>>> --COMP_RUN_INFO="CC='@CC@'  CFLAGS='@CFLAGS@'  CXX='@CXX@'  CXXFLAGS='@CXXFLAGS@'  LDFLAGS='@LDFLAGS@'  ASFLAGS='@ASFLAGS@'"
>>>>> -+COMP_CALL_INFO="CC='@CC_VERSION@'  CFLAGS='@SAVE_CFLAGS@'  CXX='@CXX_VERSION@'  CXXFLAGS='@SAVE_CXXFLAGS@'  LDFLAGS='@SAVE_LDFLAGS@'  ASFLAGS='@SAVE_ASFLAGS@'"
>>>>> -+COMP_RUN_INFO="CC='@CC_VERSION@'  CFLAGS='@CFLAGS@'  CXX='@CXX_VERSION@'  CXXFLAGS='@CXXFLAGS@'  LDFLAGS='@LDFLAGS@'  ASFLAGS='@ASFLAGS@'"
>>>>> - CONFIGURE_LINE="@CONF_COMMAND@"
>>>>> -
>>>>> - LIBC_INFO=""
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch b/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>>>>> index e97def602..ac9427958 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/configure.cmake-fix-valgrind.patch
>>>>> @@ -1,6 +1,6 @@
>>>>> -From 5effba0d7d47071a3f1bca56823190d5a95bb1a6 Mon Sep 17 00:00:00 2001
>>>>> +From 24e2b0edc2612acefcc48414bb6f0aeb086061a9 Mon Sep 17 00:00:00 2001
>>>>>    From: Jackie Huang <jackie.huang at windriver.com>
>>>>> -Date: Wed, 12 Nov 2014 03:09:10 -0500
>>>>> +Date: Tue, 26 Feb 2019 23:57:06 -0800
>>>>>    Subject: [PATCH] configure.cmake: fix valgrind
>>>>>
>>>>>    Check valgrind headers only if WITH_VALGRIND is set.
>>>>> @@ -15,27 +15,26 @@ PACKAGECONFIG to decide if valgrind is needed or not.
>>>>>    Upstream-Status: Inappropriate [oe specific]
>>>>>
>>>>>    Signed-off-by: Jackie Huang <jackie.huang at windriver.com>
>>>>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>>>>> +
>>>>>    ---
>>>>> - configure.cmake | 4 ++--
>>>>> - 1 file changed, 2 insertions(+), 2 deletions(-)
>>>>> + configure.cmake | 5 ++---
>>>>> + 1 file changed, 2 insertions(+), 3 deletions(-)
>>>>>
>>>>>    diff --git a/configure.cmake b/configure.cmake
>>>>> -index 0bd7bbe..51a098f 100644
>>>>> +index 3cfc4b31..d017b3b3 100644
>>>>>    --- a/configure.cmake
>>>>>    +++ b/configure.cmake
>>>>> -@@ -1047,10 +1047,10 @@ MARK_AS_ADVANCED(WITH_ATOMIC_LOCKS MY_ATOMIC_MODE_RWLOCK MY_ATOMIC_MODE_DUMMY)
>>>>> +@@ -930,10 +930,9 @@ HAVE_GCC_C11_ATOMICS)
>>>>>
>>>>>     IF(WITH_VALGRIND)
>>>>>       SET(HAVE_valgrind 1)
>>>>> -+  CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>>>>> -+  HAVE_VALGRIND)
>>>>> - ENDIF()
>>>>> -
>>>>> +-ENDIF()
>>>>> +-
>>>>>    -CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>>>>> --  HAVE_VALGRIND)
>>>>> ++  CHECK_INCLUDE_FILES("valgrind/memcheck.h;valgrind/valgrind.h"
>>>>> +   HAVE_VALGRIND_MEMCHECK_H)
>>>>> ++ENDIF()
>>>>>
>>>>>     #--------------------------------------------------------------------
>>>>>     # Check for IPv6 support
>>>>> ---
>>>>> -2.0.0
>>>>> -
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>>>>> index 0c4e10237..9149ee21f 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/fix-a-building-failure.patch
>>>>> @@ -1,4 +1,7 @@
>>>>> -[PATCH] fix a building failure
>>>>> +From 1b2b6a61c9f82157cd2e0c3744f6c07e07aeb0bd Mon Sep 17 00:00:00 2001
>>>>> +From: Mingli Yu <mingli.yu at windriver.com>
>>>>> +Date: Mon, 4 Mar 2019 01:11:30 -0800
>>>>> +Subject: [PATCH] fix a building failure
>>>>>
>>>>>    Upstream-Status: Inappropriate [configuration]
>>>>>
>>>>> @@ -6,17 +9,18 @@ building failed since native does not generate import_executables.cmake
>>>>>    In fact, our building system will export the needed commands
>>>>>
>>>>>    Signed-off-by: Roy Li <rongqing.li at windriver.com>
>>>>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>>>>>    ---
>>>>>     CMakeLists.txt | 5 -----
>>>>>     1 file changed, 5 deletions(-)
>>>>>
>>>>>    diff --git a/CMakeLists.txt b/CMakeLists.txt
>>>>> -index c1ce1c5..83b3a7e 100644
>>>>> +index fc30750..4f9110e 100644
>>>>>    --- a/CMakeLists.txt
>>>>>    +++ b/CMakeLists.txt
>>>>> -@@ -350,11 +350,6 @@ MYSQL_CHECK_READLINE()
>>>>> +@@ -347,11 +347,6 @@ CHECK_PCRE()
>>>>>
>>>>> - CHECK_JEMALLOC()
>>>>> + CHECK_SYSTEMD()
>>>>>
>>>>>    -IF(CMAKE_CROSSCOMPILING)
>>>>>    -  SET(IMPORT_EXECUTABLES "IMPORTFILE-NOTFOUND" CACHE FILEPATH "Path to import_executables.cmake from a native build")
>>>>> @@ -24,8 +28,8 @@ index c1ce1c5..83b3a7e 100644
>>>>>    -ENDIF()
>>>>>    -
>>>>>     #
>>>>> - # Setup maintainer mode options by the end. Platform checks are
>>>>> + # Setup maintainer mode options. Platform checks are
>>>>>     # not run with the warning options as to not perturb fragile checks
>>>>>    --
>>>>> -1.9.1
>>>>> +2.17.1
>>>>>
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>>>>> deleted file mode 100644
>>>>> index 8d9f558d0..000000000
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-cmake-module-path.patch
>>>>> +++ /dev/null
>>>>> @@ -1,29 +0,0 @@
>>>>> -Avoid CMAKE_MODULE_PATH being overwritten
>>>>> -
>>>>> -OE-Core's setting of CMAKE_MODULE_PATH stomps on MariaDB's value unless
>>>>> -we set it after setting the project name.
>>>>> -
>>>>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>>>>> -
>>>>> -Upstream-Status: Inappropriate [working around OE-Core bug]
>>>>> -
>>>>> ---- mariadb/CMakeLists.txt     2014-07-17 11:01:07.676353047 +0100
>>>>> -+++ mariadb/CMakeLists.txt     2014-07-17 11:01:31.299353107 +0100
>>>>> -@@ -28,8 +28,6 @@
>>>>> -
>>>>> - MESSAGE(STATUS "Running cmake version ${CMAKE_VERSION}")
>>>>> -
>>>>> --SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake)
>>>>> --
>>>>> - # Distinguish between community and non-community builds, with the
>>>>> - # default being a community build. This does not impact the feature
>>>>> - # set that will be compiled in; it's merely provided as a hint to
>>>>> -@@ -77,6 +75,8 @@
>>>>> - ENDIF()
>>>>> - PROJECT(${MYSQL_PROJECT_NAME})
>>>>> -
>>>>> -+SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/cmake)
>>>>> -+
>>>>> - IF(BUILD_CONFIG)
>>>>> -   INCLUDE(
>>>>> -   ${CMAKE_SOURCE_DIR}/cmake/build_configurations/${BUILD_CONFIG}.cmake)
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch b/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>>>>> deleted file mode 100644
>>>>> index a519e4292..000000000
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/fix-mysqlclient-r-version.patch
>>>>> +++ /dev/null
>>>>> @@ -1,160 +0,0 @@
>>>>> -From 6db2a606196fb38a6d106dc409eee1cb9a40a440 Mon Sep 17 00:00:00 2001
>>>>> -From: Tor Didriksen <tor.didriksen at oracle.com>
>>>>> -Date: Mon, 24 Jun 2013 17:15:35 +0200
>>>>> -Subject: [PATCH] Bug#16809055 MYSQL 5.6 AND 5.7 STILL USE LIBMYSQLCLIENT.SO.18
>>>>> -
>>>>> -With this patch, the libmysql/ directory contains:
>>>>> -libmysqlclient.a
>>>>> -libmysqlclient_r.a -> libmysqlclient.a
>>>>> -libmysqlclient_r.so -> libmysqlclient.so*
>>>>> -libmysqlclient_r.so.18 -> libmysqlclient.so.18*
>>>>> -libmysqlclient_r.so.18.1.0 -> libmysqlclient.so.18.1.0*
>>>>> -libmysqlclient.so -> libmysqlclient.so.18*
>>>>> -libmysqlclient.so.18 -> libmysqlclient.so.18.1.0*
>>>>> -libmysqlclient.so.18.1.0*
>>>>> -
>>>>> -This fixes libmysqlclient_r symlinks pointing to the unversioned
>>>>> -libmysqlclient.so symlink (leading to package QA errors since the
>>>>> -libmysqlclient-r package ends up depending on libmysqlclient-dev).
>>>>> -
>>>>> -Borrowed from MySQL 5.6 tree at https://github.com/percona/mysql/
>>>>> -
>>>>> -Upstream-Status: Pending
>>>>> -
>>>>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>>>>> -
>>>>> ----
>>>>> - cmake/install_macros.cmake | 25 +++++++++++++++----------
>>>>> - libmysql/CMakeLists.txt    | 34 +++++++++++++++++++++++++++-------
>>>>> - 2 files changed, 42 insertions(+), 17 deletions(-)
>>>>> -
>>>>> -diff --git a/cmake/install_macros.cmake b/cmake/install_macros.cmake
>>>>> -index b8efdf8..a0d0e68 100644
>>>>> ---- a/cmake/install_macros.cmake
>>>>> -+++ b/cmake/install_macros.cmake
>>>>> -@@ -1,4 +1,4 @@
>>>>> --# Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
>>>>> -+# Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved.
>>>>> - #
>>>>> - # This program is free software; you can redistribute it and/or modify
>>>>> - # it under the terms of the GNU General Public License as published by
>>>>> -@@ -167,28 +167,33 @@ ENDFUNCTION()
>>>>> -
>>>>> -
>>>>> - # Install symbolic link to CMake target.
>>>>> --# the link is created in the same directory as target
>>>>> --# and extension will be the same as for target file.
>>>>> --MACRO(INSTALL_SYMLINK linkname target destination component)
>>>>> -+# We do 'cd path; ln -s target_name link_name'
>>>>> -+# We also add an INSTALL target for "${path}/${link_name}"
>>>>> -+MACRO(INSTALL_SYMLINK target target_name link_name destination component)
>>>>> - IF(UNIX)
>>>>> -   GET_TARGET_PROPERTY(location ${target} LOCATION)
>>>>> -   GET_FILENAME_COMPONENT(path ${location} PATH)
>>>>> --  GET_FILENAME_COMPONENT(name ${location} NAME)
>>>>> --  SET(output ${path}/${linkname})
>>>>> -+  MESSAGE(STATUS "target ${target}")
>>>>> -+  MESSAGE(STATUS "link_name ${link_name}")
>>>>> -+  MESSAGE(STATUS "target_name ${target_name}")
>>>>> -+  MESSAGE(STATUS "path ${path}")
>>>>> -+  MESSAGE(STATUS "")
>>>>> -+
>>>>> -+  SET(output ${path}/${link_name})
>>>>> -   ADD_CUSTOM_COMMAND(
>>>>> -     OUTPUT ${output}
>>>>> -     COMMAND ${CMAKE_COMMAND} ARGS -E remove -f ${output}
>>>>> -     COMMAND ${CMAKE_COMMAND} ARGS -E create_symlink
>>>>> --      ${name}
>>>>> --      ${linkname}
>>>>> -+      ${target_name}
>>>>> -+      ${link_name}
>>>>> -     WORKING_DIRECTORY ${path}
>>>>> -     DEPENDS ${target}
>>>>> -     )
>>>>> -
>>>>> --  ADD_CUSTOM_TARGET(symlink_${linkname}
>>>>> -+  ADD_CUSTOM_TARGET(symlink_${link_name}
>>>>> -     ALL
>>>>> -     DEPENDS ${output})
>>>>> --  SET_TARGET_PROPERTIES(symlink_${linkname} PROPERTIES CLEAN_DIRECT_OUTPUT 1)
>>>>> -+  SET_TARGET_PROPERTIES(symlink_${link_name} PROPERTIES CLEAN_DIRECT_OUTPUT 1)
>>>>> -   IF(CMAKE_GENERATOR MATCHES "Xcode")
>>>>> -     # For Xcode, replace project config with install config
>>>>> -     STRING(REPLACE "${CMAKE_CFG_INTDIR}"
>>>>> -diff --git a/libmysql/CMakeLists.txt b/libmysql/CMakeLists.txt
>>>>> -index be5760f..96286ff 100644
>>>>> ---- a/libmysql/CMakeLists.txt
>>>>> -+++ b/libmysql/CMakeLists.txt
>>>>> -@@ -433,6 +433,12 @@ IF(MSVC)
>>>>> -  INSTALL_DEBUG_TARGET(clientlib DESTINATION ${INSTALL_LIBDIR}/debug)
>>>>> - ENDIF()
>>>>> -
>>>>> -+MACRO(GET_TARGET_NAME target out_name)
>>>>> -+  GET_TARGET_PROPERTY(location ${target} LOCATION)
>>>>> -+  GET_FILENAME_COMPONENT(name ${location} NAME)
>>>>> -+  SET(${out_name} ${name})
>>>>> -+ENDMACRO()
>>>>> -+
>>>>> - IF(UNIX)
>>>>> -   MACRO(GET_VERSIONED_LIBNAME LIBNAME EXTENSION VERSION OUTNAME)
>>>>> -     SET(DOT_VERSION ".${VERSION}")
>>>>> -@@ -445,7 +451,13 @@ IF(UNIX)
>>>>> -       SET(${OUTNAME} ${LIBNAME}${EXTENSION}${DOT_VERSION})
>>>>> -     ENDIF()
>>>>> -   ENDMACRO()
>>>>> --  INSTALL_SYMLINK(${CMAKE_STATIC_LIBRARY_PREFIX}mysqlclient_r.a mysqlclient ${INSTALL_LIBDIR} Development)
>>>>> -+ENDIF()
>>>>> -+
>>>>> -+IF(UNIX)
>>>>> -+  GET_TARGET_NAME(mysqlclient lib_name)
>>>>> -+  INSTALL_SYMLINK(mysqlclient
>>>>> -+    ${lib_name} ${CMAKE_STATIC_LIBRARY_PREFIX}mysqlclient_r.a
>>>>> -+    ${INSTALL_LIBDIR} Development)
>>>>> - ENDIF()
>>>>> -
>>>>> - IF(NOT DISABLE_SHARED)
>>>>> -@@ -456,10 +468,9 @@ IF(NOT DISABLE_SHARED)
>>>>> -     # libtool compatability
>>>>> -     IF(CMAKE_SYSTEM_NAME MATCHES "FreeBSD" OR APPLE)
>>>>> -       SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}")
>>>>> --    ELSEIF(CMAKE_SYSTEM_NAME MATCHES "HP-UX")
>>>>> --      SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}.0")
>>>>> -     ELSE()
>>>>> --      SET(OS_SHARED_LIB_VERSION "${SHARED_LIB_MAJOR_VERSION}.0.0")
>>>>> -+      SET(OS_SHARED_LIB_VERSION
>>>>> -+        "${SHARED_LIB_MAJOR_VERSION}.${SHARED_LIB_MINOR_VERSION}.0")
>>>>> -     ENDIF()
>>>>> -     # Name of shared library is mysqlclient on Unix
>>>>> -     SET_TARGET_PROPERTIES(libmysql PROPERTIES
>>>>> -@@ -482,8 +493,13 @@ IF(NOT DISABLE_SHARED)
>>>>> -       "${CMAKE_SHARED_LIBRARY_SUFFIX}"
>>>>> -       ""
>>>>> -       linkname)
>>>>> --    INSTALL_SYMLINK(${linkname} libmysql ${INSTALL_LIBDIR} SharedLibraries)
>>>>> --    SET(OS_SHARED_LIB_SYMLINKS "${SHARED_LIB_MAJOR_VERSION}" "${OS_SHARED_LIB_VERSION}")
>>>>> -+    GET_TARGET_NAME(libmysql lib_name)
>>>>> -+    GET_FILENAME_COMPONENT(lib_name_we ${lib_name} NAME_WE)
>>>>> -+    INSTALL_SYMLINK(libmysql
>>>>> -+      ${lib_name} ${linkname}
>>>>> -+      ${INSTALL_LIBDIR} SharedLibraries)
>>>>> -+    SET(OS_SHARED_LIB_SYMLINKS
>>>>> -+      "${SHARED_LIB_MAJOR_VERSION}" "${OS_SHARED_LIB_VERSION}")
>>>>> -     LIST(REMOVE_DUPLICATES OS_SHARED_LIB_SYMLINKS)
>>>>> -     FOREACH(ver ${OS_SHARED_LIB_SYMLINKS})
>>>>> -       GET_VERSIONED_LIBNAME(
>>>>> -@@ -491,7 +507,11 @@ IF(NOT DISABLE_SHARED)
>>>>> -         "${CMAKE_SHARED_LIBRARY_SUFFIX}"
>>>>> -         "${ver}"
>>>>> -         linkname)
>>>>> --      INSTALL_SYMLINK(${linkname} libmysql ${INSTALL_LIBDIR} SharedLibraries)
>>>>> -+      GET_VERSIONED_LIBNAME(
>>>>> -+        ${lib_name_we} "${CMAKE_SHARED_LIBRARY_SUFFIX}" "${ver}" lib_name_ver)
>>>>> -+      INSTALL_SYMLINK(libmysql
>>>>> -+        ${lib_name_ver} ${linkname}
>>>>> -+        ${INSTALL_LIBDIR} SharedLibraries)
>>>>> -     ENDFOREACH()
>>>>> -   ENDIF()
>>>>> - ENDIF()
>>>>> ---
>>>>> -2.0.3
>>>>> -
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch b/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>>>>> deleted file mode 100644
>>>>> index ff26b0b86..000000000
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb/remove-bad-path.patch
>>>>> +++ /dev/null
>>>>> @@ -1,18 +0,0 @@
>>>>> -Remove host path from include directories
>>>>> -
>>>>> -Naturally this breaks cross-compilation if present.
>>>>> -
>>>>> -Upstream-Status: Pending
>>>>> -
>>>>> -Signed-off-by: Paul Eggleton <paul.eggleton at linux.intel.com>
>>>>> -
>>>>> ---- mariadb-5.5.38/storage/tokudb/ft-index/CMakeLists.txt      2014-07-17 14:37:04.529327998 +0100
>>>>> -+++ mariadb-5.5.38/storage/tokudb/ft-index/CMakeLists.txt      2014-07-17 14:43:56.991337895 +0100
>>>>> -@@ -39,7 +39,6 @@
>>>>> -
>>>>> - ## default includes and libraries
>>>>> - include_directories(SYSTEM
>>>>> --  /usr/local/include
>>>>> -   ${ZLIB_INCLUDE_DIRS}
>>>>> -   )
>>>>> -
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch b/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>>>>> new file mode 100644
>>>>> index 000000000..afc1be47b
>>>>> --- /dev/null
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/sql-CMakeLists.txt-fix-gen_lex_hash-not-found.patch
>>>>> @@ -0,0 +1,65 @@
>>>>> +From 796464015bffe6e0beca9e1c355b223512803c3e Mon Sep 17 00:00:00 2001
>>>>> +From: Mingli Yu <mingli.yu at windriver.com>
>>>>> +Date: Wed, 27 Feb 2019 23:01:00 -0800
>>>>> +Subject: [PATCH] sql/CMakeLists.txt: fix gen_lex_hash not found
>>>>> +
>>>>> +Fix the below do_compile issue in cross-compiling env.
>>>>> +| make[2]: *** No rule to make target '/build/tmp/work/aarch64-poky-linux/mariadb/10.3.13-r0/mariadb-10.3.13/sql/gen_lex_hash', needed by 'sql/lex_hash.h'.  Stop.
>>>>> +| make[2]: *** No rule to make target '/build/tmp/work/aarch64-poky-linux/mariadb/10.3.13-r0/mariadb-10.3.13/sql/gen_lex_token', needed by 'sql/lex_token.h'.  Stop.
>>>>> +
>>>>> +Upstream-Status: Inappropriate [oe build specific]
>>>>> +
>>>>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>>>>> +
>>>>> +---
>>>>> + sql/CMakeLists.txt | 30 ++++++++++++++++++++----------
>>>>> + 1 file changed, 20 insertions(+), 10 deletions(-)
>>>>> +
>>>>> +diff --git a/sql/CMakeLists.txt b/sql/CMakeLists.txt
>>>>> +index c6910f46..bf51f4cb 100644
>>>>> +--- a/sql/CMakeLists.txt
>>>>> ++++ b/sql/CMakeLists.txt
>>>>> +@@ -50,11 +50,16 @@ ${WSREP_INCLUDES}
>>>>> +
>>>>> +
>>>>> +
>>>>> +-ADD_CUSTOM_COMMAND(
>>>>> +-  OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>>>>> +-  COMMAND gen_lex_token > lex_token.h
>>>>> +-  DEPENDS gen_lex_token
>>>>> +-)
>>>>> ++IF(NOT CMAKE_CROSSCOMPILING)
>>>>> ++  ADD_CUSTOM_COMMAND(
>>>>> ++   OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>>>>> ++   COMMAND gen_lex_token > lex_token.h
>>>>> ++   DEPENDS gen_lex_token)
>>>>> ++ELSE()
>>>>> ++  ADD_CUSTOM_COMMAND(
>>>>> ++   OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_token.h
>>>>> ++   COMMAND gen_lex_token > lex_token.h)
>>>>> ++ENDIF()
>>>>> +
>>>>> + ADD_DEFINITIONS(-DMYSQL_SERVER -DHAVE_EVENT_SCHEDULER)
>>>>> +
>>>>> +@@ -370,11 +375,16 @@ IF(NOT CMAKE_CROSSCOMPILING)
>>>>> +   ADD_EXECUTABLE(gen_lex_hash gen_lex_hash.cc)
>>>>> + ENDIF()
>>>>> +
>>>>> +-ADD_CUSTOM_COMMAND(
>>>>> +-  OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>>>>> +-  COMMAND gen_lex_hash > lex_hash.h
>>>>> +-  DEPENDS gen_lex_hash
>>>>> +-)
>>>>> ++IF(NOT CMAKE_CROSSCOMPILING)
>>>>> ++  ADD_CUSTOM_COMMAND(
>>>>> ++   OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>>>>> ++   COMMAND gen_lex_hash > lex_hash.h
>>>>> ++   DEPENDS gen_lex_hash)
>>>>> ++ELSE()
>>>>> ++  ADD_CUSTOM_COMMAND(
>>>>> ++   OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/lex_hash.h
>>>>> ++   COMMAND gen_lex_hash > lex_hash.h)
>>>>> ++ENDIF()
>>>>> +
>>>>> + MYSQL_ADD_EXECUTABLE(mysql_tzinfo_to_sql tztime.cc COMPONENT Server)
>>>>> + SET_TARGET_PROPERTIES(mysql_tzinfo_to_sql PROPERTIES COMPILE_FLAGS "-DTZINFO2SQL")
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch b/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>>>>> new file mode 100644
>>>>> index 000000000..4f9a4e9b0
>>>>> --- /dev/null
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb/support-files-CMakeLists.txt-fix-do_populate_sysroot.patch
>>>>> @@ -0,0 +1,34 @@
>>>>> +From 4ac5b555d058d4d489f25a3806a787b7b2465d09 Mon Sep 17 00:00:00 2001
>>>>> +From: Mingli Yu <mingli.yu at windriver.com>
>>>>> +Date: Wed, 27 Feb 2019 22:41:26 -0800
>>>>> +Subject: [PATCH] support-files/CMakeLists.txt: fix do_populate_sysroot issue
>>>>> +
>>>>> +Comment out the logic which for suse as it introduces
>>>>> +below do_populate_sysroot error:
>>>>> +ERROR: mariadb-native-10.3.13-r0 do_populate_sysroot: sstate found an absolute path symlink /build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/sysroot-destdir/build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/recipe-sysroot-native/usr/sbin/rcmysql pointing at /build/tmp/work/x86_64-linux/mariadb-native/10.3.13-r0/recipe-sysroot-native/etc/init.d/mysql. Please replace this with a relative link.
>>>>> +
>>>>> +Upstream-Status: Inappropriate[oe build specific]
>>>>> +
>>>>> +Signed-off-by: Mingli Yu <mingli.yu at windriver.com>
>>>>> +
>>>>> +---
>>>>> + support-files/CMakeLists.txt | 7 -------
>>>>> + 1 file changed, 7 deletions(-)
>>>>> +
>>>>> +diff --git a/support-files/CMakeLists.txt b/support-files/CMakeLists.txt
>>>>> +index b5767432..56733de1 100644
>>>>> +--- a/support-files/CMakeLists.txt
>>>>> ++++ b/support-files/CMakeLists.txt
>>>>> +@@ -165,12 +165,5 @@ IF(UNIX)
>>>>> +       INSTALL(FILES rpm/enable_encryption.preset DESTINATION ${INSTALL_SYSCONF2DIR}
>>>>> +               COMPONENT IniFiles)
>>>>> +     ENDIF()
>>>>> +-
>>>>> +-    # This is for SuSE:
>>>>> +-    INSTALL(CODE "EXECUTE_PROCESS(COMMAND ${CMAKE_COMMAND} -E create_symlink
>>>>> +-                   ${INSTALL_SYSCONFDIR}/init.d/mysql
>>>>> +-                   ${INSTALL_SBINDIR}/rcmysql
>>>>> +-                   WORKING_DIRECTORY \$ENV{DESTDIR}${prefix})"
>>>>> +-                   COMPONENT SupportFiles)
>>>>> +   ENDIF(INSTALL_SYSCONFDIR)
>>>>> + ENDIF()
>>>>> diff --git a/meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb b/meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>>>>> similarity index 88%
>>>>> rename from meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb
>>>>> rename to meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>>>>> index d7895732a..4782f2b84 100644
>>>>> --- a/meta-oe/recipes-dbs/mysql/mariadb_5.5.62.bb
>>>>> +++ b/meta-oe/recipes-dbs/mysql/mariadb_10.3.13.bb
>>>>> @@ -2,7 +2,7 @@ require mariadb.inc
>>>>>
>>>>>    EXTRA_OECMAKE += "-DSTACK_DIRECTION=-1"
>>>>>
>>>>> -DEPENDS += "mariadb-native ncurses zlib readline libaio libevent"
>>>>> +DEPENDS += "mariadb-native bison-native openssl ncurses zlib readline libaio libevent"
>>>>>
>>>>>    PROVIDES += "mysql5 libmysqlclient"
>>>>>
>>>>> --
>>>>> 2.17.1
>>>>>
>>>>
>


More information about the Openembedded-devel mailing list