master/master.h
author Florian Pose <fp@igh-essen.com>
Wed, 12 Apr 2006 12:04:27 +0000
changeset 192 8d7bd5082ed5
parent 191 ca805255a935
child 195 674071846ee3
permissions -rw-r--r--
Fixed devices Makefile.
/******************************************************************************
 *
 *  m a s t e r . h
 *
 *  Struktur für einen EtherCAT-Master.
 *
 *  $Id$
 *
 *****************************************************************************/

#ifndef _EC_MASTER_H_
#define _EC_MASTER_H_

#include <linux/list.h>
#include <linux/sysfs.h>
#include <linux/timer.h>

#include "device.h"
#include "domain.h"

/*****************************************************************************/

/**
   EtherCAT master mode.
*/

typedef enum
{
    EC_MASTER_MODE_IDLE,
    EC_MASTER_MODE_FREERUN,
    EC_MASTER_MODE_RUNNING
}
ec_master_mode_t;

/*****************************************************************************/

/**
   EtherCAT-Rahmen-Statistiken.
*/

typedef struct
{
    unsigned int timeouts; /**< Kommando-Timeouts */
    unsigned int delayed; /**< Verzögerte Kommandos */
    unsigned int corrupted; /**< Verfälschte Rahmen */
    unsigned int unmatched; /**< Unpassende Kommandos */
    unsigned int eoe_errors; /**< Ethernet-over-EtherCAT Fehler */
    cycles_t t_last; /**< Timestamp-Counter bei der letzten Ausgabe */
}
ec_stats_t;

/*****************************************************************************/

/**
   EtherCAT-Master

   Verwaltet die EtherCAT-Slaves und kommuniziert mit
   dem zugewiesenen EtherCAT-Gerät.
*/

struct ec_master
{
    struct list_head list; /**< Noetig fuer Master-Liste */
    struct kobject kobj; /**< Kernel-Object */
    unsigned int index; /**< Master-Index */
    struct list_head slaves; /**< Liste der Slaves auf dem Bus */
    unsigned int slave_count; /**< Anzahl Slaves auf dem Bus */
    ec_device_t *device; /**< EtherCAT-Gerät */
    struct list_head command_queue; /**< Kommando-Warteschlange */
    uint8_t command_index; /**< Aktueller Kommando-Index */
    struct list_head domains; /**< Liste der Prozessdatendomänen */
    ec_command_t simple_command; /**< Kommando für Initialisierungsphase */
    ec_command_t watch_command; /**< Kommando zum Überwachen der Slaves */
    unsigned int slaves_responding; /**< Anzahl antwortender Slaves */
    ec_slave_state_t slave_states; /**< Zustände der antwortenden Slaves */
    int debug_level; /**< Debug-Level im Master-Code */
    ec_stats_t stats; /**< Rahmen-Statistiken */
    unsigned int timeout; /**< Timeout für synchronen Datenaustausch */
    struct list_head eoe_slaves; /**< Ethernet over EtherCAT Slaves */
    unsigned int reserved; /**< Master durch Echtzeitprozess reserviert */
    struct timer_list freerun_timer; /**< Timer fuer Free-Run-Modus. */
    ec_master_mode_t mode; /**< Modus des Masters */
};

/*****************************************************************************/

// Master creation and deletion
int ec_master_init(ec_master_t *, unsigned int);
void ec_master_clear(struct kobject *);
void ec_master_reset(ec_master_t *);

// Free-Run
void ec_master_freerun_start(ec_master_t *);
void ec_master_freerun_stop(ec_master_t *);

// IO
void ec_master_receive(ec_master_t *, const uint8_t *, size_t);
void ec_master_queue_command(ec_master_t *, ec_command_t *);
int ec_master_simple_io(ec_master_t *, ec_command_t *);

// Slave management
int ec_master_bus_scan(ec_master_t *);

// Misc
void ec_master_debug(const ec_master_t *);
void ec_master_output_stats(ec_master_t *);
void ec_master_run_eoe(ec_master_t *);

/*****************************************************************************/

#endif

/* Emacs-Konfiguration
;;; Local Variables: ***
;;; c-basic-offset:4 ***
;;; End: ***
*/