piVCCU is a project to install the original Homematic CCU2 firmware inside a virtualized container (lxc) on ARM based single board computers.
- Option to run CCU2 and other software parallel on one device
- Usage of original CCU2 firmware (and not OCCU)
- As compatible as possible with original CCU2
- Full Homematic and Homematic IP support on all supported platforms (if RF hardware supports it)
- Support for backup/restore between piVCCU and original CCU2 without modification
- Easy to install and update with apt
- Support not only on Raspberry
- Support for HM-MOD-RPI-PCB (HmRF+HmIP), HmIP-RFUSB (HmIP only) and HM-LGW-O-TW-W-EU (HmRF only)
Keeping this project running is very expensive, e.g. I have to buy a lot of different test devices. If you like to support this project, please consider sending me a donation via PayPal. Or you can send me a gift from my Amazon wishlist.
- Debian or Ubuntu based distribution
- armhf or arm64 architecture (x64 is not supported at the moment)
- At least kernel 4.4
- Supported Single Board Computer
-
Raspberry Pi 2 or 3 running Raspbian Jessie or Stretch
-
Asus Tinkerboard running Armbian with Mainline kernel
-
Banana Pi M1 running Armbian with Mainline kernel (Experimental)
-
Odroid C2 running Armbian with Mainline kernel (Experimental)
-
Orange Pi Zero, One, 2, Lite, Plus, Plus 2, Plus 2E, PC, PC Plus, R1 running Armbian with Mainline kernel
⚠️ WARNING: Some models of the Orange Pi have a rotated GPIO socket. Please ensure the correct position of Pin 1!
-
- Properly installed HM-MOD-RPI-PCB
You can find pre-prepared sd card images here. The images are configured to use the HM-MOD-RPI-PCB. If you like to use an other radio mode, please see below how to switch it. They are identical to the original distribution lite or server images but have piVCCU already installed like it is described below. Login to Raspbian based images using user 'pi' and password 'raspberry'. Login to Armbian based images using user 'root' and password '1234'.
- Raspberry Pi
- Armbian
- Other OS (Experimental)
Use the normal apt based update mechanism:
sudo apt update && sudo apt upgrade
- HM-MOD-RPI-PCB
- HmRF and HmIP is supported
- Works only on Raspbian and Armbian and only on supported hardware platforms
- HmIP-RFUSB (Experimental)
- Only HmIP is supported. You can add support for HmRF using a external HM-LGW-O-TW-W-EU
- Fake emulation (Experimental)
- Software emulation of the HM-MOD-RPI-PCB
- You can add support for (real) HmRF using a external HM-LGW-O-TW-W-EU
- To switch between radio modes use the following command:
sudo dpkg-reconfigure pivccu
Starting with version 2.31.25-23 there is the tool pivccu-backup to create CCU2 compatible backups (inside the host). Be aware, that this is only a backup of the CCU, no settings of the host are saved.
To restore a backup file use the WebUI of the CCU.
-
Original CCU2
Just restore a normal system backup using the CCU web interface
-
RaspberryMatic
- Restore a normal system backup using the CCU web interface
- Reinstall all addons using the CCU web interface
- If you previously used YAHM, please follow the instructions for removing YAHM specific configuration stuff below
-
YAHM
- Create full backup of your SD card
- Create system backup using CCU web interface
- Remove YAHM on the host (or use a plain new sd card image)
sudo lxc-stop -n yahm sudo rm -f /etc/bash_completion.d/yahm_completion sudo rm -f /etc/init.d/hm-mod-rpi-pcb sudo rm -rf /opt/YAHM sudo rm -rf /var/lib/lxc/yahm sudo sed -i /boot/config.txt -e '/dtoverlay=pi3-miniuart-bt/d' sudo sed -i /boot/config.txt -e '/dtoverlay=pi3-miniuart-bt-overlay/d' sudo sed -i /boot/config.txt -e '/enable_uart=1/d' sudo sed -i /boot/config.txt -e '/force_turbo=1/d' sudo sed -i /etc/modules -e '/#*eq3_char_loop/d' sudo sed -i /etc/modules -e '/#*bcm2835_raw_uart/d'
- Install piVCCU as described above
- Restore the system backup using the CCU web interface
- Remove YAHM specific configuration stuff (this needs to done, even if you used a new sd card image and after every restore of a YAHM backup)
sudo systemctl stop pivccu.service sudo rm -f /var/lib/piVCCU/userfs/etc/config/no-coprocessor-update sudo sed -i /var/lib/piVCCU/userfs/etc/config/rfd.conf -e 's/Improved Coprocessor Initialization = false/Improved Coprocessor Initialization = true/' if [ `grep -c '^Improved Coprocessor Initialization' /var/lib/piVCCU/userfs/etc/config/rfd.conf` -eq 0 ]; then sudo sed -i /var/lib/piVCCU/userfs/etc/config/rfd.conf -e 's/\(^Replacemap File.*\)/\1\nImproved Coprocessor Initialization = true\n/'; fi if [ `grep -c '\^[Interface 0\]' /var/lib/piVCCU/userfs/etc/config/rfd.conf` -eq 0 ]; then sudo bash -c "echo -e \"\n[Interface 0]\nType = CCU2\nComPortFile = /dev/mmd_bidcos\n#AccessFile = /dev/null\n#ResetFile = /dev/ccu2-ic200\" >> /var/lib/piVCCU/userfs/etc/config/rfd.conf"; fi sudo sed -i /var/lib/piVCCU/userfs/etc/config/multimacd.conf -e 's/bcm2835-raw-uart/mxs_auart_raw.0/' if [ `grep -c '<name>HmIP-RF</name>' /var/lib/piVCCU/userfs/etc/config/InterfacesList.xml` -eq 0 ]; then sudo bash -c "sed -i /var/lib/piVCCU/userfs/etc/config/InterfacesList.xml -e 's/\(<\/interfaces>\)/\t<ipc>\n\t\t<name>HmIP-RF<\/name>\n\t\t<url>xmlrpc:\/\/127.0.0.1:2010<\/url>\n\t\t<info>HmIP-RF<\/info>\n\t<\/ipc>\n\1/'"; fi sudo systemctl start pivccu.service
- If you used YAHM without HmIP (and only then), remove the HmIP keys to avoid migrating duplicate keys (this needs to done, even if you used a new sd card image and after every restore of a YAHM backup)
sudo systemctl stop pivccu.service sudo rm -rf /var/lib/piVCCU/userfs/etc/config/crRFD/data/* sudo systemctl start pivccu.service
- If you used YAHM without radio module, you should check your interface assignments of the LAN Gateways in the control panel
- You can find available devices on the host using
sudo pivccu-device listavailable
- Create a hook script on the host
bash -c 'echo "#!/bin/bash" > /etc/piVCCU/post-start.sh' sudo chmod +x /etc/piVCCU/post-start.sh
- For each device add an entry to this hook file, e.g. here for
/dev/ttyUSB0
bash -c 'echo "pivccu-device add /dev/ttyUSB0" >> /etc/piVCCU/post-start.sh'
- The devices will now be available inside the container, just use them like it is described in the CUxD documentation
If you like to build the .deb package by yourself
- Use Ubuntu 16.04 as build system
- Install prequisites tbd
- Clone source
- create_*.sh are the scripts to build the deb packages
- Deploy the .deb files to an apt repository e.g. using reprepro
piVCCU itself – the source files found in this git repository – are licensed under the conditions of the Apache License 2.0. The kernel module source files (folder kernel) and the generated kernel .deb files (raspberrypi-kernel-pivccu) licensed under the GPLv2 license instead. The generated CCU container .deb files (pivccu) are containing the original CCU2 firmware, containing multiple different licenses. Please refer to eQ-3 for more information.