diff -r 000000000000 -r 05c992bf5847 drivers/ec_master.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/drivers/ec_master.h Fri Oct 21 11:21:42 2005 +0000 @@ -0,0 +1,134 @@ +/**************************************************************** + * + * e c _ m a s t e r . h + * + * Struktur für einen EtherCAT-Master. + * + * $Date$ + * $Author$ + * + ***************************************************************/ + +#ifndef _EC_MASTER_H_ +#define _EC_MASTER_H_ + +#include "ec_device.h" +#include "ec_slave.h" +#include "ec_command.h" + +/***************************************************************/ + +/** + EtherCAT-Master + + Verwaltet die EtherCAT-Slaves und kommuniziert mit + dem zugewiesenen EtherCAT-Gerät. +*/ + +typedef struct +{ + EtherCAT_slave_t *slaves; /**< Zeiger auf statischen Speicher + mit Slave-Informationen */ + unsigned int slave_count; /**< Anzahl der Slaves in slaves */ + + EtherCAT_command_t *first_command; /**< Zeiger auf das erste + Kommando in der Liste */ + EtherCAT_command_t *process_data_command; /**< Zeiger Auf das Kommando + zum Senden und Empfangen + der Prozessdaten */ + + EtherCAT_device_t *dev; /**< Zeiger auf das zugewiesene EtherCAT-Gerät */ + + unsigned char command_index; /**< Aktueller Kommando-Index */ + + unsigned char tx_data[ECAT_FRAME_BUFFER_SIZE]; /**< Statischer Speicher + für zu sendende Daten */ + unsigned int tx_data_length; /**< Länge der Daten im Sendespeicher */ + unsigned char rx_data[ECAT_FRAME_BUFFER_SIZE]; /**< Statische Speicher für + eine Kopie des Rx-Buffers + im EtherCAT-Gerät */ + + unsigned char *process_data; /**< Zeiger auf Speicher mit Prozessdaten */ + unsigned int process_data_length; /**< Länge der Prozessdaten */ + + EtherCAT_command_t cmd_ring[ECAT_COMMAND_RING_SIZE]; /** Statischer Kommandoring */ + unsigned int cmd_ring_index; /**< Index des nächsten Kommandos im Ring */ +} +EtherCAT_master_t; + +/***************************************************************/ + +// Master creation and deletion +int EtherCAT_master_init(EtherCAT_master_t *, EtherCAT_device_t *); +void EtherCAT_master_clear(EtherCAT_master_t *); + +// Slave management +int EtherCAT_check_slaves(EtherCAT_master_t *, EtherCAT_slave_t *, unsigned int); +void EtherCAT_clear_slaves(EtherCAT_master_t *); +int EtherCAT_activate_slave(EtherCAT_master_t *, EtherCAT_slave_t *); +int EtherCAT_deactivate_slave(EtherCAT_master_t *, EtherCAT_slave_t *); +int EtherCAT_activate_all_slaves(EtherCAT_master_t *); +int EtherCAT_deactivate_all_slaves(EtherCAT_master_t *); + +// Sending and receiving +int EtherCAT_async_send_receive(EtherCAT_master_t *); +int EtherCAT_send(EtherCAT_master_t *); +int EtherCAT_receive(EtherCAT_master_t *); +int EtherCAT_write_process_data(EtherCAT_master_t *); +int EtherCAT_read_process_data(EtherCAT_master_t *); + +/***************************************************************/ + +// Slave information interface +int EtherCAT_read_slave_information(EtherCAT_master_t *, + unsigned short int, + unsigned short int, + unsigned int *); + +// EtherCAT commands +EtherCAT_command_t *EtherCAT_read(EtherCAT_master_t *, + unsigned short, + unsigned short, + unsigned int); +EtherCAT_command_t *EtherCAT_write(EtherCAT_master_t *, + unsigned short, + unsigned short, + unsigned int, + const unsigned char *); +EtherCAT_command_t *EtherCAT_position_read(EtherCAT_master_t *, + short, + unsigned short, + unsigned int); +EtherCAT_command_t *EtherCAT_position_write(EtherCAT_master_t *, + short, + unsigned short, + unsigned int, + const unsigned char *); +EtherCAT_command_t *EtherCAT_broadcast_read(EtherCAT_master_t *, + unsigned short, + unsigned int); +EtherCAT_command_t *EtherCAT_broadcast_write(EtherCAT_master_t *, + unsigned short, + unsigned int, + const unsigned char *); +EtherCAT_command_t *EtherCAT_logical_read_write(EtherCAT_master_t *, + unsigned int, + unsigned int, + unsigned char *); + +void EtherCAT_remove_command(EtherCAT_master_t *, EtherCAT_command_t *); + +// Slave states +int EtherCAT_state_change(EtherCAT_master_t *, EtherCAT_slave_t *, unsigned char); + +/***************************************************************/ + +// Private functions +EtherCAT_command_t *alloc_cmd(EtherCAT_master_t *); +void add_command(EtherCAT_master_t *, EtherCAT_command_t *); +void set_byte(unsigned char *, unsigned int, unsigned char); +void set_word(unsigned char *, unsigned int, unsigned int); + +/***************************************************************/ + +#endif