NAME

Tinkerforge::BrickletRS485 - Communicates with RS485/Modbus devices with full- or half-duplex

CONSTANTS

DEVICE_IDENTIFIER

This constant is used to identify a RS485 Bricklet.

The get_identity() subroutine and the CALLBACK_ENUMERATE callback of the IP Connection have a device_identifier parameter to specify the Brick's or Bricklet's type.

DEVICE_DISPLAY_NAME

This constant represents the display name of a RS485 Bricklet.

CALLBACK_READ_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_READ_LOW_LEVEL callback.

CALLBACK_ERROR_COUNT

This constant is used with the register_callback() subroutine to specify the CALLBACK_ERROR_COUNT callback.

CALLBACK_MODBUS_SLAVE_READ_COILS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_READ_COILS_REQUEST callback.

CALLBACK_MODBUS_MASTER_READ_COILS_RESPONSE_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_COILS_RESPONSE_LOW_LEVEL callback.

CALLBACK_MODBUS_SLAVE_READ_HOLDING_REGISTERS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_READ_HOLDING_REGISTERS_REQUEST callback.

CALLBACK_MODBUS_MASTER_READ_HOLDING_REGISTERS_RESPONSE_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_HOLDING_REGISTERS_RESPONSE_LOW_LEVEL callback.

CALLBACK_MODBUS_SLAVE_WRITE_SINGLE_COIL_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_SINGLE_COIL_REQUEST callback.

CALLBACK_MODBUS_MASTER_WRITE_SINGLE_COIL_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_WRITE_SINGLE_COIL_RESPONSE callback.

CALLBACK_MODBUS_SLAVE_WRITE_SINGLE_REGISTER_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_SINGLE_REGISTER_REQUEST callback.

CALLBACK_MODBUS_MASTER_WRITE_SINGLE_REGISTER_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_WRITE_SINGLE_REGISTER_RESPONSE callback.

CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_COILS_REQUEST_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_COILS_REQUEST_LOW_LEVEL callback.

CALLBACK_MODBUS_MASTER_WRITE_MULTIPLE_COILS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_WRITE_MULTIPLE_COILS_RESPONSE callback.

CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_REGISTERS_REQUEST_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_REGISTERS_REQUEST_LOW_LEVEL callback.

CALLBACK_MODBUS_MASTER_WRITE_MULTIPLE_REGISTERS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_WRITE_MULTIPLE_REGISTERS_RESPONSE callback.

CALLBACK_MODBUS_SLAVE_READ_DISCRETE_INPUTS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_READ_DISCRETE_INPUTS_REQUEST callback.

CALLBACK_MODBUS_MASTER_READ_DISCRETE_INPUTS_RESPONSE_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_DISCRETE_INPUTS_RESPONSE_LOW_LEVEL callback.

CALLBACK_MODBUS_SLAVE_READ_INPUT_REGISTERS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_READ_INPUT_REGISTERS_REQUEST callback.

CALLBACK_MODBUS_MASTER_READ_INPUT_REGISTERS_RESPONSE_LOW_LEVEL

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_INPUT_REGISTERS_RESPONSE_LOW_LEVEL callback.

CALLBACK_READ

This constant is used with the register_callback() subroutine to specify the CALLBACK_READ callback.

CALLBACK_MODBUS_MASTER_READ_COILS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_COILS_RESPONSE callback.

CALLBACK_MODBUS_MASTER_READ_HOLDING_REGISTERS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_HOLDING_REGISTERS_RESPONSE callback.

CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_COILS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_COILS_REQUEST callback.

CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_REGISTERS_REQUEST

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_SLAVE_WRITE_MULTIPLE_REGISTERS_REQUEST callback.

CALLBACK_MODBUS_MASTER_READ_DISCRETE_INPUTS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_DISCRETE_INPUTS_RESPONSE callback.

CALLBACK_MODBUS_MASTER_READ_INPUT_REGISTERS_RESPONSE

This constant is used with the register_callback() subroutine to specify the CALLBACK_MODBUS_MASTER_READ_INPUT_REGISTERS_RESPONSE callback.

