So, this is my understanding of the current hardware situation and task goals (extrapolated from conversations on PHABRICATOR and the [[ https://wiki.apertus.org/index.php/Mission_Briefings | Mission Briefing ]]). This is just my spec proposal, and I would like to have feedback before I begin implementation - or teams are built to take on individual tasks.
# WebGUI dependencies: REST, camera control daemon, automated firmware builds
**Please help me to correct erroneous / missing information by editing this directly ** 
##The CONTROLLER (WebGUI) must:
- be absolutely error free and buttery smooth from day one and forever after
- work perfectly on a well-defined set of devices, OS's and browsers
- gracefully fall back from touchscreen to mouse to keyboard to kicking and screaming
- implement existing graphic design work
- be highly reactive (max 33ms until DAEMON reacts to a command, 99ms for initial job state feedback from INTERFACE)
 - //I know this is utopian. Just the network stacks on each end each need 10-15ms but I think its possible when the system is tuned.//
- act as display for:
 - toast / alert / alarm notifications
 - system status including DAEMON's registered components
 - user interaction feedback
- debounce user input
- register and certify user device to interface by using the nonce created by the system INTERFACE when it downloaded its code
- work on one or more user-provided device(s)
  - smartphone mounted to enclosure
  - hdmi touchscreen monitor (is this out of scope?)
- allow for a user to lock out other potential users
 - Owner: RW 
 - Others: RO / none / dump / blacklist 
- work without requiring internet uplink at all, however it must connect to the camera via wifi or USB and pull its code at session begin (or on nonce invalidity)
 - Connecting to the camera should be easy (but is out of scope for the CONTROLLER)
 - Having LED feedback on the camera would be excellent
- send no more than one packet of MTU per command
 - including user nonce as "key"
- maintain user's preferences and current "nonce"
- include documentation and video how-to
- include tests
##The system INTERFACE must:
- have a CLI interface for remote (or headless) management and debugging (build this first, then open to the controller over TCP)
- enable TCP-IP communication via classical port 80
- accept well-formed curl / wget commands 
- be callable from within the system for e.g. touchscreen events, broadcasts, DAEMON emergency calls
- offer nonce'd controller client code (html, js, css)
- assume that DAEMON always succeeds in certain cases and reply with the "assumed" message - which would then be overwritten in case DAEMON says so (because DAEMON is always right)
- react to physical User Switch / Reset Switch
- enable easy registry of new features (via DAEMON module publish strategy)
- be a thin layer for communication between CONTROLLER <-> DAEMON
 - just like a classical I/O pipe: take an input from CONTROLLER, parse it, send it to DAEMON, watch for DAEMON's response and forward that back as output
- maintain a low-security user-registry of preferences (via nonce tracking / locking)
- be self-documenting
##The DAEMON must:
- use fifo instead of files or database as control structure
- be isolated from user input (at tcp, stack and environment levels) i.e. a polling service looking for well-formed commands that land on fifo.in (that should live in a small wordsize ideally in the L2 Cache - namely exactly at MTU of  ≤ 536 bytes)
- monitor, kill and restart its spawn when needed
- as a mission critical interface have high `nice` priority
 - manage the state of the hardware (absolute highest priority)
 - read from fifo.in (highest priority)
 - write results to ram-backed storage (fifo.out) high priority
 - report on state of the hardware (normal priority)
 - maintain a logrotate in non-volatile storage (low priority - NOT SD!)
 - watch file I/O, disk, network, battery health (lowest priority)
 - publish its currently available modules and their status as registered on boot (init priority)
- include documentation
- include tests
----
**CURRENT BUILD STATE (BETA 2)**
- Hardware host: Xilinx Zynq 7020 based MicroZed 
 - Data sheet: [[ http://zedboard.org/sites/default/files/product_briefs/PB-AES-Z7MB-7Z010-G-V2.pdf | microzed.org ]] | [[ https://www.avnet.com/shop/us/products/avnet-engineering-services/aes-z7mb-7z020-som-g-3074457345628965473/ | Tech Specs ]] (Please pull these resources and make available locally)
 - SOC: AES-Z7MB-7Z020-SOM-G (Z7MB-720x0-ASY Revision Board)
 - Clock: 33.33 Mhz Oscillator
 - Hardware Clock Speed: 
 - Processors: Dual ARM® Cortex®-A9 MPCore™ with CoreSight™
  - Dual Core A9 32 bit (NEON instructions 64 bit)
  - `cat /proc/cpuinfo` output:
 - Cache: 512-KB L2 Unified Cache with ECC
 - GPU/VPU: none
 - RTC: none 
 - Ram: 1 GB of DDR3 SDRAM (what is the clock speed)
 - microSD: 8gb class 10 (What purpose does the SD card serve? First time boot? Nand flashing?)
 - Nand: 128 Mb of QSPI Flash (Is this the boot source? Are logs written to /var here?)
 - SSD: User Mod (make, model, size?)
 - USB: USB-OTG, USB 2.0
 - Wifi: None onboard [[ https://www.olimex.com/Products/USB-Modules/MOD-WIFI-AR9271-ANT/ | my recommendation ]] or [[ https://www.olimex.com/Products/USB-Modules/MOD-WIFI-AR9271-ANT/ | long-range ]]
 - Communication: Ethernet (ssh / tcp), UART, USB 2.0, JTAG
 - Physical switches: 2 (reset / user defined) -> what are we using it for?
 - Voltage: 5V (over USB micro) possible also via PoE, PoUSB or (maybe) J4
 - Battery: None, possible with [[ https://www.olimex.com/Products/Power/BATTERY-LIPO4400mAh/ | LiPo ]] and [[ https://www.olimex.com/Products/Power/USB-uLiPo/open-source-hardware | charger ]] plugged into the beta power adapter???
- Additional boards:
 - https://wiki.apertus.org/index.php/Beta_CMV12K_ZIF_Sensor_Board
 - https://wiki.apertus.org/index.php/Beta_Interface_Dummy_Board
 - https://wiki.apertus.org/index.php/PMOD_LED_Matrix_Debug_Module
 - https://wiki.apertus.org/index.php/Beta_HDMI_Plugin_Module
 - https://wiki.apertus.org/index.php/Beta_1x_PMOD_Plugin_Module
 - https://wiki.apertus.org/index.php/Beta_Debug_Shield
 - https://wiki.apertus.org/index.php/Beta_Power_Board
 - https://wiki.apertus.org/index.php/Beta_Main_Board
 - https://wiki.apertus.org/index.php/Beta_Power_Adapter_Board
- OS: [[ https://gitlab.com/apertus/beta-software/-/jobs/artifacts/master/download?job=final_artifacts | Arch Linux ]] based on http://stefan.konink.de/contrib/apertus/
 - Version Management: git (managed externally)
 - Live Build System: `dd if=..` or [[ https://etcher.io/ | etcher ]] -> SD Card
 - Firmware Build System: https://lab.apertus.org/T697
 - Virtual Machine Image: none
 - Screen Buffers: VDPAU I assume, via HDMI?
 - Hardened: no SELinux
 - Available code environments: /usr/lib/* linked and precompiled assembly, c, c++ binaries; python 2.7, ...
 - Available shells: bash, sh
 - Use #!/usr/bin/env: no
 - Available permissions: granular, inheritable but root is available
 - Disallowed builtins: none
 - User Management: none (arch default) apertus:apertus
 - Container Management: none
 - Process Management: none (other than PID / top)
 - Resource Management: per script, no central lookup table
 - Benchmarking: none
**ERRATA**
- https://wiki.apertus.org/index.php/Useful_Links
- https://wiki.apertus.org/index.php/Mission_Briefings
- https://gitlab.com/apertus
- NEON STUFF - [[ https://stackoverflow.com/questions/4097034/arm-cortex-a8-whats-the-difference-between-vfp-and-neon?rq=1 | You have 3 possibilities to use Neon:]] 
 - use intrinsics functions #include "arm_neon.h"
 - inline the assembly code
 - let the gcc to do the optimisations for you by providing -mfpu=neon as argument (gcc 4.5 is good on this)
 - https://stackoverflow.com/a/38775842
 - http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0204h/Bcfhfbga.html