Skip to content

Understanding the RF signal used in the Honeywell RCWL300A, RCWL330A, Series 3, 5, 9 and Decor Series Wireless Chimes

License

Notifications You must be signed in to change notification settings

klohner/honeywell-wireless-doorbell

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Honeywell "ActivLink" Wireless Devices

What is this?

This ia an attempt to capture and decode the signals used by the Honeywell ActivLink family of devices. These devices are primarily wireless doorbell and PIR motion detector systems in North America and and operate at 916.5 MHz. Honeywell also uses this signal at 916.5 in Australia. In European countries, it operates at 868.3 MHz and the family of devices also include door/window sensors and home alarm kits.

There's some indication that this protocol may be based on the Friedland / Response 868MHz alarm system. This page indicates that the 868MHz variants of the Honeywell ActivLink system is compatible with the Friedland Libra+ Wirefree Doorbell system.

These devices are dissimilar to many other simple wireless doorbell systems in several ways. They operate on a much higher frequency than most other wireless doorbells, use FSK modulation instead of ASK/OOK, and the signal protocol supports multiple device types, signal flags, relay signals, battery low indication, and a parity check.

I'm using rtl_433 to receive and demodulate the signal using its default functionality. As of 2018-12-06, it supports this protocol.

I'm also able to transmit valid signals to these Honeywell receivers using the YARD Stick One, which uses the TI CC1111 chipset.

I've also had success transmitting a valid signal using the HopeRF RFM69HCW module, specifically as found as part of the Adafruit Feather 32u4 RFM69HCW Packet Radio device.

Planned further efforts include working with modules that use the TI CC1101 chip, and maybe other modules that are able to support this signal.

How can I help?

If you're able to run rtl_433, and have access to one of these devices, I'd like to know which device you have and what 48-bit value you receive from your device.

Using a recent build of rtl_433, here's what you can use to get that value.

North American and Australian devices:

rtl_433 -f 916800000 -q -R 0 -X n=Honeywell_ActivLink,m=FSK_PWM,s=160,l=320,r=400,y=480,invert,bits=48

European devices (including Friedland Response and Libra+ devices):

rtl_433 -f 868300000 -q -R 0 -X n=Honeywell_ActivLink,m=FSK_PWM,s=160,l=320,r=400,y=480,invert,bits=48

Submit My Doorbell Code To This Project

Any kind of signal you can provide helps. I'm especially interested in signals from the motion detectors and door/window sensors or other sensors used with this system.

Hardware inside the Honeywell doorbell transmitter

User tos7 has detailed on an rtl-sdr.com forum that the button contains a PIC Micro controller and a FSK Transmitter chip.

The Wireless Signal

The Honeywell wireless transmitter I have direct access to is the RPWL400W, though I was able to look at several of them. I also have tested with a Series 9 and Series 3 receiver.

When the wireless doorbell button is pressed, it sends out a signal centered at 916.8 MHz. It seems to be using 2FSK modulation with a 50 kHz deviation. The modulation rate seems to be 6250 baud, so each HIGH or LOW symbol is 160 microseconds (μs).

Because it is using digital symbols over 2FSK modulation, it essentially looks like two separate, simultaneous, out-of-phase OOK transmissions 100 kHz away from each other, at 916.85 MHz and and 916.75 MHz. In FSK parlance, these higher and lower frequencies are respectively referred to as the "mark" and "space" frequencies.

Data bits are encoded over three symbols. A "0" bit is defined as HIGH-LOW-LOW, and a "1" bit is defined as "HIGH-HIGH-LOW".

Each frame of data consists of a LOW-LOW-LOW signal preamble, 48 bits (144 symbols) of data, and a postamble of HIGH-HIGH-HIGH.

The signal seems to be 50 consecutive repetitions of the frame, then symbols LOW-LOW-LOW-HIGH-HIGH-HIGH, and finally 2 continuous milliseconds (2000 μs) of LOW.