FUNCTION_WRITE_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_READ_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_ENABLE_READ_CALLBACK

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_DISABLE_READ_CALLBACK

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_IS_READ_CALLBACK_ENABLED

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_RS485_CONFIGURATION

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_RS485_CONFIGURATION

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_MODBUS_CONFIGURATION

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_MODBUS_CONFIGURATION

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_MODE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_MODE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_COMMUNICATION_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_COMMUNICATION_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_ERROR_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_ERROR_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_BUFFER_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_BUFFER_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_BUFFER_STATUS

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_ENABLE_ERROR_COUNT_CALLBACK

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_DISABLE_ERROR_COUNT_CALLBACK

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_IS_ERROR_COUNT_CALLBACK_ENABLED

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_ERROR_COUNT

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_MODBUS_COMMON_ERROR_COUNT

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_REPORT_EXCEPTION

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_READ_COILS_REQUEST_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_READ_COILS

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_READ_HOLDING_REGISTERS_REQUEST_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_READ_HOLDING_REGISTERS

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_WRITE_SINGLE_COIL_REQUEST

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_WRITE_SINGLE_COIL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_WRITE_SINGLE_REGISTER_REQUEST

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_WRITE_SINGLE_REGISTER

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_WRITE_MULTIPLE_COILS_REQUEST

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_WRITE_MULTIPLE_COILS_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_WRITE_MULTIPLE_REGISTERS_REQUEST

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_WRITE_MULTIPLE_REGISTERS_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_READ_DISCRETE_INPUTS_REQUEST_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_READ_DISCRETE_INPUTS

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_SLAVE_ANSWER_READ_INPUT_REGISTERS_REQUEST_LOW_LEVEL

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_MODBUS_MASTER_READ_INPUT_REGISTERS

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_SPITFP_ERROR_COUNT

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_BOOTLOADER_MODE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_BOOTLOADER_MODE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_WRITE_FIRMWARE_POINTER

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_WRITE_FIRMWARE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_SET_STATUS_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_STATUS_LED_CONFIG

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_CHIP_TEMPERATURE

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_RESET

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_WRITE_UID

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_READ_UID

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTION_GET_IDENTITY

This constant is used with the get_response_expected(), set_response_expected() and set_response_expected_all() subroutines.

FUNCTIONS

new()

Creates an object with the unique device ID *uid* and adds it to the IP Connection *ipcon*.

write_low_level()

Writes characters to the RS485 interface. The characters can be binary data, ASCII or similar is not necessary.

The return value is the number of characters that were written.

See :func:`Set RS485 Configuration` for configuration possibilities regarding baudrate, parity and so on.

read_low_level()

Returns up to *length* characters from receive buffer.

Instead of polling with this function, you can also use callbacks. But note that this function will return available data only when the read callback is disabled. See :func:`Enable Read Callback` and :cb:`Read` callback.

enable_read_callback()

Enables the :cb:`Read` callback.

By default the callback is disabled.

disable_read_callback()

Disables the :cb:`Read` callback.

By default the callback is disabled.

is_read_callback_enabled()

Returns *true* if the :cb:`Read` callback is enabled, *false* otherwise.

set_rs485_configuration()

Sets the configuration for the RS485 communication. Available options:

* Baudrate between 100 and 2000000 baud. * Parity of none, odd or even. * Stopbits can be 1 or 2. * Word length of 5 to 8. * Half- or Full-Duplex.

The default is: 115200 baud, parity none, 1 stop bit, word length 8, half duplex.

get_rs485_configuration()

Returns the configuration as set by :func:`Set RS485 Configuration`.

set_modbus_configuration()

Sets the configuration for the RS485 Modbus communication. Available options:

* Slave Address: Address to be used as the Modbus slave address in Modbus slave mode. Valid Modbus slave address range is 1 to 247. * Master Request Timeout: Specifies how long the master should wait for a response from a slave in milliseconds when in Modbus master mode.

The default is: Slave Address = 1 and Master Request Timeout = 1000 milliseconds (1 second).

get_modbus_configuration()

