This is an old revision of the document!
This document is an overall view of the CFLink Protocol, used by CommandFusion hardware.
CFLink is a RS485 5-wire bus, used to interconnect various CommandFusion devices. For more details on the physical bus characteristics, please see the CFLink Bus documentation.
Throughout the CFLink Protocol documentation, hex bytes will be displayed in square brackets, with uppercase hex characters inside.
For example, a carriage return is represented as [0D].
The basic structure of all messages on the CFLink bus is as follows:
// Basic message format > [F2]<ID>[F3]<COMMAND>[F4]<DATA>[F5][F5]
All messages start with [F2] followed by a single ID byte representing the target (or source in the case of replies) device on the bus.
Then an [F3] byte, followed by 7 bytes representing the Command.
Then an [F4] byte, followed by optional Data associated with the command. The Data can be empty if the command does not require any associated data.
Finally, all messages are terminated with two [F5] bytes.
NOTE: THROUGHOUT THIS DOCUMENTATION, ALL CFLINK EXAMPLES WILL START WITH > OR < - THIS IS NOT PART OF THE COMMAND, BUT JUST USED TO SIGNIFY THE START OF A NEW SENT OR RECEIVED PACKET.
Every device on the CFLink bus must have a unique ID. The valid ID range is [02] to [EF] (238 total per CFLink bus).
When sending a command, you must specify the ID of the device to send the command to.
In some circumstances, you may want to send a broadcast to all devices on the network. This can be done by using the Broadcast ID: [FF].
NOTE: BROADCAST MESSAGES CANNOT BE GUARANTEED TO BE DELIVERED TO ALL DEVICES ON LARGE NETWORKS. BROADCASTING IS ONLY RECOMMENDED FOR NON-CRITICAL MESSAGES.
The <COMMAND> part of each message is always 7 characters, always upper case, and formatted as follows: <TYPE><DEVICE><COMMAND_NAME>
CFX can be used to target any device. It is useful for when you are sending a command that any device should respond to, WHO for example.
Query messages begin with <TYPE> character Q. These messages are used to retrieve the configuration details or state of a specific device property.
A query will always get a reply, unless the target device could not be found (CFLink ID does not exist on the bus).
If the query was successful, the reply would contain the same <COMMAND_NAME> along with the <DATA> associated with the query.
If there was an error in the query, the reply would be an Error Reply with details of why the error occurred.
Configuration messages begin with <TYPE> character C. These messages are used to manipulate the configuration settings of a device.
A configuration message will always get a reply, unless the target device could not be found (CFLink ID does not exist on the bus).
There are two situations that reflect what data will be replied:
If the configuration change requires a reboot (ie. changing the DHCP mode for a LANBridge), the reply to the configuration message will contain the current configuration data.
The new configuration data will only be available after rebooting the device.
If the configuration change is instant (ie. changing the CFLink ID of a device), the reply will contain the new configuration data.
If the was an error in the configuration message, the reply would be an Error Reply with details of why the error occurred.
Transmission messages begin with <TYPE> character T. These messages are used to tell the device to perform an action, such as set a relay state or send data out a serial port.
A transmission message will always get a reply, unless the target device could not be found (CFLink ID does not exist on the bus).
Most replies will simply echo the <COMMAND_NAME> along with any <DATA> from the transmission message.
But some replies will not include the <DATA> in order to reduce flooding of the network. These replies are from commands such as sending RS232 data or sending IR hex data, both of which can be quite long.
If the was an error in the transmission message, the reply would be an Error Reply with details of why the error occurred.
Reply messages begin with <TYPE> character R. Replies are always initiated by the device, in response to any of the other command types.
Generally the reply will contain the <DEVICE> name for the device sending the reply, along with echoing the <COMMAND_NAME>.
The only time a reply will not be sent is if the target CFLink ID does not exist on the CFLink bus.
More details on the reply formatting is given in the other message type documentation above.
If there is an error in any message, the device will reply with details via an error message in the following format:
// Error reply format example < [F2]<ID>[F3]R<DEVICE>ERR[F4]<ERRCODE>:<SUMMARY>:<SENDERID>:<SENT_CMD>:<SENT_DATA>[F5][F5]
Throughout the protocol, the <DATA> section of the message format is used to supply additional details to the commands and replies.
When the protocol requires a port number to be defined, it is always written in P## format. The number must be two chars, 01-99 or ZZ.
P01 = Port 1, P10 = Port 10, etc.
PZZ = All Ports. This allows you to manipulate all ports of a single type at once. eg. Open all relays in a CFMini.
When the protocol requires a module number to be defined, it is always written in M# format. The number is always 1 char, 1-9 or Z.
M1 = Module 1, M4 = Module 4, etc.
MZ = All Modules. This allows you to manipulate all modules in a modular device at once. eg. Open all relays in a DIN-MOD4.
If you want to leave a parameter unchanged, and only change some of the options in a single protocol message, simply define the parameters that you want to change as normal, and for the ones you want to leave unchanged, use the uppercase X character in their place.
This X (no change) is only valid for parameters that use a fixed length, and must be repeated for each required length byte.
So if a parameter requires 2 bytes length, and you want to leave it unchanged, enter XX as the parameter value.
Throughout the documentation, any messages that accept X (no change) parameters will be listed in the commands 'Data' section.
There are 3 data separators used in the CFLink protocol:
| (single pipe): (colon), (comma)
When a command or reply targets multiple ports of a device, the port data is separated by a single pipe | character.
The port separator is also used to separate a Module Number from the port data.
// Port Separator example - Close relay port 1, open relay port 2 on a CF Mini on CFLink ID [04] > [F2][04][F3]TRLYSET[F4]P01:1|P02:0[F5][F5] // Port Separator example, with module number - Close relay port 1, open relay port 2 on Module 2 of a MOD4 on CFLink ID [04]> [F2][04][F3]TRLYSET[F4]M2|P01:1|P02:0[F5][F5]
The data separator, : (colon), is used to separate piece of data for a single target port or device.
// Data Separator example - Device discovery reply for a LANBridge on ID [02] < [F2][02][F3]RLANWHO[F4]LANBridge:192.168.0.100:00.04.A3.19.D5.70:1.0.0.0:1.0.0.0[F5][F5] // Note: model, IP address, MAC address, boot loader version and firmware version data are all separated by colons.
When a command targets a modular device, it is possible to target multiple modules in one message. This is done by using the module separator, , (comma)
// Module Separator example - Module 1, Close relay ports 1 and 2, Module 2, Open relay ports 1 and 2 // Within a MOD4 on CFLink ID [04] > [F2][04][F3]TRLYSET[F4]M1|P01:1|P02:1,M2|P01:0|P02:0[F5][F5] // Note the comma after the module 1 data, before the module 2 data.