So, the duration of the entire 2FSK signal is

(50 reps * ((1 + 48 + 1 bits) * (3 symbols * 160 μs))) + (6 symbols * 160 μs) + 2000 μs
=
(2500 * 480 μs) + 960 μs + 2000 μs
=
1200000 μs + 2960 μs
=
1.202960 seconds

The Data Frame

Each data frame is 48 bits, or 6 bytes long. With some experimentation (using a YARD Stick One to create custom signals), here's what I've been able to ascertain about the data in the frame.

# Frame bits used in Honeywell RCWL300A, RCWL330A, Series 3, 5, 9 and all Decor Series Wireless Chimes
# 0000 0000 1111 1111 2222 2222 3333 3333 4444 4444 5555 5555
# 7654 3210 7654 3210 7654 3210 7654 3210 7654 3210 7654 3210
# XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX XX.. XXX. .... KEY DATA (any change and receiver doesn't seem to recognize signal)
# XXXX XXXX XXXX XXXX XXXX .... .... .... .... .... .... .... KEY ID (different for each transmitter)
# .... .... .... .... .... 0000 00.. 0000 0000 00.. 000. .... KEY UNKNOWN 0 (always 0 in devices I've tested)
# .... .... .... .... .... .... ..XX .... .... .... .... .... DEVICE TYPE (10 = doorbell, 01 = PIR Motion sensor)
# .... .... .... .... .... .... .... .... .... ..XX ...X XXX. FLAG DATA (may be modified for possible effects on receiver)
# .... .... .... .... .... .... .... .... .... ..XX .... .... ALERT (00 = normal, 01 or 10 = right-left halo light pattern, 11 = full volume alarm)
# .... .... .... .... .... .... .... .... .... .... ...X .... SECRET KNOCK (0 = default, 1 if doorbell is pressed 3x rapidly)
# .... .... .... .... .... .... .... .... .... .... .... X... RELAY (1 if signal is a retransmission of a received transmission, only some models)
# .... .... .... .... .... .... .... .... .... .... .... .X.. FLAG UNKNOWN (0 = default, but 1 is accepted and I don't observe any effects)
# .... .... .... .... .... .... .... .... .... .... .... ..X. LOWBAT (1 if battery is low, receiver gives low battery alert)
# .... .... .... .... .... .... .... .... .... .... .... ...X PARITY (LSB of count of set bits in previous 47 bits)

Data Frame Device ID Notes:

For simplicity, the full Device ID for the device might just be the first 4 bytes. Device Type should be included as part of the Device ID since if it is changed, a receiver would no longer recognize the signal as being from the same device. Bits after byte 4 that seem to be part of the Key ID are always 0 on all devices I've seen.

Data Frame KEY UNKNOWN 0 Notes:

These bits are 0 in all devices I've seen. Some preliminary tests with generating artificial signals seems to indicate that if these bits are not 0, the receiver does not seem to recognize the signal as a previously recognized device. So, these bits are either part of the device ID, or they simply must be 0 for the receiver to accept the signal as valid. Further testing here is required.

Data Frame DEVICE TYPE Notes:

For all devices I've tested, it seems that only the two bits specified for this field change depending on the type of device used to generate the signal. It seems logical that perhaps the the width of this field is more than two bits. It might even be all of the 4th byte. I have no data to confirm this, though. For all devices I've seen, though, only these two bits of the 4th byte might be anything other than 0.

Data Frame ALERT Notes:

On some receivers, such as the Honeywell RDWL917AX, an alert type of 01 or 10 forces the receiver to display a blinking right and left pattern, instead of the normal full perimeter LED blinking.

Data Frame RELAY Notes:

On some receiver models, such as the "Honeywell RDWL917AX", the base receiver will immediately retransmit a valid received signal if the RELAY bit is NOT set. The data in the retransmitted signal will be modified with the RELAY bit set. This seems to be an effort to extend a signal to more distant receivers.

