Please note, by default the root
account is disabled in Infix NETCONF
builds. Meaning, the only way to access the system is with the admin
account, which is created based on credentials found in the VPD area --
for Qemu devices this is emulated using qemu_fw_cfg
.
For developers this can be quite frustrating to be blocked from logging
in to debug the system. So we recommend enabling the root
account in
the Buildroot make menuconfig
system.
make menuconfig
-> System configuration
-> [*]Enable root login with password
When pre-built releases are not enough, for instance when you want to add or modify some Open Source components, you can clone the Infix tree to your PC:
$ mkdir ~/Projects; cd ~/Projects
$ git clone https://github.com/kernelkit/infix.git
$ cd infix/
$ git submodule update --init
Please see the Contributing section, below, for details on how to fork and clone when contributing to Infix.
Customer builds add product specific device trees, more OSS packages, e.g., Frr and podman, and sometimes integrates proprietary software. What's important to remember, however, is that they are all made by setting up Infix as a GIT submodule, similar to how Infix set up a GIT submodule for Buildroot.
So, in addition to using the customer's specific defconfig(s), one must also make sure to update all submodules, otherwise you will likely end up with a broken build.
$ ...
$ git submodule update --init --recursive
~~~~~~~~~~~
Other caveats should be documented in the customer specific trees.
Buildroot is almost stand-alone, it needs a few locally installed tools to bootstrap itself. The most common ones are usually part of the base install of the OS, but specific ones for building need the following. The instructions here are for Debian/Ubuntu based systems (YMMV):
$ sudo apt install bc binutils build-essential bzip2 cpio \
diffutils file findutils git gzip \
libncurses-dev libssl-dev perl patch \
python3 rsync sed tar unzip wget \
autopoint bison flex autoconf automake
For details, see the Getting Started and System Requirements sections of the excellent manual.
To build an Infix image; select the target and then make:
make x86_64_defconfig
make
Online help is available:
make help
To see available defconfigs for supported targets, use:
make list-defconfigs
Working with the regression test framework, Infamy, a few more tools and services are required on your system:
$ sudo apt install jq graphviz qemu-system-x86 qemu-system-arm \
ethtool gdb-multiarch tcpdump tshark
To be able to build the test specification you also need:
$ sudo apt-get install python3-graphviz ruby-asciidoctor-pdf
Developing with Infix is the same as developing with Buildroot.
When working with a package, be it locally kept sources, or when using
local.mk
, you only want to rebuild the parts
you have modified:
make foo-rebuild
or
make foo-reconfigure
or, as a last resort when nothing seems to bite:
make foo-dirclean foo-rebuild
As shown here, you can combine multiple build targets and steps in one go, like this:
make foo-rebuild bar-rebuild all run
This rebuilds (and installs) foo
and bar
, the all
target calls
on Buildroot to finalize the target filesystem and generate the images.
The final run
argument is explained below.
The Infix src/confd/
is the engine of the system. Currently it is a
plugin for systemd-plugind
and contains XPath subscriptions to all the
supported YANG models.
There are essentially two ways of adding support for a new YANG model:
- The sysrepo way, or
- The Infix way, using libsrx (the
lydx_*()
functions)
The former is well documented in sysrepo, and the latter is best taught
by example, e.g., src/confd/src/infix-dhcp.c
. Essentially libsrx is a
way of traversing the libyang tree instead of fetching changes by XPath.
When working with confd
you likely want to enable full debug mode,
this is how you do it:
-
Open the file
package/confd/confd.conf
-
Uncomment the first line
set DEBUG=1
-
Change the following line to add
-v3
at the end[S12345] sysrepo-plugind -f -p /run/confd.pid -n -- Configuration daemon
to:
[S12345] sysrepo-plugind -f -p /run/confd.pid -n -v3 -- Configuration daemon
Now you can rebuild confd
, just as described above, and restart Infix:
make confd-rebuild all run
Manual testing can be done using Qemu by calling make run, see also Infix in Virtual Environments.
The Infix automated test suite is built around Qemu and Qeneth, see:
While reviewing a pull request, you might find yourself wanting to
play around with a VM running that exact version. For such
occations, gh-dl-artifact.sh is your
friend in need! It will use the GitHub CLI
(gh) to locate a prebuilt image from our CI
workflow, download it, and prepare a local output directory from which
you can launch both make run
instances, and run regression tests
with make test
and friends.
For example, if you are curious about how PR 666 behaves in some
particular situation, you can use gh
to switch to that branch, from
which gh-dl-artifact.sh
can then download and prepare the
corresponding image for execution with our normal tooling:
gh pr checkout 666
./utils/gh-dl-artifact.sh
cd x-artifact-a1b2c3d4-x86_64
make run
Note: CI artifacts are built from a merge commit of the source and target branches. Therefore, the version in the Infix banner will not match the SHA of the commit you have checked out.
Infix is built from many components, when contributing you need to set up your own fork, create a local branch for your change, push to your fork, and then use GitHub to create a Pull Reqeuest.
For this to work as painlessly as possible for everyone involved:
- Fork Infix to your own user or organization1
- Fork all the Infix submodules, e.g.,
kernelkit/buildroot
to your own user or organization as well - Clone your fork of Infix to your laptop/workstation
- Deactivate the Actions you don't want in your fork
- Please read the Contributing Guidelines as well!
$ cd ~/Projects
$ git clone https://github.com/YOUR_USER_NAME/infix.git
$ cd infix/
$ git submodule update --init
Note: when updating/synchronizing with upstream Infix changes you may have to synchronize your forks as well. GitHub have a
Sync fork
button in the GUI for your fork for this purpose. A cronjob on your server of choice can do this for you with the GitHub CLI tool.
Footnotes
-
Organizations should make sure to lock the
main
(ormaster
) branch of their clones to ensure members do not accidentally merge changes there. Keeping these branches in sync with upstream Infix is highly recommended as a baseline and reference. For integration of local changes another company-specific branch can be used instead. ↩