IgH EtherCAT Master  1.5.2
foe_request.c
Go to the documentation of this file.
1 /******************************************************************************
2  *
3  * $Id$
4  *
5  * Copyright (C) 2008 Olav Zarges, imc Messsysteme GmbH
6  *
7  * This file is part of the IgH EtherCAT Master.
8  *
9  * The IgH EtherCAT Master is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License version 2, as
11  * published by the Free Software Foundation.
12  *
13  * The IgH EtherCAT Master is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
16  * Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License along
19  * with the IgH EtherCAT Master; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21  *
22  * ---
23  *
24  * The license mentioned above concerns the source code only. Using the
25  * EtherCAT technology and brand is only permitted in compliance with the
26  * industrial property and similar rights of Beckhoff Automation GmbH.
27  *
28  *****************************************************************************/
29 
34 /*****************************************************************************/
35 
36 #include <linux/module.h>
37 #include <linux/jiffies.h>
38 #include <linux/slab.h>
39 
40 #include "foe_request.h"
41 
42 /*****************************************************************************/
43 
46 #define EC_FOE_REQUEST_RESPONSE_TIMEOUT 3000
47 
48 /*****************************************************************************/
49 
51 
52 /*****************************************************************************/
53 
57  ec_foe_request_t *req
58  )
59 {
60  INIT_LIST_HEAD(&req->list);
61  req->buffer = NULL;
62  req->file_name[0] = 0;
63  req->password = 0;
64  req->buffer_size = 0;
65  req->data_size = 0;
66  req->progress = 0;
67  req->dir = EC_DIR_INVALID;
68  req->issue_timeout = 0; // no timeout
70  req->state = EC_INT_REQUEST_INIT;
71  req->result = FOE_BUSY;
72  req->error_code = 0x00000000;
73 }
74 
75 /*****************************************************************************/
76 
80  ec_foe_request_t *req
81  )
82 {
84 }
85 
86 /*****************************************************************************/
87 
91  ec_foe_request_t *req
92  )
93 {
94  if (req->buffer) {
95  kfree(req->buffer);
96  req->buffer = NULL;
97  }
98 
99  req->buffer_size = 0;
100  req->data_size = 0;
101 }
102 
103 /*****************************************************************************/
104 
113  ec_foe_request_t *req,
114  size_t size
115  )
116 {
117  if (size <= req->buffer_size) {
118  return 0;
119  }
120 
122 
123  if (!(req->buffer = (uint8_t *) kmalloc(size, GFP_KERNEL))) {
124  EC_ERR("Failed to allocate %zu bytes of FoE memory.\n", size);
125  return -ENOMEM;
126  }
127 
128  req->buffer_size = size;
129  req->data_size = 0;
130  return 0;
131 }
132 
133 /*****************************************************************************/
134 
142  ec_foe_request_t *req,
143  const uint8_t *source,
144  size_t size
145  )
146 {
147  int ret;
148 
149  ret = ec_foe_request_alloc(req, size);
150  if (ret) {
151  return ret;
152  }
153 
154  memcpy(req->buffer, source, size);
155  req->data_size = size;
156  return 0;
157 }
158 
159 /*****************************************************************************/
160 
166  const ec_foe_request_t *req
167  )
168 {
169  return req->issue_timeout
170  && jiffies - req->jiffies_start > HZ * req->issue_timeout / 1000;
171 }
172 
173 /*****************************************************************************
174  * Application interface.
175  ****************************************************************************/
176 
180  ec_foe_request_t *req,
181  uint32_t timeout
182  )
183 {
184  req->issue_timeout = timeout;
185 }
186 
187 /*****************************************************************************/
188 
192  ec_foe_request_t *req,
193  const char* file_name,
194  uint32_t password
195  )
196 {
197  strlcpy((char*) req->file_name, file_name, sizeof(req->file_name));
198  req->password = password;
199 }
200 
201 /*****************************************************************************/
202 
208  ec_foe_request_t *req
209  )
210 {
211  return req->buffer;
212 }
213 
214 /*****************************************************************************/
215 
221  const ec_foe_request_t *req
222  )
223 {
224  return req->data_size;
225 }
226 
227 /*****************************************************************************/
228 
230 {
232 }
233 
234 /*****************************************************************************/
235 
237 {
238  return req->result;
239 }
240 
241 /*****************************************************************************/
242 
244 {
245  return req->error_code;
246 }
247 
248 /*****************************************************************************/
249 
255  const ec_foe_request_t *req
256  )
257 {
258  return req->progress;
259 }
260 
261 /*****************************************************************************/
262 
266  ec_foe_request_t *req
267  )
268 {
269  req->data_size = 0;
270  req->progress = 0;
271  req->dir = EC_DIR_INPUT;
272  req->state = EC_INT_REQUEST_QUEUED;
273  req->result = FOE_BUSY;
274  req->jiffies_start = jiffies;
275 }
276 
277 /*****************************************************************************/
278 
282  ec_foe_request_t *req,
283  size_t data_size
284  )
285 {
286  if (data_size > req->buffer_size) {
287  EC_ERR("Request to write %zu bytes to FoE buffer of size %zu.\n",
288  data_size, req->buffer_size);
289  req->state = EC_INT_REQUEST_FAILURE;
290  return;
291  }
292  req->data_size = data_size;
293  req->progress = 0;
294  req->dir = EC_DIR_OUTPUT;
295  req->state = EC_INT_REQUEST_QUEUED;
296  req->result = FOE_BUSY;
297  req->jiffies_start = jiffies;
298 }
299 
300 /*****************************************************************************/
301 
304 EXPORT_SYMBOL(ecrt_foe_request_file);
305 EXPORT_SYMBOL(ecrt_foe_request_timeout);
306 EXPORT_SYMBOL(ecrt_foe_request_data);
307 EXPORT_SYMBOL(ecrt_foe_request_data_size);
308 EXPORT_SYMBOL(ecrt_foe_request_state);
309 EXPORT_SYMBOL(ecrt_foe_request_result);
310 EXPORT_SYMBOL(ecrt_foe_request_error_code);
311 EXPORT_SYMBOL(ecrt_foe_request_progress);
312 EXPORT_SYMBOL(ecrt_foe_request_read);
313 EXPORT_SYMBOL(ecrt_foe_request_write);
314 
317 /*****************************************************************************/
ec_request_state_t ecrt_foe_request_state(const ec_foe_request_t *req)
Get the current state of the FoE request.
Definition: foe_request.c:229
size_t ecrt_foe_request_data_size(const ec_foe_request_t *req)
Returns the data size.
Definition: foe_request.c:220
uint32_t issue_timeout
Maximum time in ms, the processing of the request may take.
Definition: foe_request.h:57
int ec_foe_request_timed_out(const ec_foe_request_t *req)
Checks, if the timeout was exceeded.
Definition: foe_request.c:165
ec_foe_error_t
FoE error enumeration type.
Definition: ecrt.h:548
void ec_foe_request_init(ec_foe_request_t *req)
FoE request constructor.
Definition: foe_request.c:56
uint32_t ecrt_foe_request_error_code(const ec_foe_request_t *req)
Get the FoE error code from the FoE request.
Definition: foe_request.c:243
int ec_foe_request_alloc(ec_foe_request_t *req, size_t size)
Pre-allocates the data memory.
Definition: foe_request.c:112
size_t data_size
Size of FoE data.
Definition: foe_request.h:54
void ecrt_foe_request_timeout(ec_foe_request_t *req, uint32_t timeout)
Set the request timeout.
Definition: foe_request.c:179
void ecrt_foe_request_write(ec_foe_request_t *req, size_t data_size)
Prepares a write request (master to slave).
Definition: foe_request.c:281
void ec_foe_request_clear_data(ec_foe_request_t *)
FoE request destructor.
Definition: foe_request.c:90
size_t ecrt_foe_request_progress(const ec_foe_request_t *req)
Returns the progress of the current transfer.
Definition: foe_request.c:254
uint8_t file_name[255]
FoE filename.
Definition: foe_request.h:71
void ec_foe_request_clear(ec_foe_request_t *req)
FoE request destructor.
Definition: foe_request.c:79
uint32_t response_timeout
Maximum time in ms, the transfer is retried, if the slave does not respond.
Definition: foe_request.h:59
#define EC_FOE_REQUEST_RESPONSE_TIMEOUT
Default timeout in ms to wait for FoE transfer responses.
Definition: foe_request.c:46
void ecrt_foe_request_read(ec_foe_request_t *req)
Prepares a read request (slave to master).
Definition: foe_request.c:265
uint8_t * buffer
Pointer to FoE data.
Definition: foe_request.h:52
uint8_t * ecrt_foe_request_data(ec_foe_request_t *req)
Returns a pointer to the request&#39;s data.
Definition: foe_request.c:207
EtherCAT FoE request structure.
uint32_t error_code
Error code from an FoE Error Request.
Definition: foe_request.h:70
int ec_foe_request_copy_data(ec_foe_request_t *req, const uint8_t *source, size_t size)
Copies FoE data from an external source.
Definition: foe_request.c:141
struct list_head list
List item.
Definition: foe_request.h:51
void ecrt_foe_request_file(ec_foe_request_t *req, const char *file_name, uint32_t password)
Selects a new file for the request.
Definition: foe_request.c:191
Values read by the master.
Definition: ecrt.h:439
ec_foe_error_t result
FoE request abort code.
Definition: foe_request.h:69
ec_direction_t dir
Direction.
Definition: foe_request.h:61
size_t buffer_size
Size of FoE data memory.
Definition: foe_request.h:53
Busy.
Definition: ecrt.h:549
Invalid direction.
Definition: ecrt.h:437
#define EC_ERR(fmt, args...)
Convenience macro for printing EtherCAT-specific errors to syslog.
Definition: globals.h:262
unsigned long jiffies_start
Jiffies, when the request was issued.
Definition: foe_request.h:65
size_t progress
Current position of a BUSY request.
Definition: foe_request.h:55
ec_foe_error_t ecrt_foe_request_result(const ec_foe_request_t *req)
Get the result of the FoE request.
Definition: foe_request.c:236
FoE request.
Definition: foe_request.h:50
ec_request_state_t
Request state.
Definition: ecrt.h:537
Values written by the master.
Definition: ecrt.h:438
const ec_request_state_t ec_request_state_translation_table[]
Global request state type translation table.
Definition: module.c:665
uint32_t password
FoE password.
Definition: foe_request.h:68
ec_internal_request_state_t state
FoE request state.
Definition: foe_request.h:64