Returns the configuration as set by :func:`Set Modbus Configuration`.

set_mode()

Sets the mode of the Bricklet in which it operates. Available options are

* RS485, * Modbus Master RTU and * Modbus Slave RTU.

The default is: RS485 mode.

get_mode()

Returns the configuration as set by :func:`Set Mode`.

set_communication_led_config()

Sets the communication LED configuration. By default the LED shows communication traffic, it flickers once for every 10 received data packets.

You can also turn the LED permanently on/off or show a heartbeat.

If the Bricklet is in bootloader mode, the LED is off.

get_communication_led_config()

Returns the configuration as set by :func:`Set Communication LED Config`

set_error_led_config()

Sets the error LED configuration.

By default the error LED turns on if there is any error (see :cb:`Error Count` callback). If you call this function with the SHOW ERROR option again, the LED will turn off until the next error occurs.

You can also turn the LED permanently on/off or show a heartbeat.

If the Bricklet is in bootloader mode, the LED is off.

get_error_led_config()

Returns the configuration as set by :func:`Set Error LED Config`.

set_buffer_config()

Sets the send and receive buffer size in byte. In sum there is 10240 byte (10kb) buffer available and the minimum buffer size is 1024 byte (1kb) for both.

The current buffer content is lost if this function is called.

The send buffer holds data that is given by :func:`Write` and can not be written yet. The receive buffer holds data that is received through RS485 but could not yet be send to the user, either by :func:`Read` or through :cb:`Read` callback.

The default configuration is 5120 byte (5kb) per buffer.

get_buffer_config()

Returns the buffer configuration as set by :func:`Set Buffer Config`.

get_buffer_status()

Returns the currently used bytes for the send and received buffer.

See :func:`Set Buffer Config` for buffer size configuration.

enable_error_count_callback()

Enables the :cb:`Error Count` callback.

By default the callback is disabled.

disable_error_count_callback()

Disables the :cb:`Error Count` callback.

By default the callback is disabled.

is_error_count_callback_enabled()

Returns *true* if the :cb:`Error Count` callback is enabled, *false* otherwise.

get_error_count()

Returns the current number of overrun and parity errors.

get_modbus_common_error_count()

Returns the current number of errors occurred in Modbus mode.

* Timeout Error Count: Number of timeouts occurred. * Checksum Error Count: Number of failures due to Modbus frame CRC16 checksum mismatch. * Frame Too Big Error Count: Number of times frames were rejected because they exceeded maximum Modbus frame size which is 256 bytes. * Illegal Function Error Count: Number of errors when an unimplemented or illegal function is requested. This corresponds to Modbus exception code 1. * Illegal Data Address Error Count: Number of errors due to invalid data address. This corresponds to Modbus exception code 2. * Illegal Data Value Error Count: Number of errors due to invalid data value. This corresponds to Modbus exception code 3. * Slave Device Failure Error Count: Number of errors occurred on the slave device which were unrecoverable. This corresponds to Modbus exception code 4.

modbus_slave_report_exception()

In Modbus slave mode this function can be used to report a Modbus exception for a Modbus master request.

* Request ID: Request ID of the request received by the slave. * Exception Code: Modbus exception code to report to the Modbus master.

modbus_slave_answer_read_coils_request_low_level()

In Modbus slave mode this function can be used to answer a master request to read coils.

* Request ID: Request ID of the corresponding request that is being answered. * Coils: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Coils Request` callback with the Request ID as provided by the argument of the callback.

modbus_master_read_coils()

In Modbus master mode this function can be used to read coils from a slave. This function creates a Modbus function code 1 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the read. * Count: Number of coils to read.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Read Coils Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_read_holding_registers_request_low_level()

In Modbus slave mode this function can be used to answer a master request to read holding registers.

* Request ID: Request ID of the corresponding request that is being answered. * Holding Registers: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Holding Registers Request` callback with the Request ID as provided by the argument of the callback.

modbus_master_read_holding_registers()

In Modbus master mode this function can be used to read holding registers from a slave. This function creates a Modbus function code 3 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the read. * Count: Number of holding registers to read.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Read Holding Registers Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_write_single_coil_request()