Detecting signals using rtl_433

This seems to work pretty well to pick up the signal frame data as hex in multiple rows:

rtl_433 -f 916800000 -q -R 0 -X n=Honeywell_ActivLink,m=FSK_PWM,s=160,l=320,r=400,y=480,invert,bits=48

The "invert" option is specified here to provide a decoding consistent with this document.

Change the reset value to 560 to get all data in one row:

rtl_433 -f 916800000 -q -R 0 -X n=Honeywell_ActivLink,m=FSK_PWM,s=160,l=320,r=560,y=480,invert,bits=48

Note that these don't seem to pick up the all the data frames. In my tests, it only seems to pick up 24 of the 50 data frames in the signal before triggering pulse_FSK_detect(): Maximum number of pulses reached! and ignoring the rest of the signal.

It seems to be possible to also pick up the signal as OOK in rtl_433 by setting the frequency about 90 kHz away from the center of the FSK frequency. This seems to force rtl_433 to only notice one side of the 2FSK signal. This command seems to work well to pick up the data frames. It also has the benefit that when the maximum number of pulses is reached, it doesn't trigger an error and starts decoding data again immediately.

rtl_433 -f 916890000 -q -R 0 -X n=Honeywell_ActivLink,m=OOK_PWM,s=160,l=320,g=400,r=560,y=480,bits=48,invert

rtl_433 -f 916710000 -q -R 0 -X n=Honeywell_ActivLink,m=OOK_PWM,s=160,l=320,g=400,r=560,y=480,bits=48

Transmitting a signal using a YARD Stick One

Convert the signal you want to send as a hex value representing the symbols in the signal where a 1 bit is a HIGH symbol and a 0 bit is a LOW symbol.

import sys
from rflib import *

def init(device):
	device.setFreq(916800000)
	device.setMdmModulation(MOD_2FSK)
	device.setMdmDeviatn(50000)
	device.setMdmSyncMode(0)
	device.setMdmDRate(6250)
	device.setMaxPower()

r = RfCat()
init(r)
r.RFxmit(data=pwm_signal_bytes)

Devices using this signal

Here's an incomplete list of devices and kits known or suspected to use this signal.

North American Honeywell models

  • RCA902N1004/N Wireless Motion Detector
  • RDWL311A 3 Series Portable Wireless Doorbell & Push Button
  • RDWL313A 3 Series Portable Wireless Doorbell with Strobe Light & Push Button
  • RDWL313P 3 Series Plug-In Wireless Doorbell with Strobe Light & Push Button
  • RDWL515A2000/E 5 Series Portable Wireless Doorbell with Halo Light & Push Button
  • RDWL515P 5 Series Plug-In Wireless Doorbell with Halo Light & Push Button
  • RDWL515A2000/E Portable Wireless Doorbell with Halo Light and Push Button 2 Pack
  • RDWL917AX2000/E Series 9 Portable Wireless Doorbell / Door Chime & Push Button
  • RCWL251A1005 Décor Door Chime & Push Button
  • RPWL300A Decor Wireless Push Button
  • RPWL302A1005/A Decor Wireless Surface Mount Push Button for Door Chime
  • RPWL4045A Wired to Wireless Doorbell Adapter Converter for Series 3, 5, 9 Honeywell Door Bells
  • RPWL401B Wireless Doorbell Push Button for Series 3, 5, 9 Honeywell Door Bells (Black)
  • RPWL401B2000/A Wireless Surface Mount Push Button
  • RPWL400W Wireless Doorbell Push Button for Series 3, 5, 9 Honeywell Door Bells (White)
  • RPWL400W2000/A Series 3, 5, 9 Wireless Doorbell Push Button with Halo Light
  • RPWL4045A2000 Wired to Wireless Doorbell Adapter for Series 3, 5, 9
  • RCWL330A1000/N P4-Premium Portable Wireless Doorbell / Door Chime and Push Button
  • RCWL35 Series, includes RCWL35N, RCWL3501A, RCWL3502A, RCWL3503A, RCWL3504A, RCWL3505A, RCWL3506A
  • RCWL3501A1004/N Decor Wireless Door Chime
  • RCWL3502A1002/N Decor Wireless Door Chime
  • RCWL3503A1000/N Decor Wireless Door Chime
  • RCWL3504A1008/N Decor Wireless Door Chime
  • RCWL3505A1005/N Decor Customizable Wood Wireless Doorbell / Door Chime and Push Button
  • RCWL3506A1003/N Decor Wireless Door Chime

