From ef58dc769524a5079b6979b4fa1887655123ce36 Mon Sep 17 00:00:00 2001 From: Florian Pose <fp@igh-essen.com> Date: Fri, 20 Oct 2006 13:03:01 +0000 Subject: [PATCH] Always begin with subindex 0 while fetching SDO dictionary. --- master/fsm.c | 32 ++------------------------------ 1 file changed, 2 insertions(+), 30 deletions(-) diff --git a/master/fsm.c b/master/fsm.c index 3126915c..54242426 100644 --- a/master/fsm.c +++ b/master/fsm.c @@ -2506,7 +2506,6 @@ void ec_fsm_coe_dict_desc_check(ec_fsm_t *fsm /**< finite state machine */) void ec_fsm_coe_dict_desc_response(ec_fsm_t *fsm /**< finite state machine */) { - ec_master_t *master = fsm->master; ec_datagram_t *datagram = &fsm->datagram; ec_slave_t *slave = fsm->slave; ec_sdo_t *sdo = fsm->coe_sdo; @@ -2582,36 +2581,9 @@ void ec_fsm_coe_dict_desc_response(ec_fsm_t *fsm /**< finite state machine */) return; } - if (!sdo->subindices) { // no entries - // another SDO description to fetch? - if (fsm->coe_sdo->list.next != &slave->sdo_dictionary) { - fsm->coe_sdo = list_entry(fsm->coe_sdo->list.next, ec_sdo_t, list); - - if (!(data = ec_slave_mbox_prepare_send(slave, datagram, 0x03, 8))) { - fsm->coe_state = ec_fsm_error; - return; - } - - EC_WRITE_U16(data, 0x8 << 12); // SDO information - EC_WRITE_U8 (data + 2, 0x03); // Get object description request - EC_WRITE_U8 (data + 3, 0x00); - EC_WRITE_U16(data + 4, 0x0000); - EC_WRITE_U16(data + 6, fsm->coe_sdo->index); // SDO index - - ec_master_queue_datagram(fsm->master, datagram); - fsm->coe_state = ec_fsm_coe_dict_desc_request; - return; - } - - if (master->debug_level) { - EC_DBG("Finished fetching SDO descriptions.\n"); - } - - fsm->coe_state = ec_fsm_end; - return; - } + // start fetching entries - fsm->coe_subindex = 1; + fsm->coe_subindex = 0; if (!(data = ec_slave_mbox_prepare_send(slave, datagram, 0x03, 10))) { fsm->coe_state = ec_fsm_error; -- GitLab