hil_watchdog_clear End of trail navigation bar

hil_watchdog_stop

Stops the watchdog timer.

Description

The hil_watchdog_stop function stops the watchdog timer. The watchdog timer will no longer expire so the hil_watchdog_reload function need no longer be called. Stopping the watchdog timer does not clear the watchdog state if the watchdog has already expired. Use the hil_watchdog_clear function for this purpose.

Prototype

t_error hil_watchdog_stop(t_card card);
    

Parameters

t_card card

A handle to the board, as returned by hil_open .

Return value

The return value is 0 if the watchdog stopped successfully. Otherwise a negative error code is returned. Error codes are defined in quanser_errors.h A suitable error message may be retrieved using msg_get_error_message .

Error codes

QERR_HIL_WATCHDOG_STOP

This function is not supported by the board-specific HIL driver for this board type.

QERR_INVALID_CARD_HANDLE

An invalid card handle was passed as an argument. Once a card has been closed using hil_close the card handle is invalid.

Requirements

Include Files

Libraries

hil.h

hil.lib;quanser_runtime.lib;quanser_common.lib

Examples


/*
Configure a watchdog timer that will expire every 0.1 seconds and reset the
analog outputs to 0V and the digital outputs to tristate upon expiration.
Also create a task for performing real-time control that reads
four encoder channels every millisecond. The watchdog is reloaded every sampling
instant.
*/

t_double frequency          = 1000;                        /* 1 kHz (0.001 seconds) */
t_uint32 samples            = 5000;                        /* Iterate for 5000 samples (5 seconds) */
t_uint32 samples_in_buffer  = frequency;
t_uint32 samples_to_read    = 1;                           /* Read one sample (four channels) every sampling instant */
t_double timeout            = 100 / frequency;             /* 100 sampling instants (0.1 seconds) */
t_uint32 encoder_channels[] = { 0, 1, 2, 3 };
t_uint32 analog_channels[]  = { 0, 1, 2, 3 };
t_double voltages[]         = { 0, 0, 0, 0 };
t_uint32 digital_channels[16];
t_uint32 states[16];
t_int32 counts[4];
t_error result;
t_task task;

int index;

for (index=0; index < ARRAY_LENGTH(digital_channels); index++) {
    digital_channels[index] = index;
    states[index] = DIGITAL_STATE_TRISTATE;
}

hil_watchdog_set_analog_expiration_state(card, analog_channels, ARRAY_LENGTH(analog_channels), voltages);
hil_watchdog_set_digital_expiration_state(card, digital_channels, ARRAY_LENGTH(digital_channels), states);

hil_task_create_encoder_reader(board, samples_in_buffer, channels, ARRAY_LENGTH(channels), &task);

hil_watchdog_start(card, timeout);
hil_task_start(task, SYSTEM_CLOCK_1, frequency, samples);
for (int index = 0; index < samples; index++) {
    hil_task_read_encoder(task, samples_to_read, counts); /* returns every millisecond with next sample */
    hil_watchdog_reload(card);                            /* reload watchdog before using counts for control */
    ...                                                   /* do control calculations and output motor torques */
}
hil_task_stop(task);
hil_task_delete(task);
hil_watchdog_stop(card);
    

 

navigation bar