SUMMARY = "Versatile implementation of the Network Time Protocol" 
 | 
DESCRIPTION = "Chrony can synchronize the system clock with NTP \ 
 | 
servers, reference clocks (e.g. GPS receiver), and manual input using \ 
 | 
wristwatch and keyboard. It can also operate as an NTPv4 (RFC 5905) \ 
 | 
server and peer to provide a time service to other computers in the \ 
 | 
network. \ 
 | 
\ 
 | 
It is designed to perform well in a wide range of conditions, \ 
 | 
including intermittent network connections, heavily congested \ 
 | 
networks, changing temperatures (ordinary computer clocks are \ 
 | 
sensitive to temperature), and systems that do not run continuously, or \ 
 | 
run on a virtual machine. \ 
 | 
\ 
 | 
Typical accuracy between two machines on a LAN is in tens, or a few \ 
 | 
hundreds, of microseconds; over the Internet, accuracy is typically \ 
 | 
within a few milliseconds. With a good hardware reference clock \ 
 | 
sub-microsecond accuracy is possible. \ 
 | 
\ 
 | 
Two programs are included in chrony: chronyd is a daemon that can be \ 
 | 
started at boot time and chronyc is a command-line interface program \ 
 | 
which can be used to monitor chronyd's performance and to change \ 
 | 
various operating parameters whilst it is running. \ 
 | 
\ 
 | 
This recipe produces two binary packages: 'chrony' which contains chronyd, \ 
 | 
the configuration file and the init script, and 'chronyc' which contains \ 
 | 
the client program only." 
 | 
  
 | 
HOMEPAGE = "https://chrony.tuxfamily.org/" 
 | 
SECTION = "net" 
 | 
LICENSE = "GPLv2" 
 | 
LIC_FILES_CHKSUM = "file://COPYING;md5=751419260aa954499f7abaabaa882bbe" 
 | 
  
 | 
SRC_URI = "https://download.tuxfamily.org/chrony/chrony-${PV}.tar.gz \ 
 | 
    file://chrony.conf \ 
 | 
    file://chronyd \ 
 | 
    file://arm_eabi.patch \ 
 | 
" 
 | 
  
 | 
SRC_URI:append:libc-musl = " \ 
 | 
    file://0001-Fix-compilation-with-musl.patch \ 
 | 
" 
 | 
SRC_URI[sha256sum] = "ed76f2d3f9347ac6221a91ad4bd553dd0565ac188cd7490d0801d08f7171164c" 
 | 
  
 | 
DEPENDS = "pps-tools" 
 | 
  
 | 
# Note: Despite being built via './configure; make; make install', 
 | 
#       chrony does not use GNU Autotools. 
 | 
inherit update-rc.d systemd 
 | 
  
 | 
# Add chronyd user if privdrop packageconfig is selected 
 | 
inherit ${@bb.utils.contains('PACKAGECONFIG', 'privdrop', 'useradd', '', d)} 
 | 
USERADD_PACKAGES = "${@bb.utils.contains('PACKAGECONFIG', 'privdrop', '${PN}', '', d)}" 
 | 
USERADD_PARAM:${PN} += "${@bb.utils.contains('PACKAGECONFIG', 'privdrop', '--system -d / -M --shell /bin/nologin chronyd;', '', d)}" 
 | 
  
 | 
# Configuration options: 
 | 
# - For command line editing support in chronyc, you may specify either 
 | 
#   'editline' or 'readline' but not both.  editline is smaller, but 
 | 
#   many systems already have readline for other purposes so you might want 
 | 
#   to choose that instead.  However, beware license incompatibility 
 | 
#   since chrony is GPLv2 and readline versions after 6.0 are GPLv3+. 
 | 
#   You can of course choose neither, but if you're that tight on space 
 | 
#   consider dropping chronyc entirely (you can use it remotely with 
 | 
#   appropriate chrony.conf options). 
 | 
# - Security-related: 
 | 
#   - 'sechash' is omitted by default because it pulls in nss which is huge. 
 | 
#   - 'privdrop' allows chronyd to run as non-root; would need changes to 
 | 
#     chrony.conf and init script. 
 | 
#   - 'scfilter' enables support for system call filtering, but requires the 
 | 
#     kernel to have CONFIG_SECCOMP enabled. 
 | 
PACKAGECONFIG ??= "editline \ 
 | 
    ${@bb.utils.filter('DISTRO_FEATURES', 'ipv6', d)} \ 
 | 
" 
 | 
PACKAGECONFIG[readline] = "--without-editline,--without-readline,readline" 
 | 
PACKAGECONFIG[editline] = ",--without-editline,libedit" 
 | 
PACKAGECONFIG[sechash] = "--without-tomcrypt,--disable-sechash,nss" 
 | 
PACKAGECONFIG[privdrop] = "--with-libcap,--disable-privdrop --without-libcap,libcap" 
 | 
