Skip to content

Latest commit

 

History

History
executable file
·
165 lines (114 loc) · 5.17 KB

readme.md

File metadata and controls

executable file
·
165 lines (114 loc) · 5.17 KB

1. Update Git Submodules

git submodule update --init --recursive

2. Initialize Python virtual env

Create virtual Python environment: python3 -m venv venv

Activate Python virtual env: source venv/bin/activate

Install required packages into venv: pip install -r requirements.txt

3. Build

Build C-code and extract bindings for Python: make

Build Python wheel: python3 -m build

Build Debian package: make debpkg

4. Install and run

After installing the Python package with pip, the daemon can be run with sudo atdecc-py

For example: pip install dist/atdecc-0.1.post0-py3-none-any.whl

(or equivalently sudo python3 -m atdecc).

Check out atdecc-py --help for additional options like network interface and AEM config file.

5. Systemd service

Install the debian package from the package registry with apt install atdecc-py.

The service can then be installed and started with systemctl enable atdecc-py --now.

Check the status with systemctl status atdecc-py.

Docker

As a PoC the Dockerfile can be built to an image, primarily to ensure compilation succeeds on debian when developing locally (note that this presumes you have the git submodules checked out locally):

$ docker buildx build . -t atdecc-py --platform=linux/amd64

Then run it with

$ docker run --rm -ti atdecc-py

This setup can also serve as a blueprint for the setup of the final production image.

BeagleBone/Bela

The following steps are necessary to compile the daemon on BeagleBone Black/Bela:

$ sudo apt-get install cmake build-essential python3-venv clang libclang-dev libpcap-dev gettext-base
$ python3 -m venv venv
$ source venv/bin/activate
$ pip install -r requirements.txt
$ pip freeze > requirements.txt
$ make clean
$ make

Running the daemon has to be done as root:

$ sudo su
# export LD_LIBRARY_PATH=$PWD/src
# source venv/bin/activate
# ./src/atdecc.py -d

Note: On Debix you have to specify the interface:

# ./src/atdecc.py -d -i ens33

Afterwards you should be able to discover the SBC in Hive.

Requirements

AVB Listener

ATDECC End Station

An ATDECC End Station is a device that has one or more network ports and has one or more ATDECC Entities.

An ATDECC End Station shall implement:

  • at least one ATDECC Entity
  • at least one network interface
  • IEEE 1722 control AVTP data unit (AVTPDU) packetization and depacketization

An ATDECC End Station may implement:

  • multiple ATDECC Entities
  • one or more network interfaces that implement an appropriate AVB profile as defined in IEEE Std 802.1BA­2011 and corrected by IEEE Std 802.1BATM­2011/Cor 1­2016.
  • IEEE 802.1AS time synchronization
  • IEEE 1722 stream AVTPDU packetization
  • IEEE 1722 stream AVTPDU depacketization
  • IEEE 1722 multicast address allocation protocol (MAAP)
  • IEEE 802.1Q Clause 34 FQTSS Traffic Shaping
  • IEEE 802.1Q Clause 35 Stream Reservation Protocol

ATDECC Entity

An ATDECC Entity uses one or more of the following ATDECC protocols for discovering or controlling other ATDECC Entities or for being discovered or controlled by other ATDECC Entities:

  • ATDECC discovery protocol (ADP)
  • ATDECC connection management protocol (ACMP)
  • ATDECC enumeration and control protocol (AECP)

An ATDECC Entity shall:

  • Have a single Entity ID that is assigned by the manufacturer or via an ATDECC Proxy Server.
  • Implement at least one of the ATDECC Controller, ATDECC Talker, ATDECC Listener, or the ATDECC Responder role.

A discoverable ATDECC Entity is an ATDECC Entity that is capable of advertising itself on a local area network (LAN). An ATDECC Entity that is to be discoverable on a network shall implement:

  • 6.2.4 “Advertising Entity State Machine”
  • 6.2.5 “Advertising Interface State Machine”
  • 6.2.7 “Discovery Interface State Machine”

An ATDECC Entity that is to be discoverable on a network may implement:

  • 7.5.1 “Identification Notification”

An ATDECC Entity which has a need to discover other ATDECC Entities on a LAN shall implement:

  • 6.2.6 “Discovery State Machine”

An ATDECC Entity that implements 9.3.5 “ATDECC Entity Model Entity State Machine” that implements 7.4.5 “READ_DESCRIPTOR Command” shall implement:

  • 7.2.1 “ENTITY Descriptor”

An ATDECC Entity that implements 9.3.5 “ATDECC Entity Model Entity State Machine” that implements 7.4.5 “READ_DESCRIPTOR Command” may implement:

  • 7.2.2 “CONFIGURATION Descriptor”

ATDECC Listener

An ATDECC Listener is an ATDECC Entity that can sink one or more AVTP Streams.

An ATDECC Listener shall use ATDECC messages transported via IEEE 1722 AVTPDUs.

An ATDECC Listener shall implement the following:

  • IEEE 1722 AVTP Listener
  • 8.2.4 “ACMP Listener State Machine”
  • 9.3 “ATDECC Entity Model format”
  • 9.3.3 “ATDECC Entity Model Commands”
  • 9.3.4 “ATDECC Entity Model Responses”
  • 9.3.5 “ATDECC Entity Model Entity State Machine”, implementing:
    • 7.4.1 “ACQUIRE_ENTITY Command”
    • 7.4.2 “LOCK_ENTITY Command”
    • 7.4.3 “ENTITY_AVAILABLE Command”
    • 7.4.4 “CONTROLLER_AVAILABLE Command”

An ATDECC Listener may implement the following:

  • 9.3.5 “ATDECC Entity Model Entity State Machine”, implementing zero or more of the following: xxxx