Skip to content

Latest commit

 

History

History
305 lines (199 loc) · 13.2 KB

vscp_level_ii_specifics.md

File metadata and controls

305 lines (199 loc) · 13.2 KB

VSCP Level II Specifics

Also check VSCP over TCP/IP which have more Level II specifics for the lower levels.

Level II nodes are intended for media with higher bandwidth then Level I nodes and no nickname procedure is therefore implemented on Level II. As result of this the full GUID is sent in each packet.

Level II events

The header for a level II event is defined as

typedef struct {
        uint16_t crc;           /* crc checksum (calculated from here to end) */
                                /* Used for UDP/Ethernet etc */

        uint32_t obid;          /* Used by driver for channel info etc. */

        /* Time block - Always UTC time */
        uint16_t year;
        uint8_t month;          /* 1-12 */
        uint8_t day;            /* 1-31 */
        uint8_t hour;           /* 0-23 */
        uint8_t minute;         /* 0-59 */
        uint8_t second;         /* 0-59 */

        uint32_t timestamp;     /* Relative time stamp for package in microseconds */
                                /* ~71 minutes before roll over */

        /* ----- CRC should be calculated from here to end + data block ----  */

        uint16_t head;          /* Bit 15   GUID is IP v.6 address. */
	                            /* Bit 14   This is a dumb node. No MDF, register, nothing. */
                                /* Bit 8-13 = Reserved */
                                /* bit 765  priority, Priority 0-7 where 0 is highest. */
                                /* bit 4 = hard coded, true for a hard coded device. */
                                /* bit 3 = Don't calculate CRC, false for CRC usage. */
                                /*          Just checked when CRC is used.                */
                                /*          If set the CRC should be set to 0xAA55 for    */
                                /*          the event to be accepted without a CRC check. */
                                /* bit 2 = Rolling index. */
                                /* bit 1 = Rolling index. */
                                /* bit 0 = Rolling index. */
        uint16_t vscp_class;    /* VSCP class */
        uint16_t vscp_type;     /* VSCP type */
        uint8_t GUID[ 16 ];     /* Node globally unique id MSB(0) -> LSB(15) */
        uint16_t sizeData;      /* Number of valid data bytes */

        uint8_t *pdata;         /* Pointer to data. Max 512 bytes */

    } vscpEvent;

The biggest differences is that the GUID is sent in each event and that both class and type has a 16-bit length.

The CRC is calculated using the CCITT polynomial

The format in a stream is

VSCP LEVEL II UDP datagram offsets

#define VSCP_MULTICAST_PACKET0_POS_PKTTYPE              0

#define VSCP_MULTICAST_PACKET0_POS_HEAD                 1
#define VSCP_MULTICAST_PACKET0_POS_HEAD_MSB             1

#define VSCP_MULTICAST_PACKET0_POS_HEAD_LSB             2
#define VSCP_MULTICAST_PACKET0_POS_TIMESTAMP            3

#define VSCP_MULTICAST_PACKET0_POS_YEAR                 7
#define VSCP_MULTICAST_PACKET0_POS_YEAR_MSB             7

#define VSCP_MULTICAST_PACKET0_POS_YEAR_LSB             8
#define VSCP_MULTICAST_PACKET0_POS_MONTH                9

#define VSCP_MULTICAST_PACKET0_POS_DAY                  10
#define VSCP_MULTICAST_PACKET0_POS_HOUR                 11

#define VSCP_MULTICAST_PACKET0_POS_MINUTE               12
#define VSCP_MULTICAST_PACKET0_POS_SECOND               13

#define VSCP_MULTICAST_PACKET0_POS_VSCP_CLASS           14
#define VSCP_MULTICAST_PACKET0_POS_VSCP_CLASS_MSB       14

#define VSCP_MULTICAST_PACKET0_POS_VSCP_CLASS_LSB       15
#define VSCP_MULTICAST_PACKET0_POS_VSCP_TYPE            16

#define VSCP_MULTICAST_PACKET0_POS_VSCP_TYPE_MSB        16
#define VSCP_MULTICAST_PACKET0_POS_VSCP_TYPE_LSB        17