PACKAGECONFIG[scfilter] = "--enable-scfilter,--without-seccomp,libseccomp" 
 | 
PACKAGECONFIG[ipv6] = ",--disable-ipv6," 
 | 
PACKAGECONFIG[nss] = "--with-nss,--without-nss,nss" 
 | 
PACKAGECONFIG[libcap] = "--with-libcap,--without-libcap,libcap" 
 | 
  
 | 
# --disable-static isn't supported by chrony's configure script. 
 | 
DISABLE_STATIC = "" 
 | 
  
 | 
do_configure() { 
 | 
    ./configure --sysconfdir=${sysconfdir} --bindir=${bindir} --sbindir=${sbindir} \ 
 | 
                --localstatedir=${localstatedir} --datarootdir=${datadir} \ 
 | 
                --with-ntp-era=$(shell date -d '1970-01-01 00:00:00+00:00' +'%s') \ 
 | 
                --with-pidfile=/run/chrony/chronyd.pid \ 
 | 
                --chronyrundir=/run/chrony \ 
 | 
                --host-system=Linux \ 
 | 
                ${PACKAGECONFIG_CONFARGS} 
 | 
} 
 | 
  
 | 
do_install() { 
 | 
    # Binaries 
 | 
    install -d ${D}${bindir} 
 | 
    install -m 0755 ${S}/chronyc ${D}${bindir} 
 | 
    install -d ${D}${sbindir} 
 | 
    install -m 0755 ${S}/chronyd ${D}${sbindir} 
 | 
  
 | 
    # Config file 
 | 
    install -d ${D}${sysconfdir} 
 | 
    install -m 644 ${WORKDIR}/chrony.conf ${D}${sysconfdir} 
 | 
    if ${@bb.utils.contains('PACKAGECONFIG', 'privdrop', 'true', 'false', d)}; then 
 | 
        echo "# Define user to drop to after dropping root privileges" >> ${D}${sysconfdir}/chrony.conf 
 | 
        echo "user chronyd" >> ${D}${sysconfdir}/chrony.conf 
 | 
    fi 
 | 
  
 | 
    # System V init script 
 | 
    install -d ${D}${sysconfdir}/init.d 
 | 
    install -m 755 ${WORKDIR}/chronyd ${D}${sysconfdir}/init.d 
 | 
  
 | 
    # systemd unit configuration file 
 | 
    install -d ${D}${systemd_unitdir}/system 
 | 
    install -m 0644 ${S}/examples/chronyd.service ${D}${systemd_unitdir}/system/ 
 | 
  
 | 
    # Variable data (for drift and/or rtc file) 
 | 
    install -d ${D}${localstatedir}/lib/chrony 
 | 
  
 | 
    # Fix hard-coded paths in config files and init scripts 
 | 
    sed -i -e 's!/var/!${localstatedir}/!g' -e 's!/etc/!${sysconfdir}/!g' \ 
 | 
           -e 's!/usr/sbin/!${sbindir}/!g' -e 's!/usr/bin/!${bindir}/!g' \ 
 | 
           ${D}${sysconfdir}/chrony.conf \ 
 | 
           ${D}${sysconfdir}/init.d/chronyd \ 
 | 
           ${D}${systemd_unitdir}/system/chronyd.service 
 | 
    sed -i 's!^PATH=.*!PATH=${base_sbindir}:${base_bindir}:${sbindir}:${bindir}!' ${D}${sysconfdir}/init.d/chronyd 
 | 
    sed -i 's!^EnvironmentFile=.*!EnvironmentFile=-${sysconfdir}/default/chronyd!' ${D}${systemd_unitdir}/system/chronyd.service 
 | 
} 
 | 
  
 | 
FILES:${PN} = "${sbindir}/chronyd ${sysconfdir} ${localstatedir}/lib/chrony ${localstatedir}" 
 | 
CONFFILES:${PN} = "${sysconfdir}/chrony.conf" 
 | 
INITSCRIPT_NAME = "chronyd" 
 | 
INITSCRIPT_PARAMS = "defaults" 
 | 
SYSTEMD_PACKAGES = "${PN}" 
 | 
SYSTEMD_SERVICE:${PN} = "chronyd.service" 
 | 
  
 | 
# It's probably a bad idea to run chrony and another time daemon on 
 | 
# the same system.  systemd includes the SNTP client 'timesyncd', which 
 | 
# will be disabled by chronyd.service, however it will remain on the rootfs 
 | 
# wasting 150 kB unless you put 'PACKAGECONFIG:remove:pn-systemd = "timesyncd"' 
 | 
# in a conf file or bbappend somewhere. 
 | 
RCONFLICTS:${PN} = "ntp ntimed" 
 | 
  
 | 
# Separate the client program into its own package 
 | 
PACKAGES =+ "chronyc" 
 | 
FILES:chronyc = "${bindir}/chronyc" 
 |