From 96e1d7e81b9cff8664347c1a306c0fba10591c6c Mon Sep 17 00:00:00 2001 From: Stefan Schmidt <stefan.schmidt@huawei.com> Date: Thu, 28 Jan 2021 20:43:14 +0100 Subject: [PATCH] ot-br-posix: Add OpenThread border router recipe Two additional patches to make it build with musl. Closes: https://git.ostc-eu.org/OSTC/planning/core-os/-/issues/2 Signed-off-by: Stefan Schmidt <stefan.schmidt@huawei.com> --- ...p-Werror-to-avoid-compilation-breaks.patch | 32 +++++++++++++++ ...lient-add-needed-header-for-fd_set-c.patch | 27 +++++++++++++ .../openthread/ot-br-posix_git.bb | 40 +++++++++++++++++++ 3 files changed, 99 insertions(+) create mode 100644 meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-build-drop-Werror-to-avoid-compilation-breaks.patch create mode 100644 meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-web-service-ot-client-add-needed-header-for-fd_set-c.patch create mode 100644 meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix_git.bb diff --git a/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-build-drop-Werror-to-avoid-compilation-breaks.patch b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-build-drop-Werror-to-avoid-compilation-breaks.patch new file mode 100644 index 00000000..32ba4171 --- /dev/null +++ b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-build-drop-Werror-to-avoid-compilation-breaks.patch @@ -0,0 +1,32 @@ +From 592605f1f1d3b8bf1cbe9371b1e80b7521794dc1 Mon Sep 17 00:00:00 2001 +From: Stefan Schmidt <stefan.schmidt@huawei.com> +Date: Sat, 6 Feb 2021 12:37:57 +0100 +Subject: [PATCH] build: drop -Werror to avoid compilation breaks. + +We had a warning turning into an error and breaking the compilation: + error: #warning _FORTIFY_SOURCE requires compiling with optimization (-O) [-Werror=cpp] + 397 | # warning _FORTIFY_SOURCE requires compiling with optimization (-O) + +This patch works around this for now. A better way to avoid the warning +in the first place is needed. + +Upstream-Status: Inappropriate [other] + +Signed-off-by: Stefan Schmidt <stefan.schmidt@huawei.com> +--- + CMakeLists.txt | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/CMakeLists.txt b/CMakeLists.txt +index 8bbde8c0..2fe251ce 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -59,7 +59,7 @@ if (OTBR_COVERAGE AND CMAKE_CXX_COMPILER_ID MATCHES "GNU|Clang") + target_link_libraries(otbr-config INTERFACE --coverage) + endif() + +-add_compile_options(-Wall -Wextra -Werror -Wfatal-errors -Wno-missing-braces) ++add_compile_options(-Wall -Wextra -Wfatal-errors -Wno-missing-braces) + + + execute_process( diff --git a/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-web-service-ot-client-add-needed-header-for-fd_set-c.patch b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-web-service-ot-client-add-needed-header-for-fd_set-c.patch new file mode 100644 index 00000000..46679215 --- /dev/null +++ b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix/0001-web-service-ot-client-add-needed-header-for-fd_set-c.patch @@ -0,0 +1,27 @@ +From 596eb2b582609794d87f2dbefa4b2e839faf52c8 Mon Sep 17 00:00:00 2001 +From: Stefan Schmidt <stefan.schmidt@huawei.com> +Date: Fri, 28 May 2021 14:19:53 +0200 +Subject: [PATCH] web-service/ot-client: add needed header for fd_set() call + +The select.h header file is needed for fd_set(). Depending on the +compiler and settings this will result in an error when not included. + +Upstream-Status: Pending + +Signed-off-by: Stefan Schmidt <stefan.schmidt@huawei.com> +--- + src/web/web-service/ot_client.cpp | 1 + + 1 file changed, 1 insertion(+) + +diff --git a/src/web/web-service/ot_client.cpp b/src/web/web-service/ot_client.cpp +index f151a0126..173cc48e1 100644 +--- a/src/web/web-service/ot_client.cpp ++++ b/src/web/web-service/ot_client.cpp +@@ -39,6 +39,7 @@ + #include <string.h> + #include <sys/socket.h> + #include <sys/un.h> ++#include <sys/select.h> + #include <unistd.h> + + #include "common/code_utils.hpp" diff --git a/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix_git.bb b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix_git.bb new file mode 100644 index 00000000..6d119259 --- /dev/null +++ b/meta-ohos-staging/recipes-connectivity/openthread/ot-br-posix_git.bb @@ -0,0 +1,40 @@ +# SPDX-FileCopyrightText: Huawei Inc. +# +# SPDX-License-Identifier: Apache-2.0 + +SUMMARY = "OpenThread Border Router" +SECTION = "net" +LICENSE = "BSD-3-Clause & MIT & Apache-2.0" +LIC_FILES_CHKSUM = "file://LICENSE;md5=87109e44b2fda96a8991f27684a7349c \ + file://third_party/Simple-web-server/repo/LICENSE;md5=852b3f7f320b19f6431487b8b2fb1d74 \ + file://third_party/angular-material/repo/LICENSE;md5=3d0c299b7dd4267c3ef21a705cf6a5c6 \ + file://third_party/angular/repo/LICENSE.md;md5=0d83982330e37f011a2cef9b15cb43aa \ + file://third_party/cJSON/repo/LICENSE;md5=218947f77e8cb8e2fa02918dc41c50d0 \ + file://third_party/d3js/repo/LICENSE;md5=e863f3b38093ec361d12ed4ff001c403 \ + file://third_party/http-parser/repo/LICENSE-MIT;md5=9bfa835d048c194ab30487af8d7b3778 \ + file://third_party/mdl/repo/LICENSE;md5=6f740e801ce5a08c6c113bf72859bff2 \ + file://third_party/openthread/repo/LICENSE;md5=543b6fe90ec5901a683320a36390c65f \ + " + +SRC_URI = "gitsm://github.com/openthread/ot-br-posix.git;protocol=https \ + file://0001-build-drop-Werror-to-avoid-compilation-breaks.patch \ + file://0001-web-service-ot-client-add-needed-header-for-fd_set-c.patch \ + " + +PV = "0.2+git${SRCPV}" +SRCREV = "5de1086daa12fda3d6d2b8b7d0f8954b709d5f66" + +S = "${WORKDIR}/git" + +DEPENDS = "autoconf-archive dbus readline avahi jsoncpp boost" + +inherit cmake systemd + +SYSTEMD_SERVICE_${PN} = "otbr-agent.service otbr-web.service" + +EXTRA_OECMAKE = "-DBUILD_TESTING=OFF -DOTBR_DBUS=ON -DOTBR_REST=ON -DOTBR_WEB=ON -DCMAKE_LIBRARY_PATH=${libdir}" + +FILES_${PN} += "${systemd_unitdir}/*" +FILES_${PN} += "${datadir}/*" + +RCONFLICTS_${PN} = "ot-daemon" -- GitLab