| CANopen Slave Documentation Version 7.00.02 | 
The file cos_conf.h holds all definitions for the configuration of the CANopen FD Slave protocol stack. Please set the symbols to an appropriate value in order to achieve a specific CANopen FD Slave behaviour.
| #define COS_BOOTLOADER_SUPPORT 0 | 
Support of CANopen bootloader.
With this symbol the CANopen bootloader support according to CiA 710 can be enabled.
| #define COS_BUS_EMCY 1 | 
Emergency messages on bus errors.
With this symbol it is possible to enable the transmission of emergency messages upon bus errors. The functionality is handled inside the CosMgrCanErrorHandler() function.
| #define COS_DICT_ACCESS_MODIFICATION 0 | 
Allow local change of data elements attribute.
This symbol defines if local modification of the CosDicEntry_ts::ubAttribute member is supported. A value of 0 (default) means the access modification is not supported, the value 1 enables the local access modification.
| #define COS_DICT_MAN 0 | 
Include manufacturer objects.
This symbol defines if manufacturer specific objects are included in the dictionary. A value of 0 means the manufacturer objects are not included. A value of 1 means they are included.
| #define COS_DICT_OBJ_1003 4 | 
Implementation of index 1003h.
This symbol defines the maximum number of errors that can be stored by the device. Please note that the errors are kept in RAM and require 4 byte for each entry. A value of 0 means that this object is not supported. The maximum size of the list is 254.
| #define COS_DICT_OBJ_1005 1 | 
Implementation of index 1005h.
This symbol defines if the object 1005h (SYNC identifier) is supported by the device.
| #define COS_DICT_OBJ_1006 1 | 
Implementation of index 1006h.
This symbol defines if the object 1006h (communication cycle period) is supported by the device. If the object is supported, the device can also be used as SYNC producer.
| #define COS_DICT_OBJ_1008 1 | 
Implementation of index 1008h.
This symbol defines if the object 1008h (Manufacturer device name) is supported by the device.
| #define COS_DICT_OBJ_1009 1 | 
Implementation of index 1009h.
This symbol defines if the object 1009h (Manufacturer hardware version) is supported by the device.
| #define COS_DICT_OBJ_100A 1 | 
Implementation of index 100Ah.
This symbol defines if the object 100Ah (Manufacturer software version) is supported by the device.
| #define COS_DICT_OBJ_100C 0 | 
Implementation of index 100Ch and 100Dh.
Every CANopen slave must support the Heartbeat protocol. It is optional possible to use Node Guarding. It is recommended not to support Node Guarding for new implementations because of its technical drawbacks.
| #define COS_DICT_OBJ_1010 0 | 
Store Parameters.
The symbol defines if the object 1010h is supported and how many sub-indices are used. A value of 0 means the object is not supported, i.e. the device can not store parameters. A value greater 0 denotes the highest supported sub-index. The value must be in the range from 0 to 4.
| #define COS_DICT_OBJ_1011 0 | 
Restore Parameters.
The symbol defines if the object 1011h is supported and how many sub-indices are used. A value of 0 means the object is not supported, i.e. the device can not restore parameters. A value greater 0 denotes the highest supported sub-index. The value must be in the range from 0 to 4.
| #define COS_DICT_OBJ_1012 0 | 
COB-ID time stamp object.
The symbol defines if the object 1012h is supported. A value of 0 means the object is not supported, i.e. the device has no Real-Time-Clock (RTC). A value of 1 denotes the device supports the TIME object.
| #define COS_DICT_OBJ_1013 0 | 
High resolution time stamp.
This object shall indicate the configured high resolution time stamp. It may be mapped into a PDO in order to exchange a high resolution time stamp message. Further application specific use is encouraged. The value of index 1013h is given in multiples of 1 microsecond.
| #define COS_DICT_OBJ_1014 1 | 
Emergency message.
The symbol defines if the object 1014h is supported and how many emergency messages can be queued.
| #define COS_DICT_OBJ_1015 0 | 
Emergency inhibit time.
This symbol defines if the object 1015 is supported by the device.
| #define COS_DICT_OBJ_1016 2 | 
Consumer heartbeat.
The symbol defines if the object 1016h is supported and how many sub-indices are used. A value of 0 means the object is not supported, i.e. the device has no consumer heartbeat. A value greater 0 denotes the highest supported sub-index. The maximum number of entries is limited to 4.
| #define COS_DICT_OBJ_1019 0 | 
Implementation of index 1019h.
This symbol defines if the object 1019h (SYNC counter) is supported by the device.
| #define COS_DICT_OBJ_1020 0 | 
Verify Configuration.
The symbol defines if the object 1020h is supported. If this object is supported, the device must be capable to store configuration data, i.e. object 1010 must also be supported.
| #define COS_DICT_OBJ_1021 0 | 
Support EDS store.
The symbol defines if the objects 1021h (EDS store) and 1022h (Store format) are supported. The storage format of the EDS may be compliant to ISO10646 (not compressed) or any manufacturer- specific format.
| #define COS_DICT_OBJ_1029 1 | 
Error behaviour object.
The symbol defines if the object 1029h is supported. A value greater 0 denotes the highest supported sub-index. The maximum number of entries is limited to 4.
| #define COS_DICT_OBJ_1F80 1 | 
NMT Startup.
The symbol defines if the object 1F80h is supported.
The backwards compatibility mode allows additional (obsolete) values for setting the startup behaviour. For new CANopen devices, use the value '1' for support of index 1F80h.
| #define COS_DICT_SEARCH_FAST 1 | 
Use fast search algorithm.
This symbol defines if a fast search algorithm is used for the dictionary. The fast search algorithm increases the code size. A value of 0 means a linear search method is used. A value of 1 means the fast search algorithm is used.
| #define COS_DS302_NV 0 | 
Support CiA 302 Network Variables.
This symbol defines if objects from CiA 302 are included in the dictionary.
| #define COS_DS401_AI 0 | 
Support CiA 401, analog inputs.
This symbol defines if objects for analog inputs from the device profile for I/O modules (CiA 401) are included in the dictionary.
The add-on CANopen Device Profile CiA 401 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS401_AO 0 | 
Support CiA 401, analog outputs.
This symbol defines if objects for analog outputs from the device profile for I/O modules (CiA 401) are included in the dictionary.
The add-on CANopen Device Profile CiA 401 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS401_DI 0 | 
Support CiA 401, digital inputs.
This symbol defines if objects for digital inputs from the device profile for I/O modules (CiA 401) are included in the dictionary.
The add-on CANopen Device Profile CiA 401 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS401_DO 0 | 
Support CiA 401, digital outputs.
This symbol defines if objects for digital outputs from the device profile for I/O modules (CiA 401) are included in the dictionary.
The add-on CANopen Device Profile CiA 401 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS402 0 | 
Support CiA 402.
This symbol defines if objects for drives device profile (CiA 402) are included in the dictionary.
The add-on CANopen Device Profile CiA 402 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS404_AI 0 | 
Support CiA 404, analog inputs.
This symbol defines if objects for analog inputs from the device profile for Sensors and Closed-loop Control (CiA 404) are included in the dictionary.
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS404_AI_FILTER 1 | 
Support filter within CiA 404, analog inputs.
This symbol defines if objects (index 61A0h and 61A1h) for filtering analog inputs from the device profile for sensors and closed-loop control (CiA 404) are included in the dictionary.
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS404_AI_SCALING 1 | 
Support filter within CiA 404, analog inputs.
This symbol defines if objects (index 6126h and 6127h) for scaling of analog inputs from the device profile for sensors and closed-loop control (CiA 404) are included in the dictionary.
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS404_AO 0 | 
Support CiA 404, analog outputs.
This symbol defines if objects for analog outputs from the device profile for sensors and closed-loop control (CiA 404) are included in the dictionary.
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS404_DT_FLOAT 0 | 
CiA 404 data type.
This symbol defines if the data type float is supported for the device profile for sensors and closed-loop Control (CiA 404). 
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
float | #define COS_DS404_DT_INT16 1 | 
CiA 404 data type.
This symbol defines if the data type int16_t is supported for the device profile for sensors and closed-loop Control (CiA 404). 
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
int16_t | #define COS_DS404_DT_INT32 0 | 
CiA 404 data type.
This symbol defines if the data type int32_t is supported for the device profile for sensors and closed-loop control (CiA 404). 
The add-on CANopen Device Profile CiA 404 must be installed to support this option (refer to CANopen Slave Add-on modules).
int32_t | #define COS_DS406 0 | 
Support CiA 406.
This symbol defines if objects for the device profile CiA 406 (Encoder) are included in the dictionary.
The add-on CANopen Device Profile CiA 406 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS410 0 | 
Support CiA 410.
This symbol defines if objects for the device profile CiA 410 (Inclinometer) are included in the dictionary.
The add-on CANopen Device Profile CiA 410 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS417 0 | 
Support CiA 417.
This symbol defines if objects for the application profile CiA 417 (Lift) are included in the dictionary.
The add-on CANopen Application Profile CiA 417 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS418 0 | 
Support CiA 418.
This symbol defines if objects for the device profile CiA 418 (battery modules) are included in the dictionary.
The add-on CANopen Device Profile CiA 418 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS437_AI 0 | 
Support CiA 437, analog input module.
This symbol defines if the virtual device analog input module is included in the dictionary.
The add-on CANopen Application Profile CiA 437 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS437_AO 0 | 
Support CiA 437, analog output module.
This symbol defines if the virtual device analog output module is included in the dictionary.
The add-on CANopen Application Profile CiA 437 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS437_DI 0 | 
Support CiA 437, digital input module.
This symbol defines if the virtual device digital input module is included in the dictionary.
The add-on CANopen Application Profile CiA 437 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS437_DO 0 | 
Support CiA 437, digital output module.
This symbol defines if the virtual device digital output module is included in the dictionary.
The add-on CANopen Application Profile CiA 437 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_DS437_TS 0 | 
Support CiA 437, temperature sensor.
This symbol defines if the virtual device temperature sensor is included in the dictionary.
The add-on CANopen Application Profile CiA 437 must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_FD_SUPPORT 0 | 
Support CANopen FD.
This symbol defines if the protocol stack supports CANopen FD functionality defined by the CiA 1301 specification. Support for CANopen FD also requires a CAN FD capable hardware, hence the symbol CP_CAN_FD provided by the CANpie driver must be set to 1.
Possible values for this symbol are:
If CANopen FD support is configured during compile time, it has to be enabled during run-time as depicted in the following example.
| #define COS_J1939_SUPPORT 0 | 
Support of J1939 protocol stack integration.
With this symbol the integration of the J1939 protocol stack can be enabled.
| #define COS_LED_SUPPORT 0 | 
Support of LEDs.
With this symbol the LED support can be enabled. There are two bi-color LEDs supported:
The Network LED denotes the state of the CANopen status machine (Operational, Stopped, Bus-Off, etc.). The optional Module LED denotes the physical state of the device (running, hardware failure, etc).
| #define COS_LOGICAL_PROFILE 1 | 
Number of logical device profiles.
This symbol defines the number of logical device profiles. The value must be in the range from 1 to 8.
| #define COS_LSS_SUPPORT 0 | 
Implementation of Layer Setting Services and Protocol.
LSS offers the possibility to inquire and change the settings of certain parameters of the local layers on a CANopen module with LSS Slave capabilities. This switch is used to enable/disable the LSS capability. If enabled, the file cos_lss.c must be included to the project.
| #define COS_MGR_INT 1 | 
Run CAN message handler in Poll/IRQ mode.
With this symbol it is possible to switch the CAN message handler (message reception) between Polling- and IRQ-mode. In Polling mode the messages are read from the buffer during the main loop. The default mode is the IRQ-mode: received CAN messages are processed inside the CAN IRQ-handler.
| #define COS_NMT_MASTER 0 | 
CANopen Slave device can also be NMT master.
This option provides NMT master functionality for the device.
The add-on Mini-Master must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_NRL_SUPPORT 0 | 
Support of Network Redundancy Layer.
With this symbol the Network Redundancy Layer (NRL) support can be enabled.
| #define COS_PDO_INHIBIT 0 | 
Support Inhibit time for transmit PDOs.
This symbol defines if an inhibit time is supported for transmit PDOs.
| #define COS_PDO_MAPPING 8 | 
Implementation of PDO mapping.
This symbol defines how the PDO mapping is implemented. The fixed PDO mapping consumes less memory space and computation time. The variable PDO mapping offers the most flexibility for the PDO service.
For Classical CANopen applications, the maximum allowed value of 8 is sufficient to map up to 8 bytes into a PDO. For CANopen FD applications the maximum value is 64.
| #define COS_PDO_RCV_ID_CONST 0 | 
Receive PDO identifier is constant.
Depending on the device profile or application it may be required that the identifier of the receive PDO is constant. This symbol defines if index 140xh, sub 1 is read-only:
| #define COS_PDO_RCV_NUMBER 4 | 
Number of Receive PDOs.
This symbol defines the number of receive PDOs supported by the CANopen slave. The number may vary between 0 (no receive PDO) and 32.
Please note that the maximum number of PDOs is limited by the number of mailboxes provided by the CANpie driver (i.e. the CAN silicon). A compiler error will be thrown if the number of receive PDOs exceeds the number of available mailboxes for this service.
| #define COS_PDO_SYNC_START 0 | 
Support SYNC start value for transmit PDOs.
This symbol defines if a SYNC start value is supported for transmit PDOs.
| #define COS_PDO_TRM_ID_CONST 0 | 
Transmit PDO identifier is constant.
Depending on the device profile or application it may be required that the identifier of the transmit PDO is constant. This symbol defines if index 180xh, sub 1 is read-only:
| #define COS_PDO_TRM_NUMBER 4 | 
Number of Transmit PDOs.
This symbol defines the number of transmit PDOs supported by the CANopen slave. The number may vary between 0 (no transmit PDO) and 32.
Please note that the maximum number of PDOs is limited by the number of mailboxes provided by the CANpie driver (i.e. the CAN silicon). A compiler error will be thrown if the number of transmit PDOs exceeds the number of available mailboxes for this service.
| #define COS_SDO_BLOCK 0 | 
SDO Block Transfer.
The symbol defines if the SDO Block transfer is supported. A value of 0 denotes that SDO Block transfer is not supported. A value greater 0 denotes the maximum number of blocks that can be transferred between master and slave. The maximum value is 127 blocks.
| #define COS_SDO_CLIENT 0 | 
SDO client functionality.
The symbol defines if SDO client functionality is supported. A value of 0 denotes that SDO client functionality is not supported.
The add-on Mini-Master must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_SDO_SEGMENTED 1 | 
Segmented SDO Transfer.
The symbol defines if the segmented SDO transfer is supported. If segmented SDOs are not supported, the code size can be reduced. However, segmented SDOs are required if the data type STRING must be supported with string length greater than 4.
| #define COS_SECURE_CONFIG_SUPPORT 0 | 
Support of Secure Configuration.
With this symbol the support of the Secure Configuration add-on can be ++ enabled.
| #define COS_SRDO_NUMBER 0 | 
Number of SRDOs.
This symbol defines the number of SRDOs used by the CANopen slave. The number may vary between 0 (no SRDOs) and 8.
The add-on Safety must be installed to support this option (refer to CANopen Slave Add-on modules).
| #define COS_TIMER_PERIOD 1000 | 
Period of timer interrupt.
This symbol defines the period of the timer interrupt. The value is a multiple of 1 microsecond. It is used for timing services. Please set this value to the timer interrupt period of the target system.
Please note that the value must be at least 1000 [microseconds], because all CANopen services use a multiple of 1 millisecond.
| #define COS_TMR_INT 1 | 
Run timer events in Poll/IRQ mode.
With this symbol it is possible to switch the timer function (CosTmrEvent) between Polling- and IRQ-mode. In Polling mode the timer value is checked within the main loop. The default mode is the IRQ-mode: the function CosTmrEvent() is called within the timer interrupt.
| #define COS_USDO_NUMBER 0 | 
Number of parallel USDO requests.
This symbol defines the number of parallel USDO requests that can be handled by the protocol stack. If the number is exceeded the USDO server aborts further requests by means of the USDO abort service.