In Modbus slave mode this function can be used to answer a master request to write a single coil.

* Request ID: Request ID of the corresponding request that is being answered.

This function must be called from the :cb:`Modbus Slave Write Single Coil Request` callback with the Request ID as provided by the arguments of the callback.

modbus_master_write_single_coil()

In Modbus master mode this function can be used to write a single coil of a slave. This function creates a Modbus function code 5 request.

* Slave Address: Address of the target Modbus slave. * Coil Address: Address of the coil. * Coil Value: Value to be written.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Single Coil Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_write_single_register_request()

In Modbus slave mode this function can be used to answer a master request to write a single register.

* Request ID: Request ID of the corresponding request that is being answered.

This function must be called from the :cb:`Modbus Slave Write Single Register Request` callback with the Request ID, Register Address and Register Value as provided by the arguments of the callback.

modbus_master_write_single_register()

In Modbus master mode this function can be used to write a single register of a slave. This function creates a Modbus function code 6 request.

* Slave Address: Address of the target Modbus slave. * Register Address: Address of the register. * Register Value: Value to be written.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Single Register Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_write_multiple_coils_request()

In Modbus slave mode this function can be used to answer a master request to write multiple coils.

* Request ID: Request ID of the corresponding request that is being answered.

This function must be called from the :cb:`Modbus Slave Write Multiple Coils Request` callback with the Request ID of the callback.

modbus_master_write_multiple_coils_low_level()

In Modbus master mode this function can be used to write multiple coils of a slave. This function creates a Modbus function code 15 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the write.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Multiple Coils Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_write_multiple_registers_request()

In Modbus slave mode this function can be used to answer a master request to write multiple registers.

* Request ID: Request ID of the corresponding request that is being answered.

This function must be called from the :cb:`Modbus Slave Write Multiple Registers Request` callback with the Request ID of the callback.

modbus_master_write_multiple_registers_low_level()

In Modbus master mode this function can be used to write multiple registers of a slave. This function creates a Modbus function code 16 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting Address of the write.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Multiple Registers Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_read_discrete_inputs_request_low_level()

In Modbus slave mode this function can be used to answer a master request to read discrete inputs.

* Request ID: Request ID of the corresponding request that is being answered. * Discrete Inputs: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Discrete Inputs Request` callback with the Request ID as provided by the argument of the callback.

modbus_master_read_discrete_inputs()

In Modbus master mode this function can be used to read discrete inputs from a slave. This function creates a Modbus function code 2 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the read. * Count: Number of discrete inputs to read.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Read Discrete Inputs Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_read_input_registers_request_low_level()

In Modbus slave mode this function can be used to answer a master request to read input registers.

* Request ID: Request ID of the corresponding request that is being answered. * Input Registers: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Input Registers Request` callback with the Request ID as provided by the argument of the callback.

modbus_master_read_input_registers()

In Modbus master mode this function can be used to read input registers from a slave. This function creates a Modbus function code 4 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the read. * Count: Number of input registers to read.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Read Input Registers Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

get_spitfp_error_count()

Returns the error count for the communication between Brick and Bricklet.

The errors are divided into

* ack checksum errors, * message checksum errors, * frameing errors and * overflow errors.

The errors counts are for errors that occur on the Bricklet side. All Bricks have a similar function that returns the errors on the Brick side.

set_bootloader_mode()

Sets the bootloader mode and returns the status after the requested mode change was instigated.

You can change from bootloader mode to firmware mode and vice versa. A change from bootloader mode to firmware mode will only take place if the entry function, device identifier und crc are present and correct.

This function is used by Brick Viewer during flashing. It should not be necessary to call it in a normal user program.

get_bootloader_mode()

Returns the current bootloader mode, see :func:`Set Bootloader Mode`.

set_write_firmware_pointer()

Sets the firmware pointer for func:`WriteFirmware`. The pointer has to be increased by chunks of size 64. The data is written to flash every 4 chunks (which equals to one page of size 256).

