lib/master.c
changeset 1244 0b70040d3daa
child 1246 4042bda8c980
equal deleted inserted replaced
1243:13cb18b91627 1244:0b70040d3daa
       
     1 /******************************************************************************
       
     2  *
       
     3  *  $Id$
       
     4  *
       
     5  *  Copyright (C) 2006  Florian Pose, Ingenieurgemeinschaft IgH
       
     6  *
       
     7  *  This file is part of the IgH EtherCAT Master.
       
     8  *
       
     9  *  The IgH EtherCAT Master is free software; you can redistribute it
       
    10  *  and/or modify it under the terms of the GNU General Public License
       
    11  *  as published by the Free Software Foundation; either version 2 of the
       
    12  *  License, or (at your option) any later version.
       
    13  *
       
    14  *  The IgH EtherCAT Master is distributed in the hope that it will be
       
    15  *  useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
       
    16  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
       
    17  *  GNU General Public License for more details.
       
    18  *
       
    19  *  You should have received a copy of the GNU General Public License
       
    20  *  along with the IgH EtherCAT Master; if not, write to the Free Software
       
    21  *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
       
    22  *
       
    23  *  The right to use EtherCAT Technology is granted and comes free of
       
    24  *  charge under condition of compatibility of product made by
       
    25  *  Licensee. People intending to distribute/sell products based on the
       
    26  *  code, have to sign an agreement to guarantee that products using
       
    27  *  software based on IgH EtherCAT master stay compatible with the actual
       
    28  *  EtherCAT specification (which are released themselves as an open
       
    29  *  standard) as the (only) precondition to have the right to use EtherCAT
       
    30  *  Technology, IP and trade marks.
       
    31  *
       
    32  *****************************************************************************/
       
    33 
       
    34 #include <stdlib.h>
       
    35 #include <sys/ioctl.h>
       
    36 #include <stdio.h>
       
    37 #include <errno.h>
       
    38 #include <string.h>
       
    39 
       
    40 #include "master.h"
       
    41 #include "domain.h"
       
    42 #include "master/ioctl.h"
       
    43 
       
    44 /*****************************************************************************/
       
    45 
       
    46 ec_domain_t *ecrt_master_create_domain(ec_master_t *master)
       
    47 {
       
    48     ec_domain_t *domain;
       
    49     int index;
       
    50 
       
    51     domain = malloc(sizeof(ec_domain_t));
       
    52     if (!domain) {
       
    53         fprintf(stderr, "Failed to allocate memory.\n");
       
    54         return 0;
       
    55     }
       
    56     
       
    57     index = ioctl(master->fd, EC_IOCTL_CREATE_DOMAIN, NULL);
       
    58     if (index == -1) {
       
    59         fprintf(stderr, "Failed to create domain: %s\n", strerror(errno));
       
    60         free(domain);
       
    61         return 0; 
       
    62     }
       
    63 
       
    64     domain->index = (unsigned int) index;
       
    65     return domain;
       
    66 }
       
    67 
       
    68 /*****************************************************************************/
       
    69 
       
    70 ec_slave_config_t *ecrt_master_slave_config(ec_master_t *master,
       
    71         uint16_t alias, uint16_t position, uint32_t vendor_id,
       
    72         uint32_t product_code)
       
    73 {
       
    74     return 0;
       
    75 }
       
    76 
       
    77 /*****************************************************************************/
       
    78 
       
    79 int ecrt_master_activate(ec_master_t *master)
       
    80 {
       
    81     return 0;
       
    82 }
       
    83 
       
    84 /*****************************************************************************/
       
    85 
       
    86 void ecrt_master_send(ec_master_t *master)
       
    87 {
       
    88 }
       
    89 
       
    90 /*****************************************************************************/
       
    91 
       
    92 void ecrt_master_receive(ec_master_t *master)
       
    93 {
       
    94 }
       
    95 
       
    96 /*****************************************************************************/
       
    97 
       
    98 void ecrt_master_state(const ec_master_t *master, ec_master_state_t *state)
       
    99 {
       
   100 }
       
   101 
       
   102 
       
   103 /*****************************************************************************/