#define VSCP_MULTICAST_PACKET0_POS_VSCP_GUID            18
#define VSCP_MULTICAST_PACKET0_POS_VSCP_SIZE            34

#define VSCP_MULTICAST_PACKET0_POS_VSCP_SIZE_MSB        34
#define VSCP_MULTICAST_PACKET0_POS_VSCP_SIZE_LSB        35

#define VSCP_MULTICAST_PACKET0_POS_VSCP_DATA            36

As is noted the obid and time-stamp is not present in the actual stream and is only inserted by the driver interface software.

Level I events can travel in the Level II world. This is because all Level I events are repleted in Class=1024. As nicknames are not available on Level II they are replaced in the events by the full GUID. This is an important possibility in larger installations.

A event from a node on a Level I that is transferred out on a Level II can have the nodes own GUID set or the GUID of the interface between the Level I and the Level II segment. Which method to choose is up to the implementer as long as the GUID's are unique.

For interfaces the machine MAC address, if available, is a good base for a GUID which easily can map to real physical nodes that are handled by the interface. By using this method each MAC address gives 65536 unique GUID's.

Other methods to generate GUID's s also available form more information see Appendix A.

String Representation

In some cases it is useful to have a compact string representation of the an Event. This is for instance used in the VSCP tcp/ip link protocol. The format is

head,class,type,obid,datetime,timestamp,GUID,data1,data2,data3....

date time is in ISO 8601 format (_"YYYY-MM-DDTHH:MM:SS[.ssss[Z]]":).

obid, datetime, and timestamp can be left out. In this case a comma is used instead. If datetime is left out the first intelligent interface the event passes will set the datetime of the event to the current UTC time. If timestamp is left out the first interface the event passes will set the timestamp of the event to the current time in microseconds.

The GUID can either be the full GUID on the form

25:00:00:00:00:00:00:00:00:00:00:00:0D:02:00:01

or a dash

-

or empty. If it is a dash or is empty the GUID of the interface is set for the event.

All numbers except the numbers of the GUID (always in hex without a preciding '0x', can either be decimal or hexadecimal. Hexadecimal numbers should be preceded by '0x'.

XML Representation

VSCP level II events can be presented as XML data. Format is

<?xml version = "1.0" encoding = "UTF-8" ?>
<!-- Version 0.0.2 2020-02-20 -->
<event 
    vscpHead="flags for event"
    vscpClass="Event class is numerical form or CLASSx:numerical form"
    vscpType="Event type in numerical form."
    vscpGuid="ff:ee:dd:cc:bb:aa:99:88:77:66:55:44:33:22:11:00"
    vscpTimeStamp="Relative microsecond value."
    vscpDateTime="2018-03-03T12:01:40Z"
    vscpData="
    Comma separated list with event data. Hex values (preceded with '0x')and decimal values allowed."
    unit="Code for unit data is presented in"
    sensorindex="Index for sensor"
    coding="How value is codes"
    value="Measurement value"
    note="Some note about this event"
/>

unit, sensorindex, coding and value is extra information used by event decoding logic. note is used by analytic software like VSCP Works__

If vscpTimeStamp and or vscpDateTime is absent they should be treated as 'now'.

vscpTimeStamp is a sender relative value expressed in microseconds that can be used for more precise timing calculations

vscpDateTime is date + time in UTC on ISO format

JSON Representation

VSCP level II events can be presented as JSON data. Format is

{   
    "vscpHead":0,
    "vscpObId":0,
    "vscpClass":10,
    "vscpType":6,
    "vscpGuid":"ff:ee:dd:cc:bb:aa:99:88:77:66:55:44:33:22:11:00",
    "vscpTimeStamp":1234567,
    "vscpDateTime":"2018-03-03T12:01:40Z",
    "vscpData":[1,2,3,4],
    "vscpNote":"Some optional note about event",
    "measurement": {
        "value":1.2345
        "unit":0,
        "sensorindex":0,
        "zone":0,
        "subzone":0
    }
}

vscpNote is used by analytic software like VSCP Works for log files and other diagnostic event logs stored on disks or similar.

unit, sensorindex,coding and value are optional for measurements event conversions.

unit, sensorindex, coding and value is extra information used by event decoding logic. note is used by analytic software__

If vscpTimeStamp and or vscpDateTime is absent each should be treated as 'now'.

vscpTimeStamp is a sender relative value expressed in microseconds that can be used for more precise timing calculations.

vscpDateTime is date + time in UTC on ISO format.

The measurement block is optional. It can be inserted by software for measurements but should not be expected to be available.

If a tag is not present it should be interpreted as zero with the exception for vscpTimeStamp and vscpDateTime described above.

Higher level software may use

vscpClassToken:"VSCP_CLASS1_MEASUREMENT",
vscpTypeToken:"VSCP_TYPE_MEASUREMENT_ELECTRIC_CURRENT",

or similar for more user friendly class/type information. They should be give in addition to the numerical form, not instead of.

Defaults for absent fields

If bandwidth is constrained field can be omitted. If fileds are omitted the following is true

  • vscpHead will default to zero.
  • vscpObId will default to zero.
  • vscpGuid will default to all zero. This can typically be omitted if the topic on a MQTT channel holds the GUID.
  • vscpTimeStamp will defaults to the current microsecond timestamp on the client.
  • vscpDateTime will default to 'today' and 'now' on the client.
  • vscpClass and or vscpType willdefault to zero. This can typically be omitted if the topic on a MQTT channel holds one or both of them.
  • vscpData is empty if omitted.
  • vscpNote will default to an empty string

As an example imagine that you have a device that you want to monitor for on/off. The VSCP event are

The data for each event contains

  • index
  • zone
  • subzone

If you now construct a topic on the form

.../'GUID'/'class'/'type'/'index'/'zone'/'subzone'

or typically

vscp/25:00:00:00:00:00:00:00:00:00:00:00:06:01:00:01/20/+/1/2/3/#

you can easily construct the full event on the client side even if you only send minimal data.

Globally Unique Identifiers

To classify as a node in a VSCP net all nodes must be uniquely identified by a globally unique 16-byte (yes that is 16-byte (128 bits) not 16-bit) identifier. This number uniquely identifies all devices around the world and can be used as a means to obtain device descriptions as well as drivers for a specific platform and for a specific device.

The manufacturer of the device can also use the number as a serial number to track manufactured devices. In many other environments and protocols there is a high cost in getting a globally unique number for your equipment. This is not the case with VSCP. If you own an Ethernet card you also have what is needed to create your own GUID's.

The GUID address is not normally used during communication with a node. Instead an 8-bit address is used. This gives a low protocol overhead. A segment can have a maximum of 127 nodes even if the address gives the possibility for 256 nodes. The 8-bit address is received from a master node called the segment controller. The short address is also called the nodes nickname-ID or nickname address.

Besides the GUID it is recommended that all nodes should have a node description string in the firmware that points to a URL that can give full information about the node and its family of devices. As well as providing information about the node, this address can point at drivers for various operating systems or segment controller environments. Reserved GUID's

Some GUID's are reserved and unavailable for assignment. Appendix A list these and also assigned IDs.

The VSCP team controls the rest of the addresses and will allocate addresses to individuals or companies by them sending a request to [email protected]. You can request a series of 32-bits making it possible for you to manufacture 4294967295 nodes. If you need more (!!!) you can ask for another series. There is no cost for reserving a series. Appendix A in this document contains a list of assigned addresses which will also be available at https://www.vscp.org

Predefined VSCP GUID's

It is possible to create your own GUID without requesting a series and still have a valid global VSCP GUID. This is because GUID series has been constructed from Ethernet MAC addresses and other common id series. Full list is here.

Assigned VSCP GUID's

Current predefined GUID series is listed in appendix A. You can request your own series by writing [email protected]

Shorthand GUID's

Note that there is a convenient shorthand notation :: used for IPV6 that can be used as a place holder for zeros. For example

::1

really means

00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:01

and

FF:21::22:32

is the same as

FF:21:00:00:00:00:00:00:00:00:00:00:00:00:22:32

we use *: in the same way for FFs so that

*:1 really means

FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:FF:01

These short cut notations makes it much easier to write GUID's.

filename