Australian Honeywell models (916.8 MHz)

  • DC917NGA Wireless portable MP3 doorbell with range extender, customisable melodies and push button – Grey
  • DC515NA Wireless portable doorbell with halo light, sleep mode and push button – White
  • DC515NGA Wireless portable doorbell with halo light, sleep mode and push button – Grey
  • DC515NP2A Wireless plug-in doorbell with sleep mode, nightlight and push button – White
  • DC515NGP2A Wireless plug-in doorbell with sleep mode, nightlight and push button – Grey
  • DC313NA Wireless portable doorbell with volume control and push button – White
  • DC313NGA Wireless portable doorbell with volume control and push button – Grey
  • DCP311GA Wireless push button with LED confidence light – Portrait, Grey
  • DCP511A Wireless push button with nameplate and LED confidence light – Offset Landscape, White
  • DCP511GA Wireless push button with nameplate and LED confidence light – Offset Landscape, Grey

European Honeywell models

  • DW915SG Wired and wireless doorbell with range extender, sleep mode and halo light – Grey
  • DW915S Wired and wireless doorbell with range extender, sleep mode and halo light – White
  • DC917SL Wireless portable doorbell with range extender, customisable melodies and push button – White
  • DC917SG Wireless portable doorbell with range extender, customisable melodies and push button – Grey
  • DC917NG Wireless portable doorbell with range extender, customisable melodies and push button – Grey
  • DC915SG Wireless portable doorbell with range extender, sleep mode and push button – Grey
  • DC915SEA Wireless portable doorbell with range extender, wireless motion sensor and push button – White
  • DC915SCV Wireless portable doorbell with range extender, sleep mode and wired to wireless converter – White
  • DC915S Wireless portable doorbell with range extender, sleep mode and push button – White
  • DC915NG Wireless portable doorbell with range extender, sleep mode and push button – Grey
  • DC915N Wireless portable doorbell with range extender, sleep mode and push button – White
  • DC515S Wireless portable doorbell with halo light, sleep mode and push button – White
  • DC515NGBS Wireless plug-in doorbell with sleep mode, nightlight and push button – Grey
  • DC515NG Wireless portable doorbell with halo light and push button – Grey
  • DC515NBS Wireless plug-in doorbell with sleep mode, nightlight and push button – White
  • DC515N Wireless portable doorbell with halo light, sleep mode and push button – White
  • DC315NG Wireless portable doorbell with halo light and push button – Grey
  • DC315NBS Wireless plug-in doorbell with halo light, USB charging and push button – White
  • DC315N Wireless portable doorbell with halo light and push button – White
  • DC313SFB Wireless portable doorbell with volume control and two push buttons – White
  • DC313NHGBS Wireless portable and plug-in doorbell with volume control and push button – White
  • DC313NG Wireless portable doorbell with volume control and push button – Grey
  • DC313NFB Wireless portable doorbell with volume control and two push buttons – White
  • DC313NBS Wireless plug-in doorbell with volume control and push button – White
  • DC313N Wireless portable doorbell with volume control and push button – White
  • DC312SP2USB Wireless plug-in doorbell with push button – White
  • DC311NBS Wireless plug-in doorbell with push button – White
  • DC311N Wireless portable doorbell with push button – White
  • DCP311 Wireless push button with LED confidence light – Portrait, White
  • DCP311G Wireless push button with LED confidence light – Portrait, Grey
  • DCP511 Wireless push button with nameplate and LED confidence light – Offset Landscape, White
  • DCP711 Wireless push button with LED confidence light – Round, White
  • DCP711G Wireless push button with LED confidence light – Round, Grey
  • DCP917S Doorbell wired to wireless converter kit – White
  • HS3MAG1N Wireless door and window sensor – White
  • HS3MAG1S Wireless door and window sensor – White
  • HS3MAG2S Wireless door and window sensor twin pack – White
  • HS3SS1S Wireless solar siren
  • HS3PIR2S Wireless motion sensor (PIR) twin pack
  • HS3PIR1S Wireless motion sensor (PIR)
  • HS3FOB1S Wireless remote control key fob
  • HS3BS1S Wireless battery siren
  • L430S Wireless Motion Sensor (IP54) – White

