fp@409: /****************************************************************************** fp@409: * fp@409: * $Id$ fp@409: * fp@409: * Copyright (C) 2006 Florian Pose, Ingenieurgemeinschaft IgH fp@409: * fp@409: * This file is part of the IgH EtherCAT Master. fp@409: * fp@409: * The IgH EtherCAT Master is free software; you can redistribute it fp@409: * and/or modify it under the terms of the GNU General Public License fp@409: * as published by the Free Software Foundation; either version 2 of the fp@409: * License, or (at your option) any later version. fp@409: * fp@409: * The IgH EtherCAT Master is distributed in the hope that it will be fp@409: * useful, but WITHOUT ANY WARRANTY; without even the implied warranty of fp@409: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the fp@409: * GNU General Public License for more details. fp@409: * fp@409: * You should have received a copy of the GNU General Public License fp@409: * along with the IgH EtherCAT Master; if not, write to the Free Software fp@409: * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA fp@409: * fp@409: * The right to use EtherCAT Technology is granted and comes free of fp@409: * charge under condition of compatibility of product made by fp@409: * Licensee. People intending to distribute/sell products based on the fp@409: * code, have to sign an agreement to guarantee that products using fp@409: * software based on IgH EtherCAT master stay compatible with the actual fp@409: * EtherCAT specification (which are released themselves as an open fp@409: * standard) as the (only) precondition to have the right to use EtherCAT fp@409: * Technology, IP and trade marks. fp@409: * fp@409: *****************************************************************************/ fp@409: fp@409: /** fp@409: \file fp@847: Canopen-over-EtherCAT Sdo request functions. fp@409: */ fp@409: fp@409: /*****************************************************************************/ fp@409: fp@409: #include fp@409: fp@847: #include "sdo_request.h" fp@409: fp@409: /*****************************************************************************/ fp@409: fp@852: void ec_sdo_request_clear_data(ec_sdo_request_t *); fp@852: fp@852: /*****************************************************************************/ fp@852: fp@847: /** Sdo request constructor. fp@758: */ fp@847: void ec_sdo_request_init( fp@852: ec_sdo_request_t *req /**< Sdo request. */ fp@831: ) fp@831: { fp@430: req->data = NULL; fp@854: req->mem_size = 0; fp@854: req->data_size = 0; fp@859: req->dir = EC_DIR_OUTPUT; fp@852: req->state = EC_REQUEST_COMPLETE; fp@430: } fp@430: fp@430: /*****************************************************************************/ fp@430: fp@847: /** Sdo request destructor. fp@847: */ fp@847: void ec_sdo_request_clear( fp@847: ec_sdo_request_t *req /**< Sdo request. */ fp@847: ) fp@430: { fp@852: ec_sdo_request_clear_data(req); fp@430: } fp@430: fp@430: /*****************************************************************************/ fp@852: fp@852: /** Sdo request destructor. fp@852: */ fp@852: void ec_sdo_request_clear_data( fp@852: ec_sdo_request_t *req /**< Sdo request. */ fp@852: ) fp@852: { fp@852: if (req->data) { fp@852: kfree(req->data); fp@852: req->data = NULL; fp@852: } fp@852: fp@854: req->mem_size = 0; fp@854: req->data_size = 0; fp@852: } fp@852: fp@852: /*****************************************************************************/ fp@852: fp@854: /** Set the Sdo address. fp@852: */ fp@854: void ec_sdo_request_address( fp@852: ec_sdo_request_t *req, /**< Sdo request. */ fp@852: uint16_t index, /**< Sdo index. */ fp@852: uint8_t subindex /**< Sdo subindex. */ fp@852: ) fp@852: { fp@852: req->index = index; fp@852: req->subindex = subindex; fp@852: } fp@852: fp@852: /*****************************************************************************/ fp@854: fp@854: /** Pre-allocates the data memory. fp@854: * fp@854: * If the \a mem_size is already bigger than \a size, nothing is done. fp@854: */ fp@854: int ec_sdo_request_alloc( fp@854: ec_sdo_request_t *req, /**< Sdo request. */ fp@854: size_t size /**< Data size to allocate. */ fp@854: ) fp@854: { fp@854: if (size <= req->mem_size) fp@854: return 0; fp@854: fp@854: ec_sdo_request_clear_data(req); fp@854: fp@854: if (!(req->data = (uint8_t *) kmalloc(size, GFP_KERNEL))) { fp@854: EC_ERR("Failed to allocate %u bytes of Sdo memory.\n", size); fp@854: return -1; fp@854: } fp@854: fp@854: req->mem_size = size; fp@854: req->data_size = 0; fp@854: return 0; fp@854: } fp@854: fp@854: /*****************************************************************************/ fp@854: fp@854: /** Copies Sdo data from an external source. fp@854: * fp@854: * If the \a mem_size is to small, new memory is allocated. fp@854: */ fp@854: int ec_sdo_request_copy_data( fp@854: ec_sdo_request_t *req, /**< Sdo request. */ fp@854: const uint8_t *source, /**< Source data. */ fp@854: size_t size /**< Number of bytes in \a source. */ fp@854: ) fp@854: { fp@854: if (ec_sdo_request_alloc(req, size)) fp@854: return -1; fp@854: fp@854: memcpy(req->data, source, size); fp@854: req->data_size = size; fp@854: return 0; fp@854: } fp@854: fp@858: /***************************************************************************** fp@858: * Realtime interface. fp@858: ****************************************************************************/ fp@858: fp@858: void ecrt_sdo_request_timeout(ec_sdo_request_t *req, uint32_t timeout) fp@858: { fp@858: } fp@858: fp@858: /*****************************************************************************/ fp@858: fp@858: uint8_t *ecrt_sdo_request_data(ec_sdo_request_t *req) fp@858: { fp@858: return req->data; fp@858: } fp@858: fp@858: /*****************************************************************************/ fp@858: fp@858: ec_request_state_t ecrt_sdo_request_state(const ec_sdo_request_t *req) fp@858: { fp@858: return req->state; fp@858: } fp@858: fp@858: /*****************************************************************************/ fp@858: fp@858: ec_sdo_request_error_t ecrt_sdo_request_error(const ec_sdo_request_t *req) fp@858: { fp@858: return EC_SDO_REQUEST_SUCCESS; // FIXME fp@858: } fp@858: fp@858: /*****************************************************************************/ fp@858: fp@858: void ecrt_sdo_request_read(ec_sdo_request_t *req) fp@854: { fp@859: req->dir = EC_DIR_INPUT; fp@854: req->state = EC_REQUEST_QUEUED; fp@854: } fp@854: fp@854: /*****************************************************************************/ fp@854: fp@858: void ecrt_sdo_request_write(ec_sdo_request_t *req) fp@854: { fp@859: req->dir = EC_DIR_OUTPUT; fp@854: req->state = EC_REQUEST_QUEUED; fp@854: } fp@854: fp@854: /*****************************************************************************/ fp@858: fp@858: EXPORT_SYMBOL(ecrt_sdo_request_timeout); fp@858: EXPORT_SYMBOL(ecrt_sdo_request_data); fp@858: EXPORT_SYMBOL(ecrt_sdo_request_state); fp@858: EXPORT_SYMBOL(ecrt_sdo_request_error); fp@858: EXPORT_SYMBOL(ecrt_sdo_request_read); fp@858: EXPORT_SYMBOL(ecrt_sdo_request_write); fp@859: fp@859: /*****************************************************************************/