All notable changes to the project are documented in this file.
- Upgrade Linux kernel to 6.18.16 (LTS)
- Revamped http://network.local device browser. Device cards now show the IP address, product name, and firmware version from mDNS TXT records. the mDNS browser is now also available over plain HTTP
- mDNS service records now embed the per-device hostname (using avahi's
%hwildcard), so devices avoid the#2,#3suffix collisions on service names when multiple Infix devices share the same LAN - Add configurable mDNS hostname: set
services mdns hostnameto override the mDNS name advertised in A/AAAA records. Supports%h(default hostname),%i(hardware ID), and%m(MAC address) format specifiers - cli: new
show mdnscommand to list mDNS-discovered devices on the LAN, with addresses and product model - Add SSH client commands to the CLI:
ssh [user <name>] [port <num>] <host>— connect to a remote deviceset ssh known-hosts <host> <keytype> <pubkey>— pre-enroll a host key received out-of-band, e.g. after a factory reset changes the device host keyno ssh known-hosts <host>— remove a stale or changed host key entry
- Add OSPF point-to-multipoint (P2MP) and hybrid interface type support
- Fix #1387:
infix.localnow resolves to exactly one device per LAN. Previously all Infix devices claimed bothhostname.localandinfix.local, causing avahi to append#2,#3suffixes to the shared alias on busy networks. Assignment is now first-come-first-served using standard mDNS conflict resolution - Fix #1416:
show firewallcommand show an error when the firewall is disabled - Fix regression in MVEBU SafeXcel Crypto Engine for Marvell Armada SOCs (37xx, 7k, 8k, and CN913x series). Firmware package lost in v26.01.0
v26.02.0 - 2026-03-01
Note
The blog and User Guide have a new address: https://www.kernelkit.org
- Upgrade Linux kernel to 6.18.15 (LTS)
- Upgrade Buildroot to 2025.02.11 (LTS)
- Upgrade FRR to 10.5.1
- Add support for Microchip SAMA7G54 Evaluation Kit, Arm Cortex-A7
- Add support for Banana Pi R3 Mini, a 2 port router with 2 WiFi chip, uses the same bootloader as BPI-R3 (eMMC-version)
- Add GPS/GNSS receiver support with NTP reference clock integration
- Add
reset-volumesoption tocontainer upgrade foocommand
- Fix CLI
copycommand problem to copy to scp/sftp destinations
v26.01.0 - 2026-02-03
Important
This release includes breaking changes to WiFi configuration that will result in existing configuration being disabled:
- WiFi station/client configuration has been restructured. The
wificontainer now requires aradioreference, and station configuration has moved under awifi/stationcontainer. Existing WiFi configurations must be manually updated - WiFi radios are now configured via
ietf-hardwareinstead of the interfaces module
Also, Raspberry Pi users must upgrade the bootloader before upgrading to
this release. We recommend backing up your startup-config.cfg and reflash
the SD card with a new sd card image.
Noteworthy changes and additions in this release are marked below in bold text.
- Upgrade Linux kernel from 6.12.65 to 6.18.8 (LTS)
- Upgrade Buildroot to 2025.02.10 (LTS)
- Upgrade libyang to 4.2.2
- Upgrade sysrepo to 4.2.10
- Upgrade netopeer2 (NETCONF) to 2.7.0
- Add RIPv2 routing support, issue #582
- Add NTP server support, issue #904
- Migrate DHCPv6 client to odhcp6c for improved Router Advertisement integration. Adds support for hybrid RA+DHCPv6 deployments where SLAAC assigns addresses and DHCPv6 provides DNS (common ISP scenario)
- Add support for configurable OSPF debug logging, issue #1281. Debug options can now be enabled per category (bfd, packet, ism, nsm, default-information, nssa). All debug options are disabled by default to prevent log flooding in production environments. See the documentation for usage examples
- Add support for configurable container resource limits, memory and CPU. Resource usage is available through the operational datastore, where the currently active resource limits in the container runtime are also available
- Add support for "routing interfaces", issue #647. Lists interfaces with IP
forwarding. Inspect from CLI using
show interface, look for⇅flag - Add operational data journal to statd with hierarchical time-based retention policy, keeping snapshots from every 5 minutes (recent) to yearly (historical)
- Add support data collection script, useful when troubleshooting issues on deployed systems. Gathers system information, logs, and more. Issue #1287
- Add WiFi Access Point (AP) mode with multi-SSID support and WPA2/WPA3
security. BREAKING: WiFi architecture refactored with radios configured
via
ietf-hardwareand interfaces requiringradioreference. Station config moved towifi/stationcontainer. Existing Wi-Fi interfaces will be removed during upgrade (for the rest of the configuration to apply) and you need to reconfigure them again. See the WiFi documentation for details - Add support for WireGuard VPN tunnels.
- Updated CLI change command to support
cleartext-symmetric-key(type binary). Used by both WireGuard and WiFi, with application-specifickey-formatfor keys and passphrases - New default NACM privilege levels (user levels) in
factory-config:operator(network & container manager) andguest(read-only). For details, see the updated system configuration documentation, as well as a new dedicated NACM configuration guide - New
show nacmadmin-exec command to inspect access control rules - CLI now supports Ctrl-@ and Ctrl-w/Meta-w to mark and copy test regions
- CLI now uses
copyandrpctools instead of deprecatedsysrepocfg. The latter now also require the use ofsudoforadminlevel users - Enhanced
copycommand with XPath filtering support - Kernel now announces details of new USB devices
- Fix #515: add per-interface IPv6 forwarding control using the Linux 6.17+
force_forwardingsysctl. This provides true per-interface IPv6 forwarding similar to IPv4, correctly mapping to the ietf-ip.yang model semantics - Fix #1082: Wi-Fi interfaces always scanned, introduce a
scan-modeto the Wi-Fi concept in Infix - Fix #1313: Container is not restarted if environment variable is changed
- Fix #1314: Raspberry Pi 4B with 1 or 8 GiB RAM does not boot. This was due newer EEPROM firmware in newer boards require a newer rpi-firmware package
- Fix #1345: firewall not updating when interfaces become bridge/lag ports
- Fix #1346: firewall complains in syslog, missing
/etc/firewalld/firewalld.conf - Fix Raspberry Pi 2B build, among other things, the
aarch32_defconfigdid not include a dtb. Please note, the platform has now been renamed toarm - Fix default password hash in
do password encryptcommand. New hash is the same as the more commonly usedchange passwordcommand, yescrypt - Prevent MOTD from showing on non-shell user login attempts
- Fix mDNS reflector.
v25.11.0 - 2025-12-02
Note
Noteworthy changes and additions in this release:
- DHCPv6 client support
- Configurable support for TTL in GRE/VXLAN tunnels
- Extensive filtering support for syslog messages
- Upgrade Buildroot to 2025.02.8 (LTS)
- Upgrade Linux kernel to 6.12.60 (LTS)
- Initial support for 32-bit ARM systems, reference board: Raspberry Pi 2B
- Enable MVEBU SafeXcel Crypto Engine firmware for Marvell Armada SOCs (37xx, 7k, 8k, and CN913x series). Fixes kernel warnings about firmware load failures and crypto-safexcel probe errors on affected boards
- Major improvements to OSPF and BFD operational data and CLI commands:
- CLI commands now use data from the operational datastore instead of calling vtysh directly, providing better integration and consistency
- New
show ip ospfcommand family (neighbor, interface, route) to align with industry standard CLI conventions. Legacyshow ospfcommands are deprecated but still work with warnings - The
show ip ospf databasesubcommand has been dropped for now, the advanced user can still usevtyshfrom Bash if necessary, issue #1253 - Extended BFD commands:
show bfd(status),show bfd peers(detailed),show bfd peers brief(table format), andshow bfd peer <address> - All command names now use singular form (interface, route, neighbor) matching Cisco/FRR conventions, as well as configure context naming
- New support for configuring OSPF interface priority for DR/BDR election
- The DHCP client configuration has moved from
/infix-dhcp-client:dhcp-clientto/interfaces/interface[name]/ipv4/infix-dhcp-client:dhcp, issue #1109. The configuration is automatically migrated on upgrade. The DHCP client is now enabled using a presence container instead of a separateenabledleaf - The
enablednode for IPv4 autoconf (ZeroConf) has been dropped,autoconfis now a presence container. Configuration automatically migrated on upgrade - Add DHCPv6 client support for per-interface IPv6 configuration, augmenting
/interfaces/interface[name]/ipv6/infix-dhcpv6-client:dhcp, issue #1110 - Fix namespace for DHCPv4 client YANG module from
urn:ietf:params:xml:ns:yangtourn:infix:params:xml:ns:yangto properly reflect custom implementation - Improvements to
sdcard.imggeneration, useful for developers mostly:- The NanoPi R2S bootloader is now automatically built and uploaded to
the
latest-bootrelease tag - The
utils/mkimage.shscript now supports fetching the bootloader - The raspberrypi-rpi64 board's bootloader is now aptly named rpi64
- The NanoPi R2S bootloader is now automatically built and uploaded to
the
- Add support for configuring TTL, ToS/DSCP, and Path MTU Discovery on GRE and VXLAN tunnels. This also changes the default TTL of tunnels to 64, from the kernel default (inherit), which in turn fixes reported issues with dropped OSPF Hello frames in GRE tunnels
- Document how to go from SD card to eMMC on BPi-R3
- Add CLI commands for managing boot partition order:
show boot-orderandset boot-orderallow viewing and changing the boot order from the CLI, complementing the existing YANG RPC support, issue #1032 - Extended syslog filtering capabilities, issue #1091:
- Add support for pattern matching using POSIX extended regular expressions
on message content (IETF
select-matchfeature) - Add support for advanced severity comparison: exact match (
equals) and exclusion (block/stop) in addition to the default equals-or-higher (IETFselect-adv-comparefeature) - Add support for hostname-based filtering, useful when acting as a log server to route messages from different devices to separate log files
- Add support for property-based filtering with operators (contains, isequal, startswith, regex, ereregex) on message properties (msg, msgid, programname, hostname, source, data), with optional case-insensitive and negate modifiers
- Add support for pattern matching using POSIX extended regular expressions
on message content (IETF
- Update factory configuration for BPi-R3 and NanoPi R2S boards to enable DHCPv6 client on WAN interface and allow traffic forwarding from LAN to WAN zone in the firewall (this is what most users expect)
- New
supportcommand for collecting system diagnostics to aid in both troubleshooting and support. Runsupport collect > data.tar.gzlocally or remotely via SSH to gather configuration, logs, network state, and system information (encryption usinggpgavailable too)
- Fix #855: User admin sometimes fails to be added to
wheelgroup - Fix #1112: setting hostname via DHCP client sometimes gets overridden by the configured system hostname
- Fix #1247: Prevent invalid configuration of OSPF backbone area (0.0.0.0) as stub or NSSA. The backbone must always be a normal area per RFC 2328. Any existing invalid configurations are automatically corrected during upgrade
- Fix #1255: serious regression in boot time, introduced in v25.10, delays the boot step "Mounting filesystems ...", from 30 seconds up to five minutes!
- Fix #1289: SSH host key generation warning at boot after factory reset
- Fix broken intra-document links in container and tunnel documentation
- Fix
show dhcp-servercommand crashing with invalid timestamp format. DHCP lease expiry timestamps had double timezone suffix causing libyang validation errors - Fix
show dhcp-serveroutput alignment. The EXPIRES column was misaligned when CLIENT ID field was empty, and CLIENT ID column was too narrow for typical 20-character client IDs
v25.10.0 - 2025-10-31
Note
Noteworthy changes and additions in this release:
🛡️ Zone-Based Firewall (ZBF): Protect your network with our zone-based firewall powered by firewalld. Define security zones, set policies between them, and enable masquerading.
📊 System & Hardware Monitoring: CLI show system, show services, and
show hardware now give you instant visibility into CPU temperature, fan
speeds, memory, running services, and sensor data from SFP modules, WiFi radios,
and more. All operational data also available over NETCONF and RESTCONF.
🚀 Expanded Hardware Support: The NanoPi R2S is now included in the
default Aarch64 build, which also adds support for Raspberry Pi 3B, and
Raspberry Pi CM4 variants. All boards now benefit from automatic /var
partition expansion on first boot.
- Upgrade Buildroot to 2025.02.7 (LTS)
- Upgrade Linux kernel to 6.12.56 (LTS)
- Extend NETCONF and RESTCONF scripting documentation with operational data examples, discovery patterns, and common workflow examples, issue #1156
- Initial support for a zone-based firewall, based on
firewalld, issue #448 - Add
validateoption to CLIcopycommand. This can be used before doing a restore of a backup, or when having edited configuration files manually. With the validate flag (-nfrom the shell) the file is only loaded and validated against the YANG models, it is not rolled in if validation is successful. Example:copy /media/backup/old.cfg running-config validate, issue #373 - Automatically expand
/varpartition at first boot on all MMC-based devices - New
upgradeRPC (action) for containers using images with mutable tags - Optimize startup of preexisting containers by adding metadata to track all OCI archives loaded into container store, and all container configurations used to create container instances. Instances are now only recreated when metadata from an existing instance does not match either the configuration or the image — because of configuration changes or image upgrades
- Updated container documentation on volumes, image tags, and image upgrade
- Add new
show servicescommand to display running system services - Add new
show systemcommand with comprehensive system overview including hostname, uptime, load average, CPU/fan temperatures, memory, disk usage - Add hardware sensor monitoring support in
show hardwarewith hierarchical display of temperature, fan, voltage, current, and power sensors - Add support for NanoPi R2S router platform to the default Aarch64 build, bumping it to Tier 2 support (SD-card images built separately)
- Add support for Raspberry Pi 3B (BCM2837)
- Add support for Raspberry Pi Compute Module 4 IoT Router Board Mini
- Add support for Raspberry Pi Compute Module 4 NVME NAS box
- Add
rebootoption to CLIupgradecommand for automatic system restart
- Fix #981: copying any file, including
running-config, to the persistent back-end store forstartup-config, does not take - Fix #1121: Ensure DHCP server does not crash if no address pool is set. This change infers a pool range (only) for /24 networks, and only when a pool is enabled. YANG validation for this and other use-cases is also included. As an unforeseen bonus, Infix now also support non-pool (static lease) setups
- Fix #1122: Add YANG validation for consistency, IP addresses are not allowed on bridge port (interfaces). Even though Infix previously allowed this, but disregarded it operationally, it is no longer supported in the configuration
- Fix #1146: Possible to set longer containers names than the system supports. Root cause, a limit of 15 characters implicitly imposed by the service mgmt daemon, Finit. The length has not been increased to 64 characters (min: 2) and the YANG model now properly warns if the name is outside of these limits
- Fix #1147: Use container metadata to clean up lingering old container images
instead of using the too broad
podman image prune -afcommand - Fix #1148: Only retry container instance create on remote images
- Fix #1149: Increase
podman stoptimeout, from 10 to 30 seconds, needed with bigger containers on heavily loaded systems - Fix #1194: CLI
text-editorcommand does not do proper input sanitation - Fix #1197: RPi4 no longer boots after BPi-R3 merge, introduced in v25.09
- Upgrade fixes for containers with mutable images, e.g.,
:latest. Infix now always tries to fetch a new version of the OCI archive, for remote images, regardless of the transport. After upgrade the old image is pruned - Fix #1203: copying any file, including
startup-config, torunning-configdoes not take
v25.09.0 - 2025-09-30
- Upgrade Buildroot to 2025.02.6 (LTS)
- Upgrade Linux kernel to 6.12.49 (LTS)
- Upgrade libyang to 3.13.5
- Upgrade sysrepo to 3.7.11
- Upgrade netopeer2 (NETCONF) to 2.4.5
- Upgrade rousette (RESTCONF) to v2
- Add support for Banana Pi R3, a 7 port switch with 2 WiFi chip
- Add neofetch system information tool for system introspection, issue #1143
- Add mtr and iperf3 network diagnostic tools, issue #1144
- Improve default bash settings with better history handling and tab completion
- cli: new
terminal resetandterminal resizeconvenience commands
- Fix #1080: Error message in log from rauc, deprecated 'Install' D-Bus method
- Fix #1100: Reduce DHCP client logging verbosity by 70% and include interface names in log messages for easier troubleshooting
- Fix #1119: CLI UX regression, restore proper behavior for
no enabledcommand - Fix #1155:
show ospfcommands regression - Fix #1150:
show-legacywrapper permissions - Fix #1161: error in log during boot about unsupported command
- Fix #1169: Expected neighbors not shown in sysrepocfg
- Fixes for unicode translation in log and pager outputs as well as
syslogd
v25.08.0 - 2025-09-01
- Upgrade Buildroot to 2025.02.5 (LTS)
- Upgrade Linux kernel to 6.12.44 (LTS)
- Raspberry Pi 4 is now a part of the aarch64 image.
- Add support for Raspberry Pi touch display on Raspberry Pi 4
- Fix #1098: Prune dangling container images to reclaim disk space
- Fix #1123: Disabling or removing a container may cause podman to hang
- Fix #1124: Container setup with unreachable remote image spawns
excessive
ip monitorprocesses - Fix #1127: Silence libyang Obsolete schema node warnings in log
v25.06.0 - 2025-07-01
- Upgrade Buildroot to 2025.02.4 (LTS)
- Upgrade Linux kernel to 6.12.35 (LTS)
- Upgrade curiOS built-in containers to v25.06.0
- Add support for setting mode of a container content mount, issue #1070
- Add Wi-Fi client support and add support for some USB-Wi-Fi cards
- New slogan: Infix OS — Immutable.Friendly.Secure
- cli: fix by-word movement, detect word barrier using non-alphanum chars
- cli: fix delete word left/right, make sure to save word in kill buffer
v25.05.1 - 2025-06-12
- Upgrade Linux kernel to 6.12.32 (LTS)
- Fix #1060: Restore of missing CLI commands, regression in Infix v25.05.0
v25.05.0 - 2025-05-27
- Upgrade Buildroot to 2025.02.3 (LTS)
- Upgrade Linux kernel to 6.12.30 (LTS)
- Upgrade libyang to 3.12.2
- Upgrade sysrepo to 3.6.11
- Upgrade netopeer2 (NETCONF) to 2.4.1
- New hardware support: Raspberry Pi 4B (aarch64)
- Add documentation on Infix upgrading and downgrading, issue #1009
- Add HDMI and USB support for iMX8MP-evk
- Enforced strict format for LLDP destination MAC address:
- Only accepts colon-separated format:
01:80:C2:00:00:0E
- Only accepts colon-separated format:
- Add
show lldpcommand to show discovered neighbors per interface. - Add configuration support for per-interface LLDP administrative status
- Fix containers with multiple mounts
- Correct description for LAG LACP modes
- Fix #1040: Add
mountconstraint for container config
v25.04.0 - 2025-04-30
- Upgrade Linux kernel to 6.12.25 (LTS)
- Upgrade Buildroot to 2025.02.1 (LTS)
- Format for disk image (for QEMU) has changed to
qcow2
- Fix #1002: Broken symlink in release package
- Fix #1006: NanoPi R2S corrupt startup, regression in Infix v25.02.0
- Bump R2S kernel, now same as tier one boards
- Fix #1015: Not possible to save custom SSH settings in startup-config
- Fix group owner and permissions of
/cfg/backupdirectory - Fix extraction of old version for
/cfg/backup/files - Fix configuration migration issues when upgrading
v25.03.0 - 2025-03-31
Important
This release is the first with the new Buildroot 2025.02 (LTS)
- Upgrade Linux kernel to 6.12.21 (LTS)
- Upgrade Buildroot to 2025.02.0 (LTS)
- Fix #964: YANG schema warning in syslog: missing 'monitor' node for lag
- Fix #980: the system fails to reboot when a container is (stuck), for whatever reason, in its 'setup' state
- Fix #990: web console, ttyd service, stopped working after upgrade to
Buildroot 2025.02, caused by new (missing) option
--writable - Fix TCAM memory corruption in
mvpp2Ethernet controller - Fix annoying (but harmless) usage message from the logger tool when
startup-configfails to load and the system reverts to failure mode - Fix harmless log warning for product specific init when no product specific init scripts are found
- Backport fixes for sysklogd, affecting hostname filtering and periods in TAG names, pending official backport in Buildroot
v25.02.0 - 2025-03-04
- Upgrade Linux kernel to 6.12.18 (LTS)
- Upgrade Buildroot to 2024.02.11 (LTS)
- Add support for link aggregation (lag), static (balance-xor) and LACP
- Add support for the i.MX 8M Plus EVK
- YANG type change for SSH private/public keys, from ietf-crypto-types to infix-crypto-types
- Disable global IPv6 forwarding by default, enable by per-interface setting. Note, route advertisements are always accepted. Issue #785
- Drop automatic default route (interface route) for IPv4 autoconf, not necessary and causes more confusion than good. Issue #923
- Update scripting with new RESTCONF examples
- Fix #896:
/etc/resolv.confnot properly generated when system runs in fail secure mode (failing to loadstartup-config) - Fix #902: containers "linger" in the system (state 'exited') after having removed them from the configuration
- Fix #930: container configuration changes does not apply at runtime
only when saved to
startup-configand system is rebooted - Fix #936: DHCP server reconfiguration does not always take effect.
- Fix #956: CLI
copycommand complains it cannot change owner when copyingfactory-configtorunning-config. Bogus error, the latter is not really a file - Fix #977: "Operation not permitted" when saving
running-configtostartup-config(harmless warning but annoying and concerning)
v25.01.0 - 2025-01-31
Note
This release contains breaking changes in the configuration file
syntax for DHCP clients. Specifically DHCP options with value,
i.e., the syntax for sending a hexadecimal value now require hex
prefix before a string of colon-separated pairs of hex values.
- Upgrade Linux kernel to 6.12.11 (LTS)
- Upgrade Buildroot to 2024.02.10 (LTS)
- Upgrade FRR from 9.1.2 to 9.1.3
- Add support for configuring SSH server, issue #441. As a result,
both SSH and NETCONF now use the same host key in
factory-config - Add operational support for reading DNS resolver info, issue #510
- Add operational support for NTP client, issue #510
- Add support for more mDNS settings: allow/deny interfaces, acting as "reflector" and filtering of reflected services. Issue #678
- Add DHCPv4 server support, multiple subnets with static hosts and
DHCP options on global, subnet, or host level, issue #703.
Contributed by MINEx Networks
- DHCP client options aligned with DHCP server,
startup-configfiles with old syntax are automatically migrated
- DHCP client options aligned with DHCP server,
- Breaking change in DHCP client options with value. Hexadecimal
values must now be formatted as
{ "hex": "c0:ff:ee" }(JSON) - Add documentation on management via SSH, Web (RESTCONF, Web Console), and Console Port, issue #787
- Add documentation of DNS client use and configuration, issue #798
- Add support for changing boot order for the system with an RPC, including support for reading boot order from operational datastore
- Add support for GRE/GRETAP tunnels
- Add support for STP/RSTP on bridges
- Add support for VXLAN tunnels
- Add support for configuring global LLDP
message-tx-interval
- Fix #777: Authorized SSH key not applied to
startup-config - Fix #829: Avahi (mDNS responder) not starting properly on switches
with many ports (>10). This led to a review of
sysctl:- New for IPv4:
- Adjust IGMP max memberships: 20 -> 1000
- Use neighbor information on nexthop selection
- Use inbound interface address on ICMP errors
- Ignore routes with link down
- Disable
rp_filter - ARP settings have been changed to better fit routers, i.e.,
systems with multiple interfaces:
- Always use best local address when sending ARP
- Only reply to ARP if target IP is on the inbound interface
- Generate ARP requests when device is brought up or HW address changes
- New for IPv6:
- Keep static global addresses on link down
- Ignore routes with link down
- New for IPv4:
- Fix #861: Fix error when running 251+ reconfigurations in test-mode
- Fix #869: Setup of bridges is now more robust
- Fix #899: DHCP client with client-id does not work
- Minor cleanup of Networking Guide
- Fix memory leaks in
confd
v24.11.1 - 2024-11-29
- Upgrade Frr to 9.1.2, fixes an OSPF issue where Zebra lost netlink messages and drifted out of sync with the kernel's view of addresses and interfaces available in the system
- Allow setting IP address directly on VLAN filtering bridges. This only works when the bridge is an untagged member of a (single) VLAN.
- cli: usability -- showing log files now automatically jump to the end of the file, where the latest events are
- cli: usability -- showing container status, or other status that overflows the terminal horizontally, now wrap the lines and exit the pager immediately if the contents fit on the first screen
- The default log level of the mDNS responder,
avahi-daemon, has been adjusted to make it less verbose. Now onlyLOG_NOTICEand higher severity is logged -- making it very quiet
- Fix #685: DSA conduit interface not always detected. Previous attempt at a fix (v24.10.2) mitigated the issue, but did not completely solve it.
- Fix #835: redesign how the system creates/deletes containers from the
running-config. Prior to this change, all removal and creation was handled by a separate queue that ran asynchronously from theconfdprocess. This could lead to situations where new configurations are applied before the queue had been fully processed. After this change containers are deleted synchronously and new containers are created in the same flow as during normal runtime operation (start/upgrade) - Fix start of containers with
manual=Trueoption should now work again, regression in v24.11.0 - Fix loss of writable volumes when temporarily disabling a container in the configuration, now the container remains dormant with all its volumes still available
- Fix presentation bug in CLI
show interfaceswhere all line-drawing characters showed up as hexadecimal values. Regression in v24.11.0 - Fix missing log messages from Frr Zebra daemon
- Stop the zeroconf (IPv4LL) agent,
avahi-autoipd, when removing an interface, e.g.,br0 - Creating more than one container trigger restarts of previously set up containers. Which in some cases may cause these earlier ones to end up in an inconsistent state
- Prevent traffic assigned to locally terminated VLANs from being forwarded, when the underlying ports are simultaneously attached to a VLAN filtering bridge.
v24.11.0 - 2024-11-20
Caution
This release contains breaking changes for container users! As of
v24.11.0, all persistent1 containers always run in read-only mode
and the setting itself is deprecated (kept only for compatibility
reasons). The main reason for this change is to better serve users
with embedded container images in their builds of Infix. I.e., they
can now upgrade the OCI image in their build and rely on the container
being automatically upgraded when Infix is upgraded, issue #823. For
other users, the benefit is that all container configuration changes
take when activated, issue #822, without having to perform any tricks.
- Add validation of interface name lengths, (1..15), Linux limit
- Add support for ftp/http/https URI:s in container image, with a new
checksumsetting for MD5/SHA256/SHA512 verification, issue #801 - Add a retry timer to the background container create service. This
will ensure failing
docker pulloperations from remote images are retrying after 60 seconds, or quicker - CLI base component,
klish, has been updated with better support for raw terminal mode and alternate quotes (' in addition to ") - Log silenced from container activation messages, only the very bare
necessities are now logged, e.g.,
podman createcommand + status - Factory reset no longer calls
shredto "securely erase" any files from writable data partitions. This will speed up the next boot considerably
- Fix #659: paged output in CLI accessed via console port sometimes
causes lost lines, e.g. missing interfaces. With updated
klishand the terminal in raw mode, the pager (less) can now control both the horizontal and vertical - Fix #822: adding, or changing, an environment variable to a running
container does not take without the
container upgrade NAMEtrick - Fix #823: with an OCI image embedded in the Infix image, an existing container in the configuration is not upgraded to the new OCI image with the Infix upgrade.
- Frr leaves log files in
/var/tmp/frron unclean shutdowns. This has now been fixed with a "tmpfiles" cleanup of that path at boot
v24.10.2 - 2024-11-08
- Support for showing interfaces owned by running containers in the CLI
command
show interfaces. This also adds support for showing the peer interface of VETH pairs. Issue #626 - Reboot system on kernel "oops", on "oops" the kernel now panics and reboots after 20 seconds. Issue #740
- Update static factory-config for NanoPi R2S: enable NACM, securing all
passwords, and enabling
iburstfor the NTP client. Issue #750 - Updated QoS documentation with pictures and more information on VLAN interface ingress/egress priority handling, issue #759
- Disable RTC device in Styx device tree, issue #794
- Support for saving and restoring system clock from a disk file. This allows restoring the system clock to a sane date in case the RTC is disabled or does not have a valid time, issue #794
- Update device discovery chapter with information on
infix.localmDNS alias,netbrowsesupport to discover all local units, and command examples for disabling LLDP and mDNS services, issue #786 - Updated OSPF documentation to include information on global OSPF
settings (
redistribution,explicit-router-id, etc.), issue #812 - Added information on forwarding of IEEE reserved group addresses to bridge section of networking documentation, issue #788
- Add support for bootstrap conditions and early init product overrides
- Styx: enable second Ethernet port LED in device tree, again, rename it: yellow -> aux, and make sure it is turned off at boot
- Styx: disable second port LED for the 4xSFP slots, does not work
- Styx: override iitod (LED daemon) with a product specific LED script
- Fix #685: DSA conduit interface not always detected, randomly causing major issues configuring systems with multiple switch cores
- Fix #778: reactivate OpenSSL backend for libssh/libssh2 for NanoPI R2S. This fixes a regression in v24.10.0 causing loss of NETCONF support
- Fix #809: enable syslog logging for RAUC
- Fix harmless bootstrap log error message on systems without USB ports:
jq: error (at <stdin>:0): Cannot iterate over null (null) - Change confusing
tclog error message:Error: does not support hardware offloadtoSkipping $iface, hardware offload not supported.
v24.10.1 - 2024-10-18
- Add support for interface description, sometimes referred to as
"ifAlias". Saved as an Linux interface alias (not
altname), e.g.,/sys/class/interfaces/veth0a/ifalias, includes operational support
- Fix #735:
copyanderasecommands missing from CLI, regression in Infix v24.10.0 defconfigs, now added as dep. in klish package
v24.10.0 - 2024-10-18
News: this release contains breaking YANG changes in custom MAC addresses for interfaces! For details, see below issue #680.
Also, heads-up to all downstream users of Infix. YANG models have been renamed to ease maintenance, more info below.
-
Software control of port LEDs on the Styx platform has been disabled.
Default driver behavior, green link and green traffic blink, is kept as-is, which should mitigate issues reported in #670
-
Correcting documentation on QoS. For packets containing both a VLAN tag and an IP header, PCP priority takes precedence over DSCP priority (not vice versa).
-
Update CONTRIBUTING.md for scaling core team and helping external contributors understand the development process, issue #672
-
Updated branding documentation with more information on how dynamic and static factory-config work, including examples
-
Updated container documentation, improved images, detail how to set interface name inside the container, and some syntax fixes
-
Updated networking documentation, new General settings section, and more details added to initial section on network building blocks
-
As of this release, all Infix YANG models have dropped the
@DATEsuffix from the name, this type of versioning is not handled using symlinks instead. -
Update Infix
provisionscript, used to install Infix on eMMC, add example of how to erase partition table to be able to re-run the script on already provisioned devices, issue #671 -
OSPF: Add limitation to allow an interface to be in one area only
-
Add support for "dummy" interfaces, mostly useful for testing
-
Add support for container hostname format specifiers, just like it already works for the host's hostname setting
-
Hide all
status obsoleteYANG nodes in CLI -
Add YANG
units, if available, to CLI help text (default value) -
The CLI commands
copyanderaseare now available also from Bash -
Greatly reduced size of bundled curiOS httpd OCI container image, reduced from 1.8 MiB to 281 KiB
-
Add deviation to ietf-interfaces.yang,
link-up-down-trap-enableis not supported (yet) in Infix, issue #709 -
The default builds now include the curiOS nftables container image, which can be used for advanced firewall setups. For an introduction see https://www.kernelkit.org/posts/firewall-container/
- Fix #499: add an NACM rule to factory-config, which by default deny everyone to read user password hash(es)
- Fix #663: internal Ethernet interfaces shown in CLI tab completion
- Fix #674: CLI
show interfacesdisplay internal Ethernet interfaces, regression introduced late in v24.09 release cycle - Fix #676: port dropped from bridge when changing its VLAN membership from tagged to untagged
- Fix #680: replace deviation for
phys-addressin ietf-interfaces.yang withcustom-phys-addressto allow for constructing more free-form MAC addresses based on the chassis MAC (a.k.a., base MAC) address. For more information, see the YANG model, a few examples are listed in the updated documentation. The syntax will be automatically updated in thestartup-configandfactory-config-- make sure to verify the changes and update any staticfactory-configused for your products - Fix #690: CLI
show ip routecommand stops working after 24 hours, this includes all operational data in ietf-routing:/routing/ribs. - Fix #697: password is not always set for new users, bug introduced in v24.06.0 when replacing Augeas with native user handling
- Fix #700: add missing
admin-statusto interface operational data - Fix #701: make sure CLI (and Bash)
copycommand use same sysrepo timeout as other operations that load sysrepo. Was 10 second timeout, which caused some (really big) configurations not to apply from the CLI, but worked at boot, for instance. New timeout is 60 seconds - Fix #708: allow all container networks to set interface name inside
container, not just auto-generated veth-pair ends for
docker0bridge - Fix
show interfaceson platforms like the NanoPi R2S, which does not support reading RMON counters in JSON format usingethtool - Fix #730: CLI command
show ntp [sources]stopped working in v24.08. Missing access rights after massive CLI lock-down - Fix BFD in OSPF, previously you could not enable BFD on a single interface without enabling it on all interfaces
v24.09.0 - 2024-09-30
News: this release enhances the integration of all types of static
routes with FRRouting (Frr), including all routes that can be set by
DHCP and IPvLL (ZeroConf) clients. Due to this fundamental change, the
system routing table is now primarily read from Frr, which increases the
amount of relevant routing information available to the user. E.g., in
the CLI exec command show ip route and show ipv6 route. Support for
adjusting the administrative distance of all types of static routes has
also been added to facilitate site specific adaptations. Please see the
documentation for details.
- The CLI command
show interfacesmay for some terminal resolutions not display all interfaces (on systems with >20 interfaces). This problem is limited to the console port and only occurs for smaller terminals (30-50 rows height). Callingshow ifacesfrom the shell, dumping/ietf-interfaces:interfacesXPath usingsysrepocfg, or using the CLI from an SSH session, is not affected. Issue #659
- Upgrade Buildroot to 2024.02.6 (LTS)
- Upgrade Linux kernel to 6.6.52 (LTS)
- Upgrade libyang to 3.4.2
- Upgrade sysrepo to 2.11.7
- Upgrade netopeer2 (NETCONF) to 2.2.31
- Updated
infix-routing.yangto declare deviations for unsupported OSPF RPCs and Notifications inietf-ospf.yang - The CLI admin-exec command
show dnsnow also shows any configured name servers, not just ones acquired via DHCP. Issue #510 - Add support for IPv4 (autoconf)
request-address. This instructs the ZeroConf client to start with the requested address. If this is not successful the client falls back to its default behavior. Issue #628 - Major speedup (10x) in operational data, in particular when querying
interface status. Very noticeable in the CLI
show interfacescommand on devices with large port counts. Issue #651 - Silence
yangerlog warnings for failingmctlcommand. Caused bymctlreporting no multicast filtering enabled on bridge
- Fix #357: EUI-64 based IPv6 autoconf address on bridges seem to be
randomized. Problem caused by kernel setting a random MAC before any
bridge port is added. Fixed by using the device's base MAC address on
bridge interfaces. Possible to override using
phys-addressoption - Fix #601: CLI regression in
show ospffamily of commands causing authorized users, likeadmin, to not being able to query status of OSPF or BFD. Workaround by using the UNIX shellsudo vtysh. Regression introduced in v24.08.0 - Fix #603: regression in GNS3 image, starts in test mode by default. Introduced in v24.08.
- Fix #613: CLI regression in tab completion of container commands,
e.g.,
container shell <TAB>. Regression introduced in v24.08.0 - Fix #616: Silent failure when selecting bash as login shell for non-admin user, this silent lock has been removed
- Fix #618: CLI command
show interfacesdoes not show bridges and bridge ports, regression introduced in v24.08.0 -- only affects bridges without multicast snooping - Fix #623: CLI command
container upgrade NAMEdoes not work, regression introduced in v24.06.0 - Fix #625: initialize sysrepo startup datastore at boot. Improves
usability when working directly against the sysrepo datastores from
the shell with
sysrepocfgandsysrepoctltools - Fix #635: OSPF: all router neighbors reported as neighbor on every interface
- Fix #638: Disabling IPv4LL (autoconf) on an interface does not clean up 169.254/16 addresses
- Fix #640: unable to set static default route due to priority inversion from DHCP or IPv4LL (ZeroConf) clients setting their routes directly in the kernel. This has resulted in a complete overhaul of route management, using FRRouting for all routes, including DHCP and IPv4LL routes, presentation in the CLI, and also support for custom route preference for static routes
- Fix #658: deleting VETH pairs does not work unless rebooting first.
Creating a VETH pair, followed by at least one other reconfiguration
before removing the pair, causes
confdto fail when applying the interface changes (tries to delete both ends of the pair) - Spellcheck path to
/var/lib/containerswhen unpacking OCI archives on container upgrade - cli: restore
tcpdumppermissions for administrator level users, regression introduced in v24.08.0 - The timeout before giving up on loading the
startup-configat boot is now 1 minute, just like operations via other front-ends (NETCONF and RESTCONF). This was previously (incorrectly) set to 10 seconds
v24.08.0 - 2024-08-30
News: this release adds full configuration support for syslog, with logging to local files, external media, remote log server, as well as support for acting as a log sink/server. External media can now be mounted automatically, very useful, not only for logging, but also for upgrading and container images.
Finally, the following consumer boards are now fully supported:
- NanoPi R2S (ARM)
- StarFive VisionFive2 (RISC-V)
- Upgrade Buildroot to 2024.02.5 (LTS)
- Upgrade Linux kernel to 6.6.46 (LTS)
- Issue #158: enhance security of factory reset. All file content is now overwritten x3, the last time with zeroes, then removed. Example, on the NanoPi R2S this process takes ~30 seconds, but may take longer in setups with bigger configurations, e.g., containers
- Issue #497: support for auto-mounting USB media. Useful for logging,
upgrade, and container images. Mounted under
/media/<LABEL>, where<LABEL>is the partition label(s) available on the USB media - Issue #503: configurable syslog support, based on IETF Syslog config draft model, includes file based logging (built-in or external media) and remote logging, as well as acting as a log sink (remote server) for syslog clients (Infix extension). Documentation available in Syslog Support
- Issue #521: audit trail support. Logs changes to configuration, both
running-configandstartup-config, as well as RPCs, e.g., setting system date-time. Logs contain name of user and the action taken. Supported for CLI, NETCONF, and RESTCONF - Issue #545: sort loopback interface first in CLI
show interfaces - New documentation for Ethernet interfaces: how to set speed, duplex, query status and statistics
- Issue #587: add YANG must expressions for bridge multicast filters
- Initial RISC-V (riscv64) support: StarFive VisionFive2
- Massive updates to the NanoPi R2S:
- Update Linux kernel to v6.10.3 and sync defconfig with aarch64
- Workaround
rebootcommand "hang" on NanoPi R2S (failure to reboot) by replacing the Rockchip watchdog driver with "softdog" - Update U-Boot to v2024.07, enable secure boot loading of images
- Rename interfaces to LAN + WAN to match case and LEDs
- Rename images to
infix-r2s$ver.ext, not same as other aarch64 - Change rootfs to squashfs for enhanced security
- Add RAUC support to simplify device maintenance/upgrade
- Add support for saving unique interface MAC addresses in U-Boot
- Add support for system LEDs, see product's README
- Add support for reset button from U-Boot, to trigger factory reset,
and from Linux, to trigger
reboot - Add static
factory-configas an example - Full LED control, including WAN LED (link up and DHCP lease)
- Password login can now be disabled by removing the password. Before this change only empty password disabled password login (in favor of SSH key login), removing the password locked the user completely out
- Add LED indication on factory reset, all LEDs available in Linux
/sys/class/ledsare turned on while clearing writable partitions - CLI: improve
dirandshow logcommand user experience. List files also in user's home directory and allow displaying gzipped log files - Lock down CLI admin-exec to prevent unprivileged users from managing system configuration or state.
- The local log file
/var/log/syslogno longer contains debug level log messages. See/var/log/debugfor all log messages
- Fix #274: add missing link/traffic LEDs on NanoPi R2S LAN port
- Fix #489: ensure all patches are versioned, including Linux kernel
- Fix #531: creating a new VLAN interface named
vlanNshould not setlower-layer-iftovlanN. With thevlanNpattern, only C-VLAN and VID can be inferred - Fix #541: make sure Frr OSPF logs are sent to
syslogdand filtered to/var/log/routingfor easy access from the CLI - Fix #542: warning message from
login, cannot findpam_lastlog.so - Fix #570: the CLI
change passwordcommand does not work - Fix #576: the CLI tab completion for
startup-configdoes not work - Fix #585: on internal configuration database error, restart internal
service
sysrepo-plugindto attempt to get remote access over NETCONF and RESTCONF back to the user - Silence bogus
sysctlwarnings at boot (syslog) - Silence output from user group member check (sys-cli in syslog)
- Fix annoying CLI freeze if pressing any key before initial prompt
v24.06.0 - 2024-06-28
Note: this release contains breaking changes in YANG models that are incompatible with existing configuration files. So, after upgrade, but before reboot, a factory reset is required!
- Upgrade Buildroot to 2024.02.3 (LTS)
- Upgrade Linux kernel to 6.6.34 (LTS)
- Upgrade bundled curiOS httpd container to v24.05.0
- Default web landing page refactored into a Buildroot package to make it possible to overload from customer repos.
- Enable DCB support in aarch64 kernel (for EtherType prio override)
- Topology mapper improvements, including option for deterministic reproduction of logical to physical mappings
- New version of
gencerttool, for self signed HTTPS certificates. This allows dropping dependency on building a host rust toolchain - Issue #374: add timestamps to dagger .log files
- Add small delay in U-Boot to allow stopping boot on reference boards
- Document how to provision the bootloader and Infix on a blank board
- Use initial hostname from
/etc/os-releaseas configuration fallback - Update documentation for use of VETH pairs in containers
- Issue #454: create bridges in
factory-configwith IGMP/MLD snooping enabled by default - The following YANG models have been updated to newer draft versions:
ietf-crypto-types,ietf-keystore,ietf-netconf-server,ietf-ssh-common,ietf-ssh-server,ietf-tcp-client,ietf-tcp-common,ietf-tcp-server,ietf-tcp-server,ietf-tcp-server,ietf-tcp-server. In these there are a lot of breaking changes, most likely you will need to redo your configuration fromfactory-config. - The Augeas package has been dropped, so
augtoolis no longer available - VLAN interfaces can now map the incoming PCP value to the kernel-internal priority on ingress, and perform the reverse mapping on egress.
mv88e6xxxports can now use Linux's priority information to select the appropriate egress queue, via themqprioqueuing discipline.- Add logging of output from container start/stop action
- Clean up stale directories after OCI container archive import
- Add support for
show leaf-nodein CLI configure context - Allow non-admin users to use the CLI. NACM rules still apply
- Ensure filesystem is sync'ed properly after a CLI
copycommand - Issue #178: add early boot script to migrate configuration files of older version to new syntax. Initial, rudimentary support, for the change in shell types
- Issue #308: add
versionfield to configuration file using a new model, infix-meta.yang. Used to trigger migration from older formats to newer on future breaking changes - Issue #432: extract YANG documentation at build time. Part of the
release tarballs is now
yangdoc.htmlfor the complete tree of all YANG configuration, operational data, RPCs, and notification nodes - Issue #435: add support for
$factory$password hash. This allows backing up configuration files with device specific passwords. Upon restore to another device this ensures the replacement's password is used instead of the originals' - Issue #435: add support for hostname format specifiers. The default
hostname configuration is now
%h-%mto encode,infix-c0-ff-ee - Issue #435: support for "empty" NETCONF host keys. Primarily used in
static factory-config setups. When a configuration is detected with
this, the automatically generated, device specific 2048 bit RSA host
key pair is used. With this, vendor/product specific factory-config
is now fully supported. See
src/confd/README.md - Issue #447: add support for yescrypt,
$y$hashes. This also adds support for$0$cleartextpassword according to ietf-system.yang - Issue #455: split CLI tutorial into multiple files for easy access
from the CLI admin-exec context using the
helpcommand - Issue #478: add operational support for ietf-system.yang, reading actual hostname and passwords after issue #435
- Merge infix-shell-types.yang with infix-system.yang
- cli: improved error/warning message on missing or incomplete command
- Fix #424: regression, root user can log in without password
- Fix build regressions in
cn9130_crb_boot_defconfigcaused by upgrade to Buildroot v2024.02 and recent multi-key support in RAUC and U-Boot - Fix provisioning script after changes to make GRUB loading more robust
- Fix missing
/etc/resolv.conf, as noticed byavahi-daemon, when a user callsno systemfrom the CLI - Fix #428: loss of admin account after upgrade to v24.04
- Fix #429: failing to load
startup-configdoes not trigger the fail secure mode, causing the system to end up in an undefined state - Fix #453: fix inconsistent behavior of custom MAC address (interface
phys-addressfor VETH pairs. Allows fixed MAC in containers - Fix #462: increase port column width for CLI
show bridge mdb - Fix #468: non-admin users can get a POSIX shell as login shell, root cause was buggy Augeas library, replaced with plain C API.
- Fix #469: non-admin users added to any group get administrator
privileges (added to UNIX
wheelgroup) - Fix #473: bridge interface with IPv6 SLAAC never get global prefix
- Fix #476: Custom command for containers not working
- Fix #479: timeout from underlying datastore when disabling containers in configuration. Only disabling (stopping) container now done in the configuration change, removal of container done in the background
- Fix locking issue with standard counter groups on
mv88e6xxx - Add missing LICENSE hash for factory reset tool
- Fix timeout handling in container restart command
- Fix MDB/ATU synchronization issue from IGMPv3/MLDv2 reports on
mv88e6xxxsystems
v24.04.2 - 2024-05-15
- Add small delay in U-Boot to allow stopping boot on reference boards
- Document how to provision the bootloader and Infix on a blank board
- Use initial hostname from
/etc/os-releaseas configuration fallback
- Fix build regressions in
cn9130_crb_boot_defconfigcaused by upgrade to Buildroot v2024.02 and recent multi-key support in RAUC and U-Boot - Fix provisioning script after changes to make GRUB loading more robust
- Fix missing
/etc/resolv.conf, as noticed byavahi-daemon, when a user callsno systemfrom the CLI - Fix #428: loss of admin account after upgrade to v24.04
- Fix #429: failing to load
startup-configdoes not trigger the fail secure mode, causing the system to end up in an undefined state
v24.04.1 - 2024-05-03
- Default web landing page refactored into a Buildroot package to make it possible to overload from customer repos.
- Enable DCB support in aarch64 kernel (for EtherType prio override)
- Topology mapper improvements, including option for deterministic reproduction of logical to physical mappings
- New version of
gencerttool, for self signed HTTPS certificates. This allows dropping dependency on building a host rust toolchain - Issue #374: add timestamps to dagger .log files
- Add missing LICENSE hash for factory reset tool
- Fix #424: regression, root user can log in without password
v24.04.0 - 2024-04-30
News: this release marks the first major upgrade of the underlying Buildroot to the latest LTS release, v2024.02. This caused a few small regressions in the release cycle, all known issues have been addressed.
Also worth highlighting, as of this release the Infix Classic variant
has been dropped. It was the legacy Infix with manual configuration of
the system using a persistent /etc. May be resurrected later as a
separate project. Going forward Infix' focus is entirely on NETCONF.
Finally, the YANG Status section has been dropped for this release, the idea is to generate supported features from the models and include in future releases.
- Bump the base Buildroot version to v2024.02 LTS
- Bump the base Linux kernel version to 6.6 LTS
- Drop Classic variant to reduce overhead, simplify build & release processes, and focus on NETCONF for Arm64 and Amd64 platforms
- Add hostname restrictions to ietf-system, and infix-dhcp-client models. Max 64 characters on Linux systems
- Add mDNS CNAME (alias) advertisement, e.g., infix.local in addition to the default infix-c0-ff-ee.local. Note: this is build-specific and does not change if system hostname is changed
- Add mDNS browser web application, https://network.local that shows all mDNS devices on the LAN. The network.local mDNS name is also a CNAME, so with multiple Infix devices, only one will act as the mDNS browser
- Add temporary landing page to web server for https://infix.local
- Add web console using ttyd, https://infix.local:7681
- Add support for disabling web services using CLI
- The bridge model now has built-in validation of port memberships, i.e., a port must be a bridge member to be used in VLAN filtering
- The bridge model only permits the bridge itself to be a tagged member of VLANs -- meaning, the only way to set an IP address on such bridges is to use a VLAN interface on top
- A VLAN filtering bridge now validates that no IP address has been set. Use a VLAN interface on top for that (see above)
- Restructure documentation, let first page in doc/ be table of contents
- Scripting Infix, new document on how to script Infix from remote, e.g., for production or from a container
- Introduction, update documentation now that the
adminuser's default login shell is/bin/bash - System documentation, first outline of how to change hostname, add users, add system administrator users, changing login banner, change the system default editor, and more
- Network documentation, add section on VETH pairs
- Container documentation:
- CLI prompts have been updated to match the examples used in other parts of the User Guide
- Default route example for static container interfaces
- How to upgrade a container image
- As a follow-up to port speed/duplex/autoneg support added in v24.02, this release ensures flow-control is always disabled on all Ethernet ports, as described in the IEEE Ethernet interfaces YANG model
- Add support for core dumps, saving them in
/var/crash, max one dump per process, for use with future support tarballs - Add support for multicast snooping, both IPv4 (IGMP) and IPv6 (MLD) in bridge setups, including offloading to switchdev
- Add support for acting as passive (proxy) or active IGMP querier
- Add support for static multicast filters, MAC, IPv4 and IPv6 groups are supported -- multicast snooping must be enabled
- Include Buildroot
legal-infoin releases, i.e., licenses, sources with patches, as well as csv files for packages and toolchain - Drop
shellcommand from CLI to allow confining users - The CLI
copycommand now allows absolute paths - Local resolver,
dnsmasq, had port 53 visible from externalnmapscans, even though it dropped non-local requests, it now only binds to the loopback interface reduce number of externally visible ports - Kernel log messages, of severity error or higher, now log directly to the console. This may cause some annoyance but has been enabled to ease debugging, in particular issues where the system crashes before the syslog daemon has flushed logs to disk. (Logs are still saved to log files as well.)
- Issue #325: Add support for multiple administrator users by opening
up basic NETCONF ACM support. See documentation for details
- Any user can be added to the
adminNACM group - Any user not in the
admingroup is not allowed to have a login shell other than the CLI (or disabled). POSIX shell, e.g., Bash is reserved for system administrators
- Any user can be added to the
- Issue #327: Remove IPv6LL from bridge port interfaces
- Issue #358: translate YANG model's LOWER-LAYER-DOWN -> LINK-DOWN in
CLI
show interfacescommand - Issue #360: document factory-config, startup-config, and the various failure modes in the system
- Issue #361: document how a privileged container can break out of its
confinement and run host commands, e.g., call
sysrepocfg - Issue #365: add limited support for container capabilities, e.g., to
enable
CAP_NET_RAWto allow containers to useping. This allows users to avoid enabling privileged mode - Issue #367: setting date/time over NETCONF now saves system time also to the RTC, which otherwise is only saved on reboot or power-down
- Issue #369: Remove limitation that the routing instance must be named 'default'
- confd: Fix memory leak when operating on candidate configuration
- probe: Fix crash on systems without USB
- Reduced syslog errors for accesses no non-existing xpaths
- Fix bogus warning about not properly updating
/etc/motdin newmotd-bannersetting, introduced in v24.02.0 - infix-routing model: the
enableconfiguration setting for OSPF, indefault-route-advertisehas been obsoleted and replaced byenabled - Fix #328: when setting up a VLAN filtering bridge, the PVID for bridge ports defaulted to 1, making it impossible to set up "tagged-only" ports which drop ingressing untagged traffic
- Fix #329: VLAN inference for interfaces named
eth0.1, i.e., VID 1 on lower-layer-ifeth0. Only affects automatic inference in the CLI, entering the values manually (CLI/NETCONF) not affected by this bug - Fix #331: inconsistent naming of 'enabled' in infix-routing.yang
- Fix #349: minor changes to
bridge-portsettings, like settingpvidwhen you forget it, did not take without a reboot - Fix #353: impossible to remove bridge port with
no bridge-port - Fix #358: MAC address no longer shown for bridge interfaces in CLI
show interfacescommand - Fix #365: not possible to run
pingfrom container - Fix #366: static routes from container host interfaces do not work. Documentation updated with an example
- Fix #368: upgrading
oci-archive:/images fail because system thinks the image can be pulled from a localhost registry. Documentation has also been updated, describing various methods and how to upgrade them - Fix #370: despite the documentation stating containers must explicitly
declare
networksettings, Infix v23.02 had a late regression that reverted back to the podman default: network behind a CNI bridge (firewalled and NAT:ed, hidden from the rest of the network) - Fix #375: k8s-logger, used for containers, does not exit properly and causes 100% CPU load when container stop or are restarted. Also in this issue: handle ip/route additions to container networks at runtime
- Fix #384: segfault in helper function when disabling the DHCP client
using
no dhcp-clientfrom the CLI - Fix #391 Creating VLAN interface in the CLI with "edit interface vlanN" does not set VLAN id to N.
- Fix #404:
lldpdshould be disabled on internal interfacedsa0 - Fix #406: an overly restrictive
whenexpression in the bridge YANG model prevented users from adding VLAN interfaces as bridge ports. E.g., creating interfaceeth0.10and adding that tobr0 - Fix #412: after starting up with DHCP client enabled on any interface
set dhcp-client enabled falsedoes not bite at runtime - Fix #414: spelling error in
infix-hardware.yang, leaf nodecoutry - Fix #415:
startup-configowned byrootuser and group instead ofadmin. The file ownership is now adjusted on every boot - Fix #416:
adminuser cannot perform a factory reset with RPC usingsysrepocfgtool over SSH - Fix bogus syslog warning about not updating
/etc/motdproperly
v24.02.0 - 2024-03-01
Note: the
rootaccount is disabled in official builds. Only theadminuser can log in to the system. This can be changed, but only in developer builds:make menuconfig-> System configuration ->[*]Enable root login with password
Infix devices support downloading all YANG models over NETCONF, including models with submodules. As a rule, standard models are used as long as they map to underlying Linux concepts and services. All exceptions are listed in Infix specific models, detailing deviations and augmentations.
Currently supported models:
-
- Toggle port speed & duplex auto-negotiation on/off
- Set port speed and duplex when auto-negotiation is off
- Query port speed/duplex and auto-negotiation status (operational)
- Frame counters:
YANG Linux / Ethtool out-framesFramesTransmittedOKout-multicast-framesMulticastFramesXmittedOKout-broadcast-framesBroadcastFramesXmittedOKin-total-octetsFramesReceivedOK+ FrameCheckSequenceErrors+ FramesLostDueToIntMACRcvError+ AlignmentErrors+ etherStatsOversizePkts+ etherStatsJabbersin-framesFramesReceivedOKin-multicast-framesMulticastFramesReceivedOKin-broadcast-framesBroadcastFramesReceivedOKin-error-undersize-framesundersize_pktsin-error-fcs-framesFrameCheckSequenceErrorsin-good-octetsOctetsReceivedOKout-good-octetsOctetsTransmittedOK -
- Populates standard hardware model from corresponding data in device EEPROMs
- augments:
- Initial support for USB ports
- Vital Product Data (VPD) from device EEPROMs (ONIE structure)
- infix-hardware: Deviations and augments
-
- augments:
- Message of the Day (MotD) banner, shown after SSH or console login.
Please note: the legacy
motdhas been replaced withmotd-banneros of v24.02. Use CLItext-editorto modify the latter - User login shell, default:
/bin/false(no SSH or console login) - State information for remotely querying firmware version information
- Message of the Day (MotD) banner, shown after SSH or console login.
Please note: the legacy
- deviations:
- timezone-name, using IANA timezones instead of plain string
- UTC offset, only support per-hour offsets with tzdata
- Usernames, clarifying Linux restrictions
- Unsupported features marked as deviations, e.g. RADIUS
- infix-system-software: firmware upgrade with
install-bundleRPC
- augments:
-
- deviation to allow read-write
if:phys-addressfor custom MAC address - ietf-ip: augments
- IPv4LL similar to standardized IPv6LL
- ietf-ip: deviations (
not-supported) added for IPv4 and IPv6:/if:interfaces/if:interface/ip:ipv4/ip:address/ip:subnet/ip:netmask/if:interfaces/if:interface/ip:ipv6/ip:address/ip:status/if:interfaces/if:interface/ip:ipv4/ip:neighbor/if:interfaces/if:interface/ip:ipv6/ip:neighbor
- ietf-routing: Base model for routing
- ietf-ipv4-unicast-routing: Static unicast routing, incl. operational data, i.e., setting static IPv4 routes and reading IPv4 routing table
- ietf-ipv6-unicast-routing: Static unicast routing, incl. operational data, i.e., setting static IPv6 routes and reading IPv6 routing table
- ietf-ospf: Limited support for OSPFv2, with additional support for injecting default route, and route redistribution. Underlying routing engine in use is Frr. Includes operational status + data (routes). See infix-routing model for detailed list of deviations
- infix-ethernet-interface: deviations for ieee802-ethernet-interface
- infix-routing: Limit ietf-routing to one instance
defaultper routing protocol, also details unsupported features (deviations) to both ietf-routing and ietf-ospf models, as well as augments made to support injecting default route in OSPFv2 - infix-if-bridge: Linux bridge interfaces with native VLAN support
- infix-if-type: deviation for interface types, limiting number to
supported types only. New identities are derived from default IANA
interface types, ensuring compatibility with other standard models, e.g.,
ieee802-ethernet-interface.yang - infix-if-veth: Linux VETH pairs
- infix-if-vlan: Linux VLAN interfaces, e.g.
eth0.10
- deviation to allow read-write
-
infix-containers: Support for Docker containers, incl. operational data to query status and remotely stop/start containers
-
infix-dhcp-client: DHCPv4 client, including supported options
-
Configurable services:
- ieee802-dot1ab-lldp: stripped down to an
enabledsetting - infix-services: support for enabling mDNS service/device discovery
- ieee802-dot1ab-lldp: stripped down to an
-
New hardware support: NanoPi R2S from FriendlyELEC, a simple two-port router
-
Static routing support, now also for IPv6
-
Dynamic routing support with OSPFv2, limited (see
infix-routing.yangfor deviations), but still usable in most relevant use-cases. If you are using this and are interested in more features, please let us know!- Multiple area support, including different area types
- Route redistribution
- Default route injection
- Full integration with Bidirectional Forward Detection (BFD)
- Operational status, including but not limited to:
- OSPF Router ID
- Neighbor status
- OSPF routing table
- Interface type, incl. passive status
- For more information, see
doc/networking.md
-
Support for disabling USB ports in
startup-config(no auto-mount yet!) -
Initial support for Docker containers, see documentation for details:
- Custom Infix model, see
infix-containers.yangfor details - Add image URL/location and volumes/mounts/interfaces to configuration, the system ensures the image is downloaded and container created in the background before launching it. If now networking is available the job is queued and retried every time a new network route is learned
- Status and actions (stop/start/restart) available in operational datastore
- Possible to move physical switch ports inside container, see docs
- Possible to bundle OCI archives in Infix image, as well as storing any
file content in
factory-configto override container image defaults
- Custom Infix model, see
-
IEEE Ethernet interface:
- Support for setting port speed/duplex or auto-negotiating
- New per-port counters, augments to IEEE model added in infix-ethernet.yang:
in-good-octets,out-good-octets
-
Many updates to DHCPv4 client YANG model:
- new options, see
infix-dhcp-client.yangfor details:- Default options: subnet, router, dns+domain, hostname, broadcast, ntpsrv
- Set NTP servers, require NTP client in ietf-system to be enabled, will
be treated as non-preferred sources, configured
preferservers wins - Learn DNS servers, statically configured servers always takes precedence
- Install routes, not only from option 3, but also options 121 and 249
- Support for ARP:ing for client lease (default enabled)
- Configurable route metrics, by default metric 100 to allow static routes to win over DHCP routes, useful for backup DHCP connections
- new options, see
-
IETF Hardware data: added YANG model for vital product data representation, and augments for initial USB support (enable/disable)
-
IETF System:
- the
motdaugment ininfix-system.yangfor Message of the Day has been marked as obsolete and replaced withmotd-banner. The new setting is of type binary and allows control codes and multi-line content to be stored. The legacymotdwill remain for the foreseeable future and takes precedence over the newmotd-bannersetting - new
text-editoraugment ininfix-system.yangto select the backend for the newtext-editorcommand:emacs,nano, orvi
- the
-
Many updates to the test system, Infamy, incl. new Quick Start Guide in updated
doc/testing.mdto help new developers get started -
Add
htopto default builds, useful for observing and attaching (strace) -
Change the default shell of the
adminuser fromclishtobash. Change required for factory production and provisioning reasons. Only affects the built-in default, customer specificfactory-config's are not affected! -
CLI: the
setcommand on a boolean can now be used without an argument,set booleansets the boolean option to true -
CLI: new command
change, for use with ietf-system user passwords, starts an interactive password dialog, including confirmation entry. The resulting password is by default salted and hashed using sha512crypt -
CLI: new command
text-editor, for use with binary fields, e.g.,contentfor file mounts in containers, or the newmotd-banner:admin@infix-c0-ff-ee:/config/system/> text-editor motd-banner ... exit with Ctrl-x Ctrl-c ... admin@infix-c0-ff-ee:/config/system/> show motd-banner VGhpcyByZWxlYXNlIHdhcyBzcG9uc29yZWQgYnkgQWRkaXZhIEVsZWt0cm9uaWsK; -
CLI: new admin-exec command
show ntp [sources] -
CLI: new admin-exec command
show dnsto display DNS client status -
CLI: new admin-exec command
show ospf [subcommand] -
CLI: new admin-exec command
show container [subcommand] -
CLI: new admin-exec command
show hardwareonly USB port status for now -
CLI: updates to the
show interfacescommand to better list bridge VLANs
- Fix #177: ensure bridge is not bridge port to itself
- Fix #259: failure to
copy factory-config startup-configin CLI - Fix #278: allow DHCP client to set system hostname (be careful)
- Fix #283: hostname in DHCP request adds quotation marks
- Fix #294: drop stray
vfrom version suffix in release artifacts - Fix #298: drop privileges properly before launching user
shellin CLI - Fix #312: race condition in
ipv4_autoconf.py, causes test to block forever - Backport upstream fix to netopeer2-server for fetching YANG models that refer to submodules over NETCONF
- CLI: drop developer debug in
setcommand - Fix out-of-place
[OK]messages at shutdown/reboot - Fix garbled syslog messages due to unicode in Infix tagline, drop unicode
v23.11.0 - 2023-11-30
Note: this is the first release where the
rootaccount is disabled in default builds. Only theadminuser, generated fromfactory-config, can log in to the system. This can be changed only in developer builds:make menuconfig-> System configuration ->[*]Enable root login with password
-
ieee802-ethernet-interface: Currently supported (read-only) features:
- Status of auto-negotiation, and if enabled.
- Current speed and duplex
- Frame counters:
YANG Linux / Ethtool out-framesFramesTransmittedOKout-multicast-framesMulticastFramesXmittedOKout-broadcast-framesBroadcastFramesXmittedOKin-total-octetsFramesReceivedOK+ FrameCheckSequenceErrors+ FramesLostDueToIntMACRcvError+ AlignmentErrors+ etherStatsOversizePkts+ etherStatsJabbersin-framesFramesReceivedOKin-multicast-framesMulticastFramesReceivedOKin-broadcast-framesBroadcastFramesReceivedOKin-error-undersize-framesundersize_pktsin-error-fcs-framesFrameCheckSequenceErrors -
- augments:
- MotD (Message of the Day)
- User login shell, default:
/bin/false(no SSH or console login) - State information for remotely querying firmware version information
- deviations:
- timezone-name, using IANA timezones instead of plain string
- UTC offset, only support per-hour offsets with tzdata
- Usernames, clarifying Linux restrictions
- Unsupported features marked as deviations, e.g. RADIUS
- infix-system-software: firmware upgrade with
install-bundleRPC
- augments:
-
- deviation to allow read-write
if:phys-addressfor custom MAC address - ietf-ip: augments
- IPv4LL similar to standardized IPv6LL
- ietf-ip: deviations (
not-supported) added for IPv4 and IPv6:/if:interfaces/if:interface/ip:ipv4/ip:address/ip:subnet/ip:netmask/if:interfaces/if:interface/ip:ipv6/ip:address/ip:status/if:interfaces/if:interface/ip:ipv4/ip:neighbor/if:interfaces/if:interface/ip:ipv6/ip:neighbor
- ietf-routing: Base model for routing
- ietf-ipv4-unicast-routing: Static unicast routing, incl. operational data, i.e., setting static IPv4 routes and reading IPv4 routing table
- infix-ethernet-interface: deviations for ieee802-ethernet-interface
- infix-routing: Limit ietf-routing to one instance
defaultper routing protocol, also details unsupported features (deviations) - infix-if-bridge: Linux bridge interfaces with native VLAN support
- infix-if-type: deviation for interface types, limiting number
to supported types only. New identities are derived from default
IANA interface types, ensuring compatibility with other standard
models, e.g.,
ieee802-ethernet-interface.yang - infix-if-veth: Linux VETH pairs
- infix-if-vlan: Linux VLAN interfaces, e.g.
eth0.10
- deviation to allow read-write
-
Configurable services:
- ieee802-dot1ab-lldp: stripped down to an
enabledsetting - infix-services: support for enabling mDNS service/device discovery
- ieee802-dot1ab-lldp: stripped down to an
- The CLI built-in command
password generatehas been changed to use the secure mode of thepwgentool, and 13 chars for increased entropy - The
qemu.sh -ccommand, available in developer builds and the release zip, can now be used to modify the RAM size and enable VPD emulation - Add support for overriding generated factory defaults in derivatives
using a
/etc/confdrc.lcocalfile -- incl. updated branding docs. - Add support for detecting factory reset condition from a bootloader
- Ensure
/varis also cleared (properly) during factory reset - Add support for port auto-negotiation status in operational datastore
- Add CLI support for showing veth pairs in
show interfaces - Speedups to CLI detailed view of a single interface
- Updated documentation of VLAN interfaces and VLAN filtering bridge
- Updated documentation for how to customize services in Hybrid Mode
- In RMA mode (runlevel 9), the system no longer has any login services
- Disable
rootlogin in all NETCONF builds, onlyadminavailable - Add support for VPD data in ONIE EEPROM format
- Add
iito, the intelligent input/output daemon for LED control - Add port autoneg and speed/duplex status to operational data
- Upgrade Linux to v6.5.11, with kkit extensions
- Add support for static IPv4 routing using
ietf-routing@2018-03-13.yangandietf-ipv4-unicast-routing@2018-03-13.yang, onedefaultinstance only - Add support for partitioning and self-provisioning of new devices
- Add support for reading
adminuser's default password from VPD. Devices that do not have a VPD can set a password hash in the device tree - Add support for upgrading software bundles (images) from the CLI. Supported remote servers: ftp, tftp, and http/https.
- Traversing the CLI configure context has been simplified by collapsing all
YANG containers that only contain a single list element. Example:
edit interfaces interface eth0becomesedit interface eth0 - Add CLI support for creating configuration backups and transferring files to/from remote servers: tftp, ftp, http/https (download only). Issue #155
- Add
_netconf-ssh._tcprecord to mDNS-SD
- Fix #111: fix auto-inference of dynamic interface types (bridge, veth)
- Fix #125: improved feedback on invalid input in configure context
- Fix #198: drop bridge default PVID setting, for VLAN filtering bridge. All bridge ports must have explicit VLAN assignment (security)
- Fix #215: impossible to enable NTP client, regression from v23.06.0
- Fix regression in CLI
show factory-configcommand - Fix missing version in
/etc/os-releasevariablePRETTY_NAME - Fix failure to start
podmanin GNS3 (missing Ext4 filesystem feature) - Fix initial terminal size probing in CLI when logging in from console port
- Fix CLI
show running-config, use proper JSON format like other files - Fix caching of libyang module references in confd. Loading other plugins to sysrepo-plugind modifies these references, which may can cause corruption
- Fix missing
vinVERSION,VERSION_ID, andIMAGE_VERSIONin/etc/os-releaseand other generated files for release builds.
v23.10.0 - 2023-10-31
Note: upcoming releases will lock the
rootuser for system-only services. Instead anadminuser will be the only default user with the CLI as its login shell. This user is already available, so please consider updating any guidelines or documentation you may have.
- ietf-system:
- augments:
- MotD (Message of the Day)
- User login shell, default:
/bin/false - State information for remotely querying firmware version information
- deviations:
- timezone-name, using IANA timezones instead of plain string
- UTC offset, only support per-hour offsets with tzdata
- Usernames, clarifying Linux restrictions
- Unsupported features marked as deviations, e.g. RADIUS
- infix-system-software: firmware upgrade with
install-bundleRPC
- augments:
- ietf-interfaces:
- deviation to allow read-write
if:phys-addressfor custom MAC address - ietf-ip: augments
- IPv4LL similar to standardized IPv6LL
- ietf-ip: deviations (
not-supported) added for IPv4 and IPv6:/if:interfaces/if:interface/ip:ipv4/ip:address/ip:subnet/ip:netmask/if:interfaces/if:interface/ip:ipv6/ip:address/ip:status/if:interfaces/if:interface/ip:ipv4/ip:neighbor/if:interfaces/if:interface/ip:ipv6/ip:neighbor
ietf-if-vlan-encapsulation:Removed in favor of a native model.- infix-if-bridge: Linux bridge interfaces with native VLAN support
- infix-if-type: deviation for interface types, limiting number
to supported types only. New identities are derived from default
IANA interface types, ensuring compatibility with other standard
models, e.g.,
ieee802-ethernet-interface.yang - infix-if-veth: Linux VETH pairs
- infix-if-vlan: Linux VLAN interfaces, e.g.
eth0.10(New model!)
- deviation to allow read-write
- Configurable services:
- ieee802-dot1ab-lldp: stripped down to an
enabledsetting - infix-services: support for enabling mDNS service/device discovery
- ieee802-dot1ab-lldp: stripped down to an
-
Add support for setting/querying IPv4/IPv6 MTU, see #152 for details.
-
Add support for Fail Secure Mode: if loading
startup-configfails, e.g. YANG model validation failure after upgrade, the system now falls back to loadfailure-configinstead of just crashing. This config, along withfactory-config, is generated on every boot to match the active image's YANG models. In case neither config can be loaded, or even bootstrapping YANG models fail, the system will go into an RMA state -- Return to Manufacturer, clearly signaled on the console and, on devices that support it, angry LED signaling. See #154 for more. -
Add support for generating GNS3 appliance file for NETCONF Aarch64.
-
Add support for UTC offset (+/- HH:00) in
ietf-system, PR #174 -
Add support for
ietf-factory-defaultRPC, PR #175 -
Add support for performing factory reset (using #175 RPC) from CLI
-
Replace
ietf-if-vlan-encapsulationYANG model with the nativeinfix-if-vlanmodel. This fits better with Linux VLAN interfaces and simplifies the syntax greatly. For details, see PR #179admin@example:/config/interfaces/interface/eth0.10/> set vlan id 10 lower-layer-if eth0 -
The following new NETCONF interface operational counters have been added:
| YANG | Linux / Ethtool |
|---|---|
out-frames |
FramesTransmittedOK |
out-multicast-frames |
MulticastFramesXmittedOK |
out-broadcast-frames |
BroadcastFramesXmittedOK |
in-total-frames |
FramesReceivedOK |
+ FrameCheckSequenceErrors |
|
+ FramesLostDueToIntMACRcvError |
|
+ AlignmentErrors |
|
+ etherStatsOversizePkts |
|
+ etherStatsJabbers |
|
in-frames |
FramesReceivedOK |
in-multicast-frames |
MulticastFramesReceivedOK |
in-broadcast-frames |
BroadcastFramesReceivedOK |
in-error-undersize-frames |
undersize_pkts |
in-error-fcs-frames |
FrameCheckSequenceErrors |
- Greatly improved branding support using
make menuconfig. All the identifying strings, including firmware image, is in/etc/os-release, will be used in CLIshow system-information, the WebUI About dialog, and any prominent areas when booting up (on console), logging in to CLI and WebUI. - IGMP/MLD snooping is now disabled by default on new bridges. Support for multicast filtering bridges expected no later than v24.01.
- The SSDP responder, device discovery in Windows, has been removed in favor of Windows 10 (build 1709) native support for mDNS-SD. Details in #166
- A GreenPAK programmer has been added, not enabled by default. This is a popular programmable little chip from Renesas. Worth a look!
- The
confdscriptgen-interfacescan now generate bridges and stand-alone interfaces with IPv6 (SLAAC) forfactory-configet al. - Drop
x86_64_minimal_defconfig, previously used for regression tests only - Documentation updates of how IPv4/IPv6 addresses are shown in NETCONF operational data, as well as the built-in CLI, see #163 for details.
- Fix #106: confd: drop deviation
ietf-system:timezone-utc-offset - Fix #151: Operational status broken in v23.09
- Fix #159: Hacky generation of
/etc/resolv.confat boot - Fix #162: VLAN interface without encapsulation is accepted by YANG model
v23.09.0 - 2023-10-02
Note: upcoming releases will lock the
rootuser for system-only services. Instead anadminuser will be the only default user with the CLI as its login shell. This user is already available, so please consider updating any guidelines or documentation you may have.
- ietf-system:
- infix-system: MotD (Message of the Day) augment
- infix-system: user login shell augment, default:
/bin/false - infix-system-software: system-state/software augment for remotely querying firmware version information
- infix-system-software: firmware upgrade with
install-bundleRPC - infix-system: timezone-name deviation, replaced with IANA timezones
- infix-system: username deviation, clarifying Linux restrictions
- infix-system: deviations for unsupported features, e.g. RADIUS
- ietf-interfaces:
- infix-interfaces: deviation for
if:phys-addressto allow read-write - ietf-ip: augmented with IPv4LL similar to standardized IPv6LL
- infix-ip: deviations (
not-supported) added for IPv4 and IPv6:/if:interfaces/if:interface/ip:ipv4/ip:address/ip:subnet/ip:netmask/if:interfaces/if:interface/ip:ipv6/ip:address/ip:status/if:interfaces/if:interface/ip:ipv4/ip:mtu/if:interfaces/if:interface/ip:ipv6/ip:mtu/if:interfaces/if:interface/ip:ipv4/ip:neighbor/if:interfaces/if:interface/ip:ipv6/ip:neighbor
- ietf-if-vlan-encapsulation: Linux VLAN interfaces, e.g.
eth0.10 - infix-if-bridge: Linux bridge interfaces with native VLAN support
- infix-if-veth: Linux VETH pairs
- infix-if-type: deviation for interface types, limiting number
to supported types only. New identities are derived from default
IANA interface types, ensuring compatibility with other standard
models, e.g.,
ieee802-ethernet-interface.yang
- infix-interfaces: deviation for
- Configurable services:
- ieee802-dot1ab-lldp: stripped down to an
enabledsetting - infix-services: support for enabling mDNS and SSDP discovery
- ieee802-dot1ab-lldp: stripped down to an
- The following new NETCONF interface operational status have been added:
- admin-status
- IP address origin (dhcp, static, link-layer, random, other)
- bridge
- parent-interface
- basic statistics (
in_octets,out_octets)
- Support for custom interface
phys-address(MAC address) - The CLI admin-exec command
show interfacesnow fully uses NETCONF operational data to display both available interfaces and all of their IP addresses. Displaying an individual interface will show more info. - The CLI admin-exec command
password encryptnow default to SHA512
- Fix #136: IPv6 autoconf
create-global-addresses truedoes not bite - Fix #138: Not possible to have static IP and DHCP at the same time
- Minor fixes and updates to documentation (faulty links, references)
- The
sync-fork.ymlworkflow has finally been fixed.
v23.08.0 - 2023-08-31
Note: upcoming releases will lock the
rootuser for system-only services. Instead anadminuser will be the only default user with the CLI as its login shell. This user is already available, so please consider updating any guidelines or documentation you may have.
- ietf-system:
- infix-system: MotD (Message of the Day) augment
- infix-system: user login shell augment, default:
/bin/false - infix-system-software: system-state/software augment for remotely querying firmware version information
- infix-system-software: firmware upgrade with
install-bundleRPC - infix-system: timezone-name deviation, replaced with IANA timezones
- infix-system: username deviation, clarifying Linux restrictions
- infix-system: deviations for unsupported features, e.g. RADIUS
- ietf-interfaces:
- ietf-ip: augmented with IPv4LL similar to standardized IPv6LL
- ietf-if-vlan-encapsulation: Linux VLAN interfaces, e.g.
eth0.10 - infix-if-bridge: Linux bridge interfaces with native VLAN support
- infix-if-veth: Linux VETH pairs
- infix-if-type: deviation for interface types, limiting number
to supported types only. New identities are derived from default
IANA interface types, ensuring compatibility with other standard
models, e.g.,
ieee802-ethernet-interface.yang
- Configurable services:
- ieee802-dot1ab-lldp: stripped down to an
enabledsetting - infix-services: support for enabling mDNS and SSDP discovery
- ieee802-dot1ab-lldp: stripped down to an
- Bump Linux kernel: v5.19 to v6.1
- Updated board support for Microchip SparX-5i and Marvell CN9130 CRB
- New logo and significant updates to the documentation
- New NETCONF RPC
factory-defaultto resetrunning-config - Replaced limited BusyBox ping with iputils-ping
- Most system services are now disabled by default, support for enabling
LLDP, mDNS-SD, and SSDP using NETCONF, enabled in
factory-config - Firmware upgrade framework, based on RAUC, added
- Matching YANG model (see above) and an
install-bundleRPC - Currently supported upgrade protocols: HTTP/HTTPS, FTP, SCP
- Matching YANG model (see above) and an
- Initial support for interface operational status, in ietf-interfaces
- Add support for setting user login shell:
bash,clish,false - Default login shell for new users:
false - Massive updates and fixes to the CLI (klish):
- Line editing now works as similar CLI:s from major vendors
- Hotkey fixes: Ctrl-D and Ctrl-Z now work as expected
- Prompt changed from JunOS style to be more similar to Bash
- Online help commands, both in admin-exec and configure context,
type
helpafter entering the CLI to get started - Improved help for configure context using YANG descriptions
- Support for reading and setting system "datetime" (RPC), an
optional
isokeyword can be used when reading time to see the format required when setting the time - Support for showing interfaces status, using above operational data
- Support for showing bridge status: links, fdb, mdb, vlans
- Support for showing log files, including tailing with
follow - Support for
password generateandpassword encrypt, highly useful from configure context when creating new users: use thedo password encrypt type sha256to generate the hash - Support show uptime, version, calling
netcalc, ping, and tcpdump
- Fix #57: unneccesary lldpd restarts on configuration change
- Ensure mDNS advertises the correct hostname after hostname change
- Fix regression in enabling IPv4 ZeroConf address
- Loopback interface now shows
UPoperstate instead ofUNKNOWN - Fix adding user without password, i.e., login using SSH keys only
v23.06.0 - 2023-06-23
Midsummer release. The first official Infix release, based on Buildroot 2023.02.2, with NETCONF support using the sysrepo and netopeer2.
Supported YANG models in addition to those used by sysrepo and netopeer:
- ietf-system
- Everything except radius authentication and timezone-utc-offset
- Augmented with MotD (Message of the Day), Infix YANG model
- ietf-interfaces
- ietf-ip augmented with IPv4LL similar to standardized IPv6LL
- ietf-if-vlan-encapsulation, Linux VLAN interfaces, e.g.
eth0.10 - Linux bridge interfaces with native VLAN support, Infix YANG model
- Linux VETH pairs, Infix YANG model
DISCLAIMER: the Infix YANG models for Linux, are still under heavy development. New revisions are expected which may not be backwards compatible. When upgrading to a new release, test on a GNS3 staging environment first, or start over from a factory reset.
- Bump sysrepo to v2.2.73
- Backport support for initializing factory-default data store with default config data also for sysrepo internal modules.
- Add support for
sysrepocfg -Cfactory -d running, for testing
- Bump netopeer2 to v2.1.62
- Bump libyang to v2.1.80
- Add klish, a CLI for sysrepo
- Add podman for container support, backported from upstream Buildroot
- Add conmon for container support, backported from upstream Buildroot
- Backport cni-plugins support for host-local and static plugins
- N/A
Footnotes
-
I.e., set up in the configuration, as opposed to temporary ones started with
container runfrom the CLI admin-exec context. ↩