European Friedland models:

  • Friedland Response SL2 Premium Wireless Multi User Alarm System
  • Friedland Response SL9 Premium Wireless Keypad Alarm System
  • Friedland Response SL3 Premium Wireless Multi Function and Zoning Alarm System
  • Friedland Response SL10 Wireless Apartment Alarm Kit
  • Friedland Response SL8 Premium Wireless Expanded Zoning Alarm System
  • Friedland Response SL5 Premium Wireless Telecommunicating Alarm System
  • Friedland Response SL7 Premium Wireless Auto Dial Alarm System
  • Friedland Response HW2 Premium Wireless Movement (PIR) Detector
  • Friedland Response HW12 Premium Wireless External Lighting Controller
  • Friedland Response HW22 Premium Wireless Movement (PIR) Detector Twin Pack
  • Friedland Response HW3 Premium Wireless Remote Control
  • Friedland Response HW4 Premium Wireless Door/Window Contact
  • Friedland Response HW44 Premium Wireless Door/Window Contact Twin pack
  • Friedland Response HW5 Premium Wireless Mounted Keypad
  • GlobalGuard Friedland Response HIS77A Wirefree Door/Window Contact (Twin Pack)
  • GlobalGuard Friedland Response HIS8A Wirefree PIR Movement Detector
  • GlobalGuard Friedland Response HIS88A Wireless Movement Detector (PIR) Twin Pack
  • GlobalGuard Friedland Response HIS9A Wireless Remote Control
  • GlobalGuard Friedland Response HIS10A Garage Door Sensor
  • GlobalGuard Friedland Response HIS2A Lampholders Twin Pack
  • GlobalGuard Friedland Response HIS1A Plug-in Socket
  • GlobalGuard Friedland Response HISK1 Wireless Home Alarm System
  • GlobalGuard Friedland Response FGGA0401WWE Solar Siren
  • Friedland Libra+ D911S Wireless Chime and Button
  • Friedland Libra+ D912S Wireless Chime and Button
  • Friedland Libra+ D914b Portable Door Chime Kit, with Brass Fronted Push
  • Friedland Libra+ D917 Additional Portable Chime
  • Friedland Libra+ D930 Wirefree White Bell Push
  • Friedland Libra+ D931 Wirefree Black/Silver Bell Push
  • Friedland Libra+ D934 Wirefree Converter Bell Push
  • Friedland Libra+ D936 Telephone Ringer
  • Friedland Libra+ L430N Libra PIR

References

  • User tos7 performed some earlier valuable analysis of this hardware and signal as detailed on an rtl-sdr.com forum post.

  • rtl_433 is an incredible and essential piece of software. I still have much of it to learn.

  • The YARD Stick One is also an incredible thing. Transmitting arbitrary digital signals to test out signal changes is essential to this project. This made it easy.

  • rfcat is also essential to effectively tap into the abilities of the YARD Stick One.

About

Understanding the RF signal used in the Honeywell RCWL300A, RCWL330A, Series 3, 5, 9 and Decor Series Wireless Chimes

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages