- Send configurable radio frames with different encodings through a radio transmitter supported by WiringPi.
- Wireless scanning support in combination with a radio receiver for analyzing and replaying radio frames.
- Record and replay radio frames to easily control air targets without having to decode the protocol.
- Configuration file support for easily addressing air targets.
The following devices have been confirmed to work with aircontrol:
- ELRO AB440S and many similar wireless outlets (encoding type: Remote Controlled Outlet)
- Melitec lights (encoding type: Melitec)
- Tormatic garage doors (encoding type: Tormatic)
- Warema EWFS based devices, e.g. shutters (encoding type: Manchester)
- WOFI FC-66 controlled lamps (encoding type: Remote Controlled Outlet)
If you are controlling other devices with aircontrol please let me know.
aircontrol needs to be compiled on a Raspberry Pi (or on a host with a compatible cross tool chain). The following libraries are needed:
- WiringPi, as root install with:
apt-get install wiringpi
- libconfig++, as root install with:
apt-get install libconfig++9v5 libconfig++-dev
Perform the following steps to compile and install aircontrol:
-
Clone the aircontrol repository. The master branch contains stable versions while the develop branch contains a current development snapshot with the latest features and fixes.
To get the latest stable version from the master branch run:
$ git clone -b master https://github.com/rfkd/aircontrol.git
To get the latest development version from the develop branch run:
$ git clone https://github.com/rfkd/aircontrol.git
-
Enter the cloned directory and build aircontrol:
$ cd aircontrol $ make
-
Complete the installation as root (optional):
# make install
Note: An already existing configuration file will not be overwritten.
To remove aircontrol and its configuration file (if it hasn't changed) run:
# make uninstall
Note: aircontrol needs to be executed as root for accessing the GPIO hardware.
Execute aircontrol -h
to see a quick overview over all available command line parameters.
The following options are available:
-c <file>
Configuration file, defaulting to /etc/aircontrol.conf.
-d <file>
Specify an air scan dump file. Applicable only when air scanning (command parameter -s
).
-g <pin>
Override the GPIO pin to be used for scanning and targeting. The parameter must be a Broadcom GPIO number, not re-mapped. Might be used for quickly testing multiple transmitters or receivers.
-l
Limit the number of aircontrol instances to 1, i.e. prevent multiple program instances.
The following commands are available, only one of them must be specified:
-r <file>
Replay the given air scan dump file.
-s <ms>
Perform an air scan for the given number of milliseconds. An ASCII graph will be written to stdout which can be redirected to a file with tee
or something similar.
-t <target>
Execute the given air target, i.e. transmit the target code as configured.
Either parameter -r
, -s
or -t
is mandatory.
The default configuration file is located in /etc/aircontrol.conf. For details about the configuration file syntax check the manual of libconfig on its project site: http://www.hyperrealm.com/libconfig/libconfig_manual.html
The configuration consists of different sections explained below.
This section defines parameters required for air replay.
gpioPin
GPIO pin of the Raspberry Pi which is connected to the DATA line of a radio transmitter. This parameter expects Broadcom GPIO numbers, not re-mapped. Example: gpioPin = 17;
This section defines all air scan relevant parameters.
gpioPin
GPIO pin of the Raspberry Pi which is connected to the DATA line of a radio receiver. This parameter expects Broadcom GPIO numbers, not re-mapped. Example: gpioPin = 18;
samplingRate
Delay between two samples when air scanning in microseconds. This parameter in combination with the -s
value defines the number of segments being output. For example when scanning for 1ms (=1000us) with a samplingRate
of 100us there will be 10 segments printed to stdout. Example: samplingRate = 100;
This section stores configuration defaults for all target sections.
gpioPin
GPIO pin of the Raspberry Pi which is connected to the DATA line of a radio transmitter. This parameter expects Broadcom GPIO numbers, not re-mapped. Example: gpioPin = 17;
dataLength
Pulse length of a single data element (0 or 1) in microseconds. Example: dataLength = 1780;
syncLength
Pulse length of a single sync element (s or S) in microseconds. Example: syncLength = 5000;
sendCommand
Number of times the air command will be transmitted. Example: sendCommand = 10;
sendDelay
Delay between the air command transmissions in microseconds. Example: sendDelay = 10000;
airCode
Encoding type of the air command. This parameter defines the validity and meaning of all airCommand
values. The following radio frame encodings are currently supported. Example: airCode = 0;
_ _ _
0 Manchester; values: 0) |_ 1) _| s) _ S)
_ ___
1 Remote Controlled Outlet; values: 0) |___ 1) |_
(for reference: 00 -> 0, 11 -> 1, 01 -> F)
_ _ _
2 Tormatic: 0) |__ 1) |_|
_ __
3 Melitec: 0) |__ S) |_
airCommand
Sequence of values to be transmitted. The accepted values of this parameter are defined by airCode. Example: airCode = 0; airCommand = "sss010011SSS";
_ __ _ _ ____
___| |__| |_| |__| |_|
sss 0 1 0 0 1 1 SSS
The actual target sections can be named freely, they incorporate all defaults from the 'target' section. All parameters from the 'target' section apply. For example all timing relevant parameters can be defined in the 'target' section while the real target sections only contain the appropriate airCommand
.
aircontrol is able to record radio frames while scanning into a so called air scan dump file. This file can be used later to replay the recorded radio frames, see the following example:
Air scan for 1000ms and dump the results to example.asd
:
# aircontrol -d example.asd -s 1000
Replay the previously recorded air scan dump example.asd
:
# aircontrol -r example.asd