This function is used by Brick Viewer during flashing. It should not be necessary to call it in a normal user program.

write_firmware()

Writes 64 Bytes of firmware at the position as written by :func:`Set Write Firmware Pointer` before. The firmware is written to flash every 4 chunks.

You can only write firmware in bootloader mode.

This function is used by Brick Viewer during flashing. It should not be necessary to call it in a normal user program.

set_status_led_config()

Sets the status LED configuration. By default the LED shows communication traffic between Brick and Bricklet, it flickers once for every 10 received data packets.

You can also turn the LED permanently on/off or show a heartbeat.

If the Bricklet is in bootloader mode, the LED is will show heartbeat by default.

get_status_led_config()

Returns the configuration as set by :func:`Set Status LED Config`

get_chip_temperature()

Returns the temperature in °C as measured inside the microcontroller. The value returned is not the ambient temperature!

The temperature is only proportional to the real temperature and it has bad accuracy. Practically it is only useful as an indicator for temperature changes.

reset()

Calling this function will reset the Bricklet. All configurations will be lost.

After a reset you have to create new device objects, calling functions on the existing ones will result in undefined behavior!

write_uid()

Writes a new UID into flash. If you want to set a new UID you have to decode the Base58 encoded UID string into an integer first.

We recommend that you use Brick Viewer to change the UID.

read_uid()

Returns the current UID as an integer. Encode as Base58 to get the usual string version.

get_identity()

Returns the UID, the UID where the Bricklet is connected to, the position, the hardware and firmware version as well as the device identifier.

The position can be 'a', 'b', 'c' or 'd'.

The device identifier numbers can be found :ref:`here <device_identifier>`. |device_identifier_constant|

write()

Writes characters to the RS485 interface. The characters can be binary data, ASCII or similar is not necessary.

The return value is the number of characters that were written.

See :func:`Set RS485 Configuration` for configuration possibilities regarding baudrate, parity and so on.

read()

Returns up to *length* characters from receive buffer.

Instead of polling with this function, you can also use callbacks. But note that this function will return available data only when the read callback is disabled. See :func:`Enable Read Callback` and :cb:`Read` callback.

modbus_slave_answer_read_coils_request()

In Modbus slave mode this function can be used to answer a master request to read coils.

* Request ID: Request ID of the corresponding request that is being answered. * Coils: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Coils Request` callback with the Request ID as provided by the argument of the callback.

modbus_slave_answer_read_holding_registers_request()

In Modbus slave mode this function can be used to answer a master request to read holding registers.

* Request ID: Request ID of the corresponding request that is being answered. * Holding Registers: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Holding Registers Request` callback with the Request ID as provided by the argument of the callback.

modbus_master_write_multiple_coils()

In Modbus master mode this function can be used to write multiple coils of a slave. This function creates a Modbus function code 15 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting address of the write.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Multiple Coils Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_master_write_multiple_registers()

In Modbus master mode this function can be used to write multiple registers of a slave. This function creates a Modbus function code 16 request.

* Slave Address: Address of the target Modbus slave. * Starting Address: Starting Address of the write.

Upon success the function will return a non-zero request ID which will represent the current request initiated by the Modbus master. In case of failure the returned request ID will be 0.

When successful this function will also invoke the :cb:`Modbus Master Write Multiple Registers Response` callback. In this callback the Request ID provided by the callback argument must be matched with the Request ID returned from this function to verify that the callback is indeed for a particular request.

modbus_slave_answer_read_discrete_inputs_request()

In Modbus slave mode this function can be used to answer a master request to read discrete inputs.

* Request ID: Request ID of the corresponding request that is being answered. * Discrete Inputs: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Discrete Inputs Request` callback with the Request ID as provided by the argument of the callback.

modbus_slave_answer_read_input_registers_request()

In Modbus slave mode this function can be used to answer a master request to read input registers.

* Request ID: Request ID of the corresponding request that is being answered. * Input Registers: Data that is to be sent to the Modbus master for the corresponding request.

This function must be called from the :cb:`Modbus Slave Read Input Registers Request` callback with the Request ID as provided by the argument of the callback.