RDM: Manufacturer Specific PIDs
Manufacturer-specific PIDs are used to provide manufacturers with a mechanism to implement RDM commands that are not available in the standard RDM command set. The RDM standard says:
“Manufacturer-specific PIDs shall be created in the range of 0x8000 – 0xFFDF. Uniqueness of PIDs in this range is accomplished by associating the PID with the Manufacturer ID found as the most significant 16-bits of the UID. PIDs in the range of 0xFFE0 – 0xFFFF are reserved for future uses of this standard.”
There are generally two categories of use:
1) To implement additional functionality that will be available to all.
2) To implement manufacturing specific commands that will be closed to all but the manufacturer.
The first option is simple to implement. The manufacturer-specific PIDs are defined and published using PIDs such as Supported_Parameters and Parameter_Description. From then on, it is the controller’s responsibility to ensure that it only sends you valid manufacturer-specific PIDs.
The second option provides more room for error if the designer does not think through all scenarios. It is quite usual for manufacturers to use a manufacturer-specific PID for functions such as ‘programme UID’. Clearly these are intended to be used only in the manufacturing process and chaos would ensue if they were activated in the field.
What can manufacturers do to protect against inadvertent activation of their manufacturer-specific Pids?
1) Not make public the PID in Supported-Parameters. This is sensible, but does not give any real protection. For example, network test software way well send unpublished manufacturer-specific PIDs to see whether the device responds.
2) Ensure that the responder will only accept critical manufacturer-specific PIDs when it is in a ‘special configuration mode’.
3) Include ‘magic-numbers’ in the packet to ensure that manufacturer-specific PIDs sent in error do not have unexpected effects.
4) Ensure that the responder will only accept critical manufacturer-specific PIDs which have a source-UID containing the manufacturer code. This is the strongest protection.
An index of published manufacturer PIDs can be found at: