* [Buildroot] [PATCH v3 0/2] add frr package
@ 2020-02-25 15:53 Vadim Kochan
2020-02-25 15:53 ` [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for " Vadim Kochan
2020-02-25 15:53 ` [Buildroot] [PATCH v3 2/2] package/frr: new package Vadim Kochan
0 siblings, 2 replies; 5+ messages in thread
From: Vadim Kochan @ 2020-02-25 15:53 UTC (permalink / raw)
To: buildroot
FRR is free software that implements and manages various IPv4 and IPv6
routing protocols. It runs on nearly all distributions of Linux and BSD
as well as Solaris and supports all modern CPU architectures.
FRR currently supports the following protocols:
BGP
OSPFv2
OSPFv3
RIPv1
RIPv2
RIPng
IS-IS
PIM-SM/MSDP
LDP
BFD
Babel
PBR
OpenFabric
VRRP
EIGRP (alpha)
NHRP (alpha)
FRR package requires LYD_PRIV option to be enabled in
libyang package, so enabled it in separate patch if
frr is selected.
Disabled some options for frr package like:
- POSIX capabilities
- RPKi
v3:
1) Remove hook with bootsrap running, autoreconf handles everything
2) Remove _SOURCE var, it is auto-generated
3) Remove --disable-exampledir which causes install config samples
into "$(TARGET_DIR)no" folder, but remove them from $(TARGET_DIR)/etc/frr
in POST_INSTALL hook.
4) Enable LYD_PRIV option for libyang by default because there is no
size difference with or without this option.
v2:
1) fixed TAB indent on multiline var assignment
2) fixed ABC ordering
3) add missing 'depends on' from selected libs by frr
4) directly call /usr/sbin/frrinit.sh S50frr init script
w/o start-stop-daemon tool, frr cares of daemons stopping/
running.
5) Removed not-needed empty daemons *.conf files installation,
it was taken from building instructions in frr docs, but
really it is not required.
6) Use 0644 mask for conf files.
7) Enable LYD_PRIV option for libyang only if frr selected.
8) Drop patch with rtrlib package which is needed only for
RPKi support which is disabled by default.
9) Add AUTORECONF for bootstrap invocation.
10) Get rid of manual binaries target invocation. After frr.mk
cleanup it starts to work.
11) Install var/log/frr and /var/run/frr at runtime from init.
Vadim Kochan (2):
package/libyang: enable LYD_PRIV option for frr package
package/frr: new package
DEVELOPERS | 1 +
package/Config.in | 1 +
package/frr/Config.in | 25 ++++++++++++++
package/frr/S50frr | 46 +++++++++++++++++++++++++
package/frr/frr.hash | 2 ++
package/frr/frr.mk | 69 ++++++++++++++++++++++++++++++++++++++
package/libyang/libyang.mk | 3 +-
7 files changed, 146 insertions(+), 1 deletion(-)
create mode 100644 package/frr/Config.in
create mode 100644 package/frr/S50frr
create mode 100644 package/frr/frr.hash
create mode 100644 package/frr/frr.mk
--
2.17.1
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for frr package
2020-02-25 15:53 [Buildroot] [PATCH v3 0/2] add frr package Vadim Kochan
@ 2020-02-25 15:53 ` Vadim Kochan
2020-08-26 21:11 ` Thomas Petazzoni
2020-02-25 15:53 ` [Buildroot] [PATCH v3 2/2] package/frr: new package Vadim Kochan
1 sibling, 1 reply; 5+ messages in thread
From: Vadim Kochan @ 2020-02-25 15:53 UTC (permalink / raw)
To: buildroot
This option is required by frr package, so enable it by default as there
is no size difference with or without this option enabled.
Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
---
package/libyang/libyang.mk | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/package/libyang/libyang.mk b/package/libyang/libyang.mk
index 648ffeb6a3..e701c6f448 100644
--- a/package/libyang/libyang.mk
+++ b/package/libyang/libyang.mk
@@ -15,7 +15,8 @@ HOST_LIBYANG_DEPENDENCIES = host-pcre
LIBYANG_CONF_OPTS = \
-DENABLE_VALGRIND_TESTS=OFF \
- -DGEN_PYTHON_BINDINGS=OFF
+ -DGEN_PYTHON_BINDINGS=OFF \
+ -DENABLE_LYD_PRIV=ON
HOST_LIBYANG_CONF_OPTS = \
-DENABLE_VALGRIND_TESTS=OFF \
--
2.17.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [Buildroot] [PATCH v3 2/2] package/frr: new package
2020-02-25 15:53 [Buildroot] [PATCH v3 0/2] add frr package Vadim Kochan
2020-02-25 15:53 ` [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for " Vadim Kochan
@ 2020-02-25 15:53 ` Vadim Kochan
2020-08-26 21:13 ` Thomas Petazzoni
1 sibling, 1 reply; 5+ messages in thread
From: Vadim Kochan @ 2020-02-25 15:53 UTC (permalink / raw)
To: buildroot
FRR is free software that implements and manages various IPv4 and IPv6
routing protocols. It runs on nearly all distributions of Linux and BSD
as well as Solaris and supports all modern CPU architectures.
FRR currently supports the following protocols:
BGP
OSPFv2
OSPFv3
RIPv1
RIPv2
RIPng
IS-IS
PIM-SM/MSDP
LDP
BFD
Babel
PBR
OpenFabric
VRRP
EIGRP (alpha)
NHRP (alpha)
Some not-needed features were disabled to minimize package dependencies:
- POSIX capabilities
- RPKi
Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
---
DEVELOPERS | 1 +
package/Config.in | 1 +
package/frr/Config.in | 25 ++++++++++++++++
package/frr/S50frr | 46 +++++++++++++++++++++++++++++
package/frr/frr.hash | 2 ++
package/frr/frr.mk | 69 +++++++++++++++++++++++++++++++++++++++++++
6 files changed, 144 insertions(+)
create mode 100644 package/frr/Config.in
create mode 100644 package/frr/S50frr
create mode 100644 package/frr/frr.hash
create mode 100644 package/frr/frr.mk
diff --git a/DEVELOPERS b/DEVELOPERS
index 7d3d1ca11a..95ea2254de 100644
--- a/DEVELOPERS
+++ b/DEVELOPERS
@@ -2477,6 +2477,7 @@ F: package/tstools/
N: Vadim Kochan <vadim4j@gmail.com>
F: package/brcm-patchram-plus/
+F: package/frr/
F: package/gettext-tiny/
F: package/tinyssh/
diff --git a/package/Config.in b/package/Config.in
index dfa3f34b9d..3e6b51a745 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -1998,6 +1998,7 @@ menu "Networking applications"
source "package/fping/Config.in"
source "package/freeswitch/Config.in"
source "package/freeswitch-mod-bcg729/Config.in"
+ source "package/frr/Config.in"
source "package/gerbera/Config.in"
source "package/gesftpserver/Config.in"
source "package/glorytun/Config.in"
diff --git a/package/frr/Config.in b/package/frr/Config.in
new file mode 100644
index 0000000000..c0c3bdd693
--- /dev/null
+++ b/package/frr/Config.in
@@ -0,0 +1,25 @@
+config BR2_PACKAGE_FRR
+ bool "frr"
+ depends on BR2_TOOLCHAIN_HAS_THREADS
+ depends on !BR2_STATIC_LIBS # libyang
+ depends on BR2_USE_MMU # fork()
+ depends on BR2_PACKAGE_BASH # init
+ depends on BR2_TOOLCHAIN_HAS_SYNC_4 # json-c
+ select BR2_PACKAGE_C_ARES
+ select BR2_PACKAGE_LIBYANG
+ select BR2_PACKAGE_LIBNL
+ select BR2_PACKAGE_READLINE
+ select BR2_PACKAGE_JSON_C
+ help
+ The FRRouting Protocol Suite.
+
+ FRR is free software that implements and manages various IPv4 and
+ IPv6 routing protocols.
+
+ https://frrouting.org
+
+comment "frr needs BASH, threads, dynamic library"
+ depends on BR2_TOOLCHAIN_HAS_SYNC_4
+ depends on BR2_USE_MMU
+ depends on !BR2_PACKAGE_BASH || !BR2_TOOLCHAIN_HAS_THREADS || \
+ BR2_STATIC_LIBS
diff --git a/package/frr/S50frr b/package/frr/S50frr
new file mode 100644
index 0000000000..0c128353e9
--- /dev/null
+++ b/package/frr/S50frr
@@ -0,0 +1,46 @@
+#!/bin/sh
+
+DAEMON="frr"
+
+[ -r "/etc/default/$DAEMON" ] && . "/etc/default/$DAEMON"
+
+start() {
+ install -m 755 -o frr -g frr -d /var/run/frr
+ install -m 755 -o frr -g frr -d /var/log/frr
+
+ printf 'Starting %s: ' "$DAEMON"
+ /usr/sbin/frrinit.sh start
+ status=$?
+ if [ "$status" -eq 0 ]; then
+ echo "OK"
+ else
+ echo "FAIL"
+ fi
+ return "$status"
+}
+
+stop() {
+ printf 'Stopping %s: ' "$DAEMON"
+ /usr/sbin/frrinit.sh stop
+ status=$?
+ if [ "$status" -eq 0 ]; then
+ echo "OK"
+ else
+ echo "FAIL"
+ fi
+ return "$status"
+}
+
+restart() {
+ stop
+ sleep 1
+ start
+}
+
+case "$1" in
+ start|stop|restart)
+ "$1";;
+ *)
+ echo "Usage: $0 {start|stop|restart}"
+ exit 1
+esac
diff --git a/package/frr/frr.hash b/package/frr/frr.hash
new file mode 100644
index 0000000000..7d9ff7ea04
--- /dev/null
+++ b/package/frr/frr.hash
@@ -0,0 +1,2 @@
+sha256 c209ed66a0331221649b8c21dc8c6704ce1696e2017ef4d48f8c2ac6b1fa01b7 frr-7.3.tar.gz
+sha256 8177f97513213526df2cf6184d8ff986c675afb514d4e68a404010521b880643 COPYING
diff --git a/package/frr/frr.mk b/package/frr/frr.mk
new file mode 100644
index 0000000000..2add98542a
--- /dev/null
+++ b/package/frr/frr.mk
@@ -0,0 +1,69 @@
+################################################################################
+#
+# frr
+#
+################################################################################
+
+FRR_VERSION = 7.3
+FRR_SITE = https://github.com/FRRouting/frr/archive
+FRR_LICENSE = GPL-2.0
+FRR_LICENSE_FILES = COPYING
+FRR_AUTORECONF = YES
+
+FRR_DEPENDENCIES = host-frr readline json-c \
+ libyang libnl c-ares
+
+HOST_FRR_DEPENDENCIES = host-flex host-bison host-python
+
+FRR_CONF_OPTS = --with-clippy=$(HOST_DIR)/bin/clippy \
+ --sysconfdir=/etc/frr \
+ --localstatedir=/var/run/frr \
+ --with-moduledir=/usr/lib/frr/modules \
+ --enable-configfile-mask=0640 \
+ --enable-logfile-mask=0640 \
+ --enable-multipath=256 \
+ --disable-ospfclient \
+ --enable-shell-access \
+ --enable-user=frr \
+ --enable-group=frr \
+ --enable-vty-group=frrvty \
+ --disable-capabilities \
+ --enable-fpm
+
+HOST_FRR_CONF_OPTS = --enable-clippy-only
+
+define HOST_FRR_INSTALL_CMDS
+ $(INSTALL) -D -m 0755 $(@D)/lib/clippy $(HOST_DIR)/bin/clippy
+endef
+
+define FRR_INSTALL_CONFIG_FILES
+ $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/frr
+
+ $(foreach f,daemons daemons.conf frr.conf vtysh.conf support_bundle_commands.conf,\
+ $(INSTALL) -D -m 0640 $(@D)/tools/etc/frr/$(f) \
+ $(TARGET_DIR)/etc/frr/$(f)
+ )
+
+ $(RM) $(TARGET_DIR)/etc/frr/*.sample
+endef
+FRR_POST_INSTALL_TARGET_HOOKS += FRR_INSTALL_CONFIG_FILES
+
+define FRR_PERMISSIONS
+ /etc/frr/daemons f 640 frr frr - - - - -
+ /etc/frr/daemons.conf f 640 frr frr - - - - -
+ /etc/frr/frr.conf f 640 frr frr - - - - -
+ /etc/frr/vtysh.conf f 640 frr frrvty - - - - -
+ /etc/frr/support_bundle_commands.conf f 640 frr frr
+endef
+
+define FRR_USERS
+ frr -1 frr -1 * /var/run/frr - frrvty FRR user priv
+endef
+
+define FRR_INSTALL_INIT_SYSV
+ $(INSTALL) -D -m 755 $(FRR_PKGDIR)/S50frr \
+ $(TARGET_DIR)/etc/init.d/S50frr
+endef
+
+$(eval $(autotools-package))
+$(eval $(host-autotools-package))
--
2.17.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for frr package
2020-02-25 15:53 ` [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for " Vadim Kochan
@ 2020-08-26 21:11 ` Thomas Petazzoni
0 siblings, 0 replies; 5+ messages in thread
From: Thomas Petazzoni @ 2020-08-26 21:11 UTC (permalink / raw)
To: buildroot
On Tue, 25 Feb 2020 17:53:21 +0200
Vadim Kochan <vadim4j@gmail.com> wrote:
> This option is required by frr package, so enable it by default as there
> is no size difference with or without this option enabled.
>
> Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
> ---
> package/libyang/libyang.mk | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
Applied to next, thanks.
Thomas
--
Thomas Petazzoni, CTO, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com
^ permalink raw reply [flat|nested] 5+ messages in thread
* [Buildroot] [PATCH v3 2/2] package/frr: new package
2020-02-25 15:53 ` [Buildroot] [PATCH v3 2/2] package/frr: new package Vadim Kochan
@ 2020-08-26 21:13 ` Thomas Petazzoni
0 siblings, 0 replies; 5+ messages in thread
From: Thomas Petazzoni @ 2020-08-26 21:13 UTC (permalink / raw)
To: buildroot
On Tue, 25 Feb 2020 17:53:22 +0200
Vadim Kochan <vadim4j@gmail.com> wrote:
> FRR is free software that implements and manages various IPv4 and IPv6
> routing protocols. It runs on nearly all distributions of Linux and BSD
> as well as Solaris and supports all modern CPU architectures.
>
> FRR currently supports the following protocols:
>
> BGP
> OSPFv2
> OSPFv3
> RIPv1
> RIPv2
> RIPng
> IS-IS
> PIM-SM/MSDP
> LDP
> BFD
> Babel
> PBR
> OpenFabric
> VRRP
> EIGRP (alpha)
> NHRP (alpha)
>
> Some not-needed features were disabled to minimize package dependencies:
>
> - POSIX capabilities
> - RPKi
>
> Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
I've applied to next, with a few changes, see below.
> diff --git a/package/frr/Config.in b/package/frr/Config.in
> new file mode 100644
> index 0000000000..c0c3bdd693
> --- /dev/null
> +++ b/package/frr/Config.in
> @@ -0,0 +1,25 @@
> +config BR2_PACKAGE_FRR
> + bool "frr"
> + depends on BR2_TOOLCHAIN_HAS_THREADS
> + depends on !BR2_STATIC_LIBS # libyang
> + depends on BR2_USE_MMU # fork()
> + depends on BR2_PACKAGE_BASH # init
I've selected bash instead of depending on it.
> + depends on BR2_TOOLCHAIN_HAS_SYNC_4 # json-c
> + select BR2_PACKAGE_C_ARES
> + select BR2_PACKAGE_LIBYANG
> + select BR2_PACKAGE_LIBNL
> + select BR2_PACKAGE_READLINE
> + select BR2_PACKAGE_JSON_C
> + help
> + The FRRouting Protocol Suite.
> +
> + FRR is free software that implements and manages various IPv4 and
> + IPv6 routing protocols.
> +
> + https://frrouting.org
> +
> +comment "frr needs BASH, threads, dynamic library"
> + depends on BR2_TOOLCHAIN_HAS_SYNC_4
> + depends on BR2_USE_MMU
> + depends on !BR2_PACKAGE_BASH || !BR2_TOOLCHAIN_HAS_THREADS || \
> + BR2_STATIC_LIBS
And so I dropped the "bash" part of this comment.
> +start() {
> + install -m 755 -o frr -g frr -d /var/run/frr
> + install -m 755 -o frr -g frr -d /var/log/frr
> +
> + printf 'Starting %s: ' "$DAEMON"
> + /usr/sbin/frrinit.sh start
It's not really great to have the Buildroot init script call another
sort of init script. But looking into the frrinit.sh and ffrcommon.sh
stuff, we can't really re-invent all this in Buildroot, it would be a
nightmare to maintain, so we really have to re-use what upstream
provides, like you did.
> diff --git a/package/frr/frr.mk b/package/frr/frr.mk
> new file mode 100644
> index 0000000000..2add98542a
> --- /dev/null
> +++ b/package/frr/frr.mk
> @@ -0,0 +1,69 @@
> +################################################################################
> +#
> +# frr
> +#
> +################################################################################
> +
> +FRR_VERSION = 7.3
I've updated to 7.4, as 7.3 didn't build for me with uClibc-ng, due to
the use of non-standard TRUE/FALSE. This was fixed in 7.4, which uses
the standard true/false definitions.
> +FRR_SITE = https://github.com/FRRouting/frr/archive
Changed to use the github macro we have.
> +FRR_DEPENDENCIES = host-frr readline json-c \
> + libyang libnl c-ares
> +
> +HOST_FRR_DEPENDENCIES = host-flex host-bison host-python
Changed to use host-python3. We generally try to use host-python3
whenever possible nowadays.
> +define FRR_INSTALL_CONFIG_FILES
> + $(INSTALL) -d -m 0755 $(TARGET_DIR)/etc/frr
Not needed, as you're using $(INSTALL) -D below
> +
> + $(foreach f,daemons daemons.conf frr.conf vtysh.conf support_bundle_commands.conf,\
> + $(INSTALL) -D -m 0640 $(@D)/tools/etc/frr/$(f) \
> + $(TARGET_DIR)/etc/frr/$(f)
Indented with one more tab the last line.
That's it!
Thomas
--
Thomas Petazzoni, CTO, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2020-08-26 21:13 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-02-25 15:53 [Buildroot] [PATCH v3 0/2] add frr package Vadim Kochan
2020-02-25 15:53 ` [Buildroot] [PATCH v3 1/2] package/libyang: enable LYD_PRIV option for " Vadim Kochan
2020-08-26 21:11 ` Thomas Petazzoni
2020-02-25 15:53 ` [Buildroot] [PATCH v3 2/2] package/frr: new package Vadim Kochan
2020-08-26 21:13 ` Thomas Petazzoni
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.