# HG changeset patch # User Florian Pose # Date 1189603229 0 # Node ID 87abf1166e880e851a382a71d393ae50814c4c5b # Parent ac2a81a33d3d77ec868557db55ee57329fb1a86f Clear station addresses with broadcast before setting them. diff -r ac2a81a33d3d -r 87abf1166e88 master/fsm_master.c --- a/master/fsm_master.c Wed Sep 12 13:12:38 2007 +0000 +++ b/master/fsm_master.c Wed Sep 12 13:20:29 2007 +0000 @@ -56,6 +56,7 @@ void ec_fsm_master_state_validate_product(ec_fsm_master_t *); void ec_fsm_master_state_rewrite_addresses(ec_fsm_master_t *); void ec_fsm_master_state_configure_slave(ec_fsm_master_t *); +void ec_fsm_master_state_clear_addresses(ec_fsm_master_t *); void ec_fsm_master_state_scan_slaves(ec_fsm_master_t *); void ec_fsm_master_state_write_eeprom(ec_fsm_master_t *); void ec_fsm_master_state_sdodict(ec_fsm_master_t *); @@ -280,13 +281,13 @@ list_add_tail(&slave->list, &master->slaves); } - EC_INFO("Scanning bus.\n"); - - // begin scanning of slaves - fsm->slave = list_entry(master->slaves.next, ec_slave_t, list); - fsm->state = ec_fsm_master_state_scan_slaves; - ec_fsm_slave_start_scan(&fsm->fsm_slave, fsm->slave); - ec_fsm_slave_exec(&fsm->fsm_slave); // execute immediately + if (master->debug_level) + EC_DBG("Clearing station addresses...\n"); + + ec_datagram_bwr(datagram, 0x0010, 2); + EC_WRITE_U16(datagram->data, 0x0000); + fsm->retries = EC_FSM_RETRIES; + fsm->state = ec_fsm_master_state_clear_addresses; return; } } @@ -802,6 +803,43 @@ /*****************************************************************************/ /** + * Master state: CLEAR ADDRESSES. + */ + +void ec_fsm_master_state_clear_addresses( + ec_fsm_master_t *fsm /**< master state machine */ + ) +{ + ec_master_t *master = fsm->master; + ec_datagram_t *datagram = fsm->datagram; + + if (datagram->state == EC_DATAGRAM_TIMED_OUT && fsm->retries--) + return; + + if (datagram->state != EC_DATAGRAM_RECEIVED) { + EC_ERR("Failed to receive address clearing datagram (state %i).\n", + datagram->state); + fsm->state = ec_fsm_master_state_error; + return; + } + + if (datagram->working_counter != master->slave_count) { + EC_WARN("Failed to clear all station addresses: Cleared %u of %u", + datagram->working_counter, master->slave_count); + } + + EC_INFO("Scanning bus.\n"); + + // begin scanning of slaves + fsm->slave = list_entry(master->slaves.next, ec_slave_t, list); + fsm->state = ec_fsm_master_state_scan_slaves; + ec_fsm_slave_start_scan(&fsm->fsm_slave, fsm->slave); + ec_fsm_slave_exec(&fsm->fsm_slave); // execute immediately +} + +/*****************************************************************************/ + +/** * Master state: SCAN SLAVES. * Executes the sub-statemachine for the scanning of a slave. */