[oe] [meta-networking][PATCH] umip: add recipe

Khem Raj raj.khem at gmail.com
Tue Aug 6 16:00:16 UTC 2019


On 8/6/19 2:25 AM, Yi Zhao wrote:
> The umip has been removed in commit
> bb4aa80bfbd67ddfafeaf7700aff993592387a21 because it depends on
> ipsec-tools. But in fact the ipsec-tools is not the build dependency or
> essential runtime dependency for it.
> It is also supported by other ipsec tools. e.g strongswan
> (https://wiki.strongswan.org/projects/strongswan/wiki/MobileIPv6).
>
> Consider umip is the only implementation of Mobile IPv6 and NEMO Basic
> Support for Linux. So add the recipe back.


last commit to this package was in 2013, seems to tell me that this
package is long dead. Such packages are a huge maintainance cost when we
do major changes like toolchain bumps etc. I am not willing to
re-introduce it, since this all falls on me to keep fixing them

> Signed-off-by: Yi Zhao <yi.zhao at windriver.com>
> ---
>  ...ependency-to-support-parallel-compilation.patch |  33 +++++
>  .../0002-Add-format-string-to-fprintf-call.patch   |  28 ++++
>  ...GCLD-with-SIGCHLD-and-include-sys-types.h.patch |  41 ++++++
>  ...READ_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch | 143 +++++++++++++++++++++
>  .../umip/umip/0005-support-openssl-1.1.x.patch     |  88 +++++++++++++
>  .../recipes-connectivity/umip/umip/mip6d           | 112 ++++++++++++++++
>  .../recipes-connectivity/umip/umip/mip6d.service   |  10 ++
>  .../recipes-connectivity/umip/umip_1.0.bb          |  44 +++++++
>  8 files changed, 499 insertions(+)
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/0001-add-dependency-to-support-parallel-compilation.patch
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/0002-Add-format-string-to-fprintf-call.patch
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/0003-replace-SIGCLD-with-SIGCHLD-and-include-sys-types.h.patch
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/0004-replace-PTHREAD_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/0005-support-openssl-1.1.x.patch
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/mip6d
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip/mip6d.service
>  create mode 100644 meta-networking/recipes-connectivity/umip/umip_1.0.bb
>
> diff --git a/meta-networking/recipes-connectivity/umip/umip/0001-add-dependency-to-support-parallel-compilation.patch b/meta-networking/recipes-connectivity/umip/umip/0001-add-dependency-to-support-parallel-compilation.patch
> new file mode 100644
> index 0000000..05bc801
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/0001-add-dependency-to-support-parallel-compilation.patch
> @@ -0,0 +1,33 @@
> +From b7c799fda644876d3da3df54a158ecc30e1996ab Mon Sep 17 00:00:00 2001
> +From: "Roy.Li" <RongQing.Li at windriver.com>
> +Date: Mon, 5 Aug 2019 15:25:38 +0800
> +Subject: [PATCH] add dependency to support parallel compilation
> +
> +When "make -j10", the compilation will fail,
> +because scan.c has included gram.h, but gram.h was produced
> +after scan.c was compiled
> +
> +So add this dependency to ensure that gram.h is produced
> +before scan.c is produced.
> +
> +Upstream-Status: Inappropriate [upstream is not active]
> +
> +Signed-off-by: Roy.Li <RongQing.Li at windriver.com>
> +Signed-off-by: Jackie Huang <jackie.huang at windriver.com>
> +---
> + src/Makefile.am | 2 ++
> + 1 file changed, 2 insertions(+)
> +
> +diff --git a/src/Makefile.am b/src/Makefile.am
> +index e49cb4f..746baf2 100644
> +--- a/src/Makefile.am
> ++++ b/src/Makefile.am
> +@@ -81,3 +81,5 @@ CLEANFILES = gram.c gram.h \
> + 
> + DISTCLEANFILES = $(BUILT_SOURCES)
> + MAINTAINERCLEANFILES = Makefile.in
> ++
> ++scan.c: gram.h
> +-- 
> +2.7.4
> +
> diff --git a/meta-networking/recipes-connectivity/umip/umip/0002-Add-format-string-to-fprintf-call.patch b/meta-networking/recipes-connectivity/umip/umip/0002-Add-format-string-to-fprintf-call.patch
> new file mode 100644
> index 0000000..2468471
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/0002-Add-format-string-to-fprintf-call.patch
> @@ -0,0 +1,28 @@
> +From 7dfd213707ab2208addb5c34f5cee3c227f79de2 Mon Sep 17 00:00:00 2001
> +From: Khem Raj <raj.khem at gmail.com>
> +Date: Tue, 27 Jun 2017 07:48:31 -0700
> +Subject: [PATCH] Add format string to fprintf() call
> +
> +Upstream-Status: Pending
> +
> +Signed-off-by: Khem Raj <raj.khem at gmail.com>
> +---
> + src/vt.c | 2 +-
> + 1 file changed, 1 insertion(+), 1 deletion(-)
> +
> +diff --git a/src/vt.c b/src/vt.c
> +index 795d393..a533d3d 100644
> +--- a/src/vt.c
> ++++ b/src/vt.c
> +@@ -499,7 +499,7 @@ static int vt_cmd_dump_candidates(const struct vt_handle *vh,
> + 		}
> + 		llen += cmdlen;
> + 
> +-		ret = fprintf(vh->vh_stream, e->cmd);
> ++		ret = fprintf(vh->vh_stream, "%s", e->cmd);
> + 		if (ret < 0)
> + 			return ret;
> + 
> +-- 
> +2.7.4
> +
> diff --git a/meta-networking/recipes-connectivity/umip/umip/0003-replace-SIGCLD-with-SIGCHLD-and-include-sys-types.h.patch b/meta-networking/recipes-connectivity/umip/umip/0003-replace-SIGCLD-with-SIGCHLD-and-include-sys-types.h.patch
> new file mode 100644
> index 0000000..9605e8c
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/0003-replace-SIGCLD-with-SIGCHLD-and-include-sys-types.h.patch
> @@ -0,0 +1,41 @@
> +From ed33fc650456812454e331f98bf9fdc77245db1d Mon Sep 17 00:00:00 2001
> +From: Khem Raj <raj.khem at gmail.com>
> +Date: Sun, 4 Mar 2018 22:30:30 -0800
> +Subject: [PATCH] replace SIGCLD with SIGCHLD and include sys/types.h
> +
> +Fixes
> +main.c:129:10: error: 'SIGCLD' undeclared (first use in this function); did you mean 'SIGCHLD'?
> +   signal(SIGCLD, sig_child);
> +          ^~~~~~
> +          SIGCHLD
> +
> +main.c:125:2: warning: implicit declaration of function 'umask' [-Wimplicit-function-declaration]
> +  umask(0);
> +  ^~~~~
> +
> +Upstream-Status: Pending
> +
> +Signed-off-by: Khem Raj <raj.khem at gmail.com>
> +---
> + src/main.c | 4 ++--
> + 1 file changed, 2 insertions(+), 2 deletions(-)
> +
> +diff --git a/src/main.c b/src/main.c
> +index 79db0ec..8b09603 100644
> +--- a/src/main.c
> ++++ b/src/main.c
> +@@ -133,9 +133,9 @@ static void daemon_start(int ignsigcld)
> + 
> + 	if (ignsigcld) {
> + #ifdef SIGTSTP
> +-		signal(SIGCLD, sig_child);
> ++		signal(SIGCHLD, sig_child);
> + #else
> +-		signal(SIGCLD, SIG_IGN);
> ++		signal(SIGCHLD, SIG_IGN);
> + #endif
> + 	}
> + }
> +-- 
> +2.7.4
> +
> diff --git a/meta-networking/recipes-connectivity/umip/umip/0004-replace-PTHREAD_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch b/meta-networking/recipes-connectivity/umip/umip/0004-replace-PTHREAD_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch
> new file mode 100644
> index 0000000..b0901c4
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/0004-replace-PTHREAD_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch
> @@ -0,0 +1,143 @@
> +From 55d20b7ed07c05c8a8bc83eca70533f8c83c80fc Mon Sep 17 00:00:00 2001
> +From: Khem Raj <raj.khem at gmail.com>
> +Date: Sun, 4 Mar 2018 23:01:25 -0800
> +Subject: [PATCH] replace PTHREAD_MUTEX_FAST_NP with PTHREAD_MUTEX_NORMAL
> +
> +PTHREAD_MUTEX_FAST_NP is not available on non-posix systems
> +e.g. musl
> +
> +Upstream-Status: Pending
> +
> +Signed-off-by: Khem Raj <raj.khem at gmail.com>
> +---
> + src/ha.c        | 2 +-
> + src/icmp6.c     | 2 +-
> + src/mh.c        | 2 +-
> + src/mn.c        | 2 +-
> + src/movement.c  | 2 +-
> + src/mpdisc_ha.c | 2 +-
> + src/mpdisc_mn.c | 2 +-
> + src/tqueue.c    | 2 +-
> + src/tunnelctl.c | 2 +-
> + 9 files changed, 9 insertions(+), 9 deletions(-)
> +
> +diff --git a/src/ha.c b/src/ha.c
> +index 135ca8b..e6803e9 100644
> +--- a/src/ha.c
> ++++ b/src/ha.c
> +@@ -1262,7 +1262,7 @@ int ha_init(void)
> + {
> + 	pthread_mutexattr_t mattrs;
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&bu_worker_mutex, &mattrs) ||
> + 	    pthread_cond_init(&cond, NULL))
> + 		return -1;
> +diff --git a/src/icmp6.c b/src/icmp6.c
> +index 6da7234..02fc476 100644
> +--- a/src/icmp6.c
> ++++ b/src/icmp6.c
> +@@ -243,7 +243,7 @@ int icmp6_init(void)
> + 		return -1;
> + 	/* create ICMP listener thread */
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&icmp6_sock.send_mutex, &mattrs) ||
> + 	    pthread_rwlock_init(&handler_lock, NULL) ||
> + 	    pthread_create(&icmp6_listener, NULL, icmp6_listen, NULL))
> +diff --git a/src/mh.c b/src/mh.c
> +index 58185b3..cba9a33 100644
> +--- a/src/mh.c
> ++++ b/src/mh.c
> +@@ -204,7 +204,7 @@ int mh_init(void)
> + 		return -1;
> + 
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&mh_sock.send_mutex, &mattrs) ||
> + 	    pthread_rwlock_init(&handler_lock, NULL) ||
> + 	    pthread_create(&mh_listener, NULL, mh_listen, NULL))
> +diff --git a/src/mn.c b/src/mn.c
> +index 27de7aa..747ac13 100644
> +--- a/src/mn.c
> ++++ b/src/mn.c
> +@@ -1568,7 +1568,7 @@ static struct home_addr_info *hai_copy(struct home_addr_info *conf_hai)
> + 	if (hai != NULL) {
> + 		pthread_mutexattr_t mattrs;
> + 		pthread_mutexattr_init(&mattrs);
> +-		pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++		pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 
> + 		memcpy(hai, conf_hai, sizeof(struct home_addr_info));
> + 
> +diff --git a/src/movement.c b/src/movement.c
> +index 5ff1183..e215124 100644
> +--- a/src/movement.c
> ++++ b/src/movement.c
> +@@ -2019,7 +2019,7 @@ int md_init(void)
> + 	int val;
> + 
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&iface_lock, &mattrs))
> + 		return -1;
> + 
> +diff --git a/src/mpdisc_ha.c b/src/mpdisc_ha.c
> +index 5bb350e..cdc0f4b 100644
> +--- a/src/mpdisc_ha.c
> ++++ b/src/mpdisc_ha.c
> +@@ -572,7 +572,7 @@ int mpd_ha_init(void)
> + {
> + 	pthread_mutexattr_t mattrs;
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&mpa_lock, &mattrs) ||
> + 	    pthread_rwlock_init(&prefix_lock, NULL) ||
> + 	    hash_init(&mpa_hash, DOUBLE_ADDR, MPA_BUCKETS) < 0)
> +diff --git a/src/mpdisc_mn.c b/src/mpdisc_mn.c
> +index b6af8d2..ad34679 100644
> +--- a/src/mpdisc_mn.c
> ++++ b/src/mpdisc_mn.c
> +@@ -267,7 +267,7 @@ int mpd_mn_init(void)
> + {
> + 	pthread_mutexattr_t mattrs;
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&mps_lock, &mattrs))
> + 		return -1;
> + 	if (hash_init(&mps_hash, DOUBLE_ADDR, MPS_BUCKETS) < 0)
> +diff --git a/src/tqueue.c b/src/tqueue.c
> +index 2f7aa0b..9c185b8 100644
> +--- a/src/tqueue.c
> ++++ b/src/tqueue.c
> +@@ -65,7 +65,7 @@ int taskqueue_init(void)
> + {
> + 	pthread_mutexattr_t mattrs;
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&mutex, &mattrs) ||
> + 	    pthread_cond_init(&cond, NULL) ||
> + 	    pthread_create(&tq_runner, NULL, runner, NULL))
> +diff --git a/src/tunnelctl.c b/src/tunnelctl.c
> +index 23fc20b..813b8ec 100644
> +--- a/src/tunnelctl.c
> ++++ b/src/tunnelctl.c
> +@@ -433,7 +433,7 @@ int tunnelctl_init(void)
> + 		return -1;
> + 
> + 	pthread_mutexattr_init(&mattrs);
> +-	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_FAST_NP);
> ++	pthread_mutexattr_settype(&mattrs, PTHREAD_MUTEX_NORMAL);
> + 	if (pthread_mutex_init(&tnl_lock, &mattrs))
> + 		return -1;
> + 
> +-- 
> +2.7.4
> +
> diff --git a/meta-networking/recipes-connectivity/umip/umip/0005-support-openssl-1.1.x.patch b/meta-networking/recipes-connectivity/umip/umip/0005-support-openssl-1.1.x.patch
> new file mode 100644
> index 0000000..4d74d82
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/0005-support-openssl-1.1.x.patch
> @@ -0,0 +1,88 @@
> +From 58adc9c226e3c8e9468201055d4d41f91fdd617a Mon Sep 17 00:00:00 2001
> +From: Hongxu Jia <hongxu.jia at windriver.com>
> +Date: Tue, 25 Sep 2018 14:38:14 +0800
> +Subject: [PATCH] support openssl 1.1.x
> +
> +Long time no maintain from upstream since 2013
> +(git://git.umip.org/umip/umip.git), backport a
> +fix from openSUSE
> +
> +Upstream-Status: Backport [openSUSE]
> +http://ftp.gwdg.de/pub/opensuse/source/distribution/leap/15.0/repo/oss/src/mipv6d-2.0.2.umip.0.4-lp150.1.2.src.rpm
> +
> +Signed-off-by: Hongxu Jia <hongxu.jia at windriver.com>
> +---
> + src/keygen.c | 12 ++++++++++++
> + src/mh.c     | 17 ++++++++++++++++-
> + 2 files changed, 28 insertions(+), 1 deletion(-)
> +
> +diff --git a/src/keygen.c b/src/keygen.c
> +index e434a38..b902644 100644
> +--- a/src/keygen.c
> ++++ b/src/keygen.c
> +@@ -172,6 +172,7 @@ static void build_kgen_token(struct in6_addr *addr, uint8_t *nonce,
> + 	uint8_t tmp[20];
> + #ifdef HAVE_LIBCRYPTO
> + 	unsigned int len = 20;
> ++#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER < 0x1010006fL
> + 	HMAC_CTX ctx;
> + 
> + 	HMAC_CTX_init(&ctx);
> +@@ -182,6 +183,17 @@ static void build_kgen_token(struct in6_addr *addr, uint8_t *nonce,
> + 	HMAC_Final(&ctx, tmp, &len);
> + 	HMAC_CTX_cleanup(&ctx);
> + #else
> ++	HMAC_CTX *ctx;
> ++	ctx = HMAC_CTX_new();
> ++	HMAC_Init_ex(ctx, key_cn, sizeof(key_cn), EVP_sha1(), NULL);
> ++	HMAC_Update(ctx, (unsigned char *)addr, sizeof(*addr));
> ++	HMAC_Update(ctx, nonce, NONCE_LENGTH);
> ++	HMAC_Update(ctx, &id, sizeof(id));
> ++	HMAC_Final(ctx, tmp, &len);
> ++	HMAC_CTX_free(ctx);
> ++#endif // End of defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER < 0x1010006fL
> ++
> ++#else
> + 	HMAC_SHA1_CTX ctx;
> + 
> + 	HMAC_SHA1_init(&ctx, key_cn, sizeof(key_cn));
> +diff --git a/src/mh.c b/src/mh.c
> +index cba9a33..212eb5a 100644
> +--- a/src/mh.c
> ++++ b/src/mh.c
> +@@ -518,9 +518,10 @@ static int calculate_auth_data(const struct iovec *iov, int iovlen,
> + 
> + #ifdef HAVE_LIBCRYPTO
> + 	unsigned int len = HMAC_SHA1_HASH_LEN;
> +-	HMAC_CTX ctx;
> + 	const EVP_MD *evp_md = EVP_sha1();
> + 
> ++#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER < 0x1010006fL
> ++	HMAC_CTX ctx;
> + 	HMAC_CTX_init(&ctx);
> + 	HMAC_Init_ex(&ctx, key, HMAC_SHA1_KEY_SIZE, evp_md, NULL);
> + 
> +@@ -532,6 +533,20 @@ static int calculate_auth_data(const struct iovec *iov, int iovlen,
> + 	HMAC_Final(&ctx, buf, &len);
> + 	HMAC_CTX_cleanup(&ctx);
> + #else
> ++	HMAC_CTX *ctx;
> ++	ctx = HMAC_CTX_new();
> ++	HMAC_Init_ex(ctx, key, HMAC_SHA1_KEY_SIZE, evp_md, NULL);
> ++
> ++	HMAC_Update(ctx, (uint8_t *)coa, sizeof(*coa));
> ++	HMAC_Update(ctx, (uint8_t *)cn, sizeof(*coa));
> ++	for (i = 0; i < iovlen; i++) {
> ++		HMAC_Update(ctx, (uint8_t *)iov[i].iov_base, iov[i].iov_len);
> ++	}
> ++	HMAC_Final(ctx, buf, &len);
> ++	HMAC_CTX_free(ctx);
> ++#endif
> ++
> ++#else
> + 	HMAC_SHA1_CTX ctx;
> + 
> + 	HMAC_SHA1_init(&ctx, key, HMAC_SHA1_KEY_SIZE);
> +-- 
> +2.7.4
> +
> diff --git a/meta-networking/recipes-connectivity/umip/umip/mip6d b/meta-networking/recipes-connectivity/umip/umip/mip6d
> new file mode 100644
> index 0000000..ebd70a6
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/mip6d
> @@ -0,0 +1,112 @@
> +#!/bin/sh
> +#
> +# mip6d		Start script for the Mobile IPv6 daemon
> +#
> +# chkconfig:	- 55 25
> +# description:	The mobile IPv6 daemon allows nodes to remain \
> +#		reachable while moving around in the IPv6 Internet.
> +# processname:	mip6d
> +# config:	/etc/mip6d.conf
> +# config:	/etc/sysconfig/mip6d
> +#
> +### BEGIN INIT INFO
> +# Provides: mipv6-daemon
> +# Required-Start: $local_fs $remote_fs $network $named
> +# Required-Stop: $local_fs $remote_fs $network
> +# Should-Start: $syslog
> +# Should-Stop: $network $syslog
> +# Default-Start:
> +# Default-Stop: 0 1 6
> +# Short-Description: Start and stop Mobile IPV6 daemon
> +# Description:	The mobile IPv6 daemon allows nodes to remain
> +#		reachable while moving around in the IPv6 Internet.
> +### END INIT INFO
> +
> +# Source function library.
> +. /etc/init.d/functions
> +
> +if [ -f /etc/sysconfig/mip6d ]; then
> +	. /etc/sysconfig/mip6d
> +fi
> +
> +mip6d=/usr/sbin/mip6d
> +prog="mip6d"
> +lockfile=/var/lock/subsys/$prog
> +
> +start() {
> +	[ -x $mip6d ] || exit 5
> +	echo -n $"Starting $prog: "
> +	start-stop-daemon -S -x ${mip6d} && success || failure
> +	retval=$?
> +	echo
> +	[ $retval -eq 0 ] && touch ${lockfile}
> +	return $retval
> +}
> +
> +stop() {
> +	echo -n $"Stopping $prog: "
> +	start-stop-daemon -K -x $mip6d
> +	retval=$?
> +	echo
> +	[ $retval -eq 0 ] && rm -f ${lockfile}
> +	return $retval
> +}
> +
> +restart() {
> +	stop
> +	start
> +}
> +
> +reload()
> +{
> +	echo -n $"Reloading $prog configuration: "
> +	killproc $mip6d -HUP
> +	retval=$?
> +	echo
> +	return $retval
> +}
> +
> +force_reload() {
> +	restart
> +}
> +
> +rh_status() {
> +	status $prog
> +}
> +
> +rh_status_q() {
> +	rh_status > /dev/null 2>&1
> +}
> +
> +case "$1" in
> +  start)
> +	rh_status_q && exit 0
> +	$1
> +	;;
> +  stop)
> +	rh_status_q || exit 0
> +	$1
> +	;;
> +  restart)
> +	$1
> +	;;
> +  reload)
> +	rh_status_q || exit 7
> +	$1
> +	;;
> +  force-reload)
> +	force_reload
> +	;;
> +  status)
> +	rh_status
> +	;;
> +  condrestart|try-restart)
> +	rh_status_q || exit 0
> +	restart
> +	;;
> +  *)
> +	echo $"Usage: $prog {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
> +	exit 2
> +esac
> +
> +exit $?
> diff --git a/meta-networking/recipes-connectivity/umip/umip/mip6d.service b/meta-networking/recipes-connectivity/umip/umip/mip6d.service
> new file mode 100644
> index 0000000..2b5a5b9
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip/mip6d.service
> @@ -0,0 +1,10 @@
> +[Unit]
> +Description=MIPL Mobile IPv6
> +After=network.target
> +
> +[Service]
> +EnvironmentFile=- at SYSCONFDIR@/sysconfig/mip6d
> +ExecStart=@SBINDIR@/mip6d $ARGS
> +
> +[Install]
> +WantedBy=multi-user.target
> diff --git a/meta-networking/recipes-connectivity/umip/umip_1.0.bb b/meta-networking/recipes-connectivity/umip/umip_1.0.bb
> new file mode 100644
> index 0000000..dfb6582
> --- /dev/null
> +++ b/meta-networking/recipes-connectivity/umip/umip_1.0.bb
> @@ -0,0 +1,44 @@
> +SUMMARY = "Mobile IPv6 and NEMO for Linux"
> +DESCRIPTION = "UMIP is an open source implementation of Mobile IPv6 and NEMO \
> +Basic Support for Linux. It is released under the GPLv2 license. It supports \
> +the following IETF RFC: RFC6275 (Mobile IPv6), RFC3963 (NEMO), RFC3776 and \
> +RFC4877 (IPsec and IKEv2)."
> +HOMEPAGE = "http://umip.org/"
> +SECTION = "System Environment/Base"
> +LICENSE = "GPLv2"
> +LIC_FILES_CHKSUM = "file://COPYING;md5=073dc31ccb2ebed70db54f1e8aeb4c33"
> +
> +DEPENDS = "openssl indent-native bison-native"
> +
> +SRC_URI = "git://git.umip.org/umip/umip.git \
> +           file://0001-add-dependency-to-support-parallel-compilation.patch \
> +           file://0002-Add-format-string-to-fprintf-call.patch \
> +           file://0003-replace-SIGCLD-with-SIGCHLD-and-include-sys-types.h.patch \
> +           file://0004-replace-PTHREAD_MUTEX_FAST_NP-with-PTHREAD_MUTEX_NOR.patch \
> +           file://0005-support-openssl-1.1.x.patch \
> +           file://mip6d \
> +           file://mip6d.service \
> +           "
> +SRCREV = "cbd441c5db719db554ff2b4fcb02fef88ae2f791"
> +
> +S = "${WORKDIR}/git"
> +
> +EXTRA_OECONF = "--enable-vt"
> +
> +inherit autotools-brokensep systemd update-rc.d
> +
> +INITSCRIPT_NAME = "mip6d"
> +INITSCRIPT_PARAMS = "start 64 . stop 36 0 1 2 3 4 5 6 ."
> +
> +SYSTEMD_SERVICE_${PN} = "mip6d.service"
> +SYSTEMD_AUTO_ENABLE = "disable"
> +
> +do_install_append() {
> +    install -D -m 0755 ${WORKDIR}/mip6d ${D}${sysconfdir}/init.d/mip6d
> +    install -D -m 0644 ${WORKDIR}/mip6d.service ${D}${systemd_system_unitdir}/mip6d.service
> +    sed -i -e 's, at SYSCONFDIR@,${sysconfdir},g' \
> +        -e 's, at SBINDIR@,${sbindir},g' \
> +        ${D}${systemd_system_unitdir}/mip6d.service
> +}
> +
> +RRECOMMENDS_${PN} = "kernel-module-mip6 kernel-module-ipv6"
-------------- next part --------------
A non-text attachment was scrubbed...
Name: pEpkey.asc
Type: application/pgp-keys
Size: 2334 bytes
Desc: not available
URL: <http://lists.openembedded.org/pipermail/openembedded-devel/attachments/20190806/0c26871f/attachment-0001.bin>


More information about the Openembedded-devel mailing list