36 #include <linux/module.h> 37 #include <linux/jiffies.h> 38 #include <linux/slab.h> 46 #define EC_MBG_REQUEST_RESPONSE_TIMEOUT 1000 60 INIT_LIST_HEAD(&req->
list);
65 req->
state = EC_INT_REQUEST_INIT;
111 if (size <= req->mem_size)
116 if (!(req->
data = (uint8_t *) kmalloc(size, GFP_KERNEL))) {
117 EC_ERR(
"Failed to allocate %zu bytes of Mbox Gateway memory.\n", size);
137 const uint8_t *source,
145 memcpy(req->
data, source, size);
158 req->
state = EC_INT_REQUEST_QUEUED;
ec_internal_request_state_t state
Request state.
EtherCAT Mailbox Gateway request.
size_t data_size
Size of MBox request data.
uint32_t response_timeout
Maximum time in ms, the transfer is retried, if the slave does not respond.
size_t mem_size
Size of MBox request data memory.
uint8_t * data
Pointer to MBox request data.
uint16_t error_code
MBox Gateway error code.
int ec_mbg_request_copy_data(ec_mbg_request_t *req, const uint8_t *source, size_t size)
Copies Mbox Gateway data from an external source.
struct list_head list
List item.
void ec_mbg_request_init(ec_mbg_request_t *req)
Mbox Gateway request constructor.
EtherCAT Mailbox Gateway request structure.
void ec_mbg_request_clear(ec_mbg_request_t *req)
Mbox Gateway request destructor.
#define EC_MBG_REQUEST_RESPONSE_TIMEOUT
Default timeout in ms to wait for Mbox Gateway responses.
#define EC_ERR(fmt, args...)
Convenience macro for printing EtherCAT-specific errors to syslog.
void ec_mbg_request_clear_data(ec_mbg_request_t *)
Free allocated memory.
unsigned long jiffies_sent
Jiffies, when the upload/download request was sent.
int ec_mbg_request_alloc(ec_mbg_request_t *req, size_t size)
Pre-allocates the data memory.
void ec_mbg_request_run(ec_mbg_request_t *req)
Request to run.