diff --git a/Doxyfile.in b/Doxyfile.in index 585fef535fe1844d30dbe535646c013c3e70f2a5..21a1230e851fdba5aa8ef744d359fda833765008 100644 --- a/Doxyfile.in +++ b/Doxyfile.in @@ -1056,7 +1056,7 @@ INCLUDE_FILE_PATTERNS = # undefined via #undef or recursively expanded use the := operator # instead of the = operator. -PREDEFINED = +PREDEFINED = __KERNEL__ # If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then # this tag can be used to specify a list of macro names that should be expanded. diff --git a/Makefile.am b/Makefile.am index 296ac1dd91b45d28c66e83050da63306dc380920..4bb631d707162e20375ecf99241b12b24574135b 100644 --- a/Makefile.am +++ b/Makefile.am @@ -62,6 +62,7 @@ EXTRA_DIST = \ README.EoE BUILT_SOURCES = \ + Doxyfile \ Kbuild modules: diff --git a/master/cdev.c b/master/cdev.c index 771d5eae4641493b327caa770529f1c9013dc4d6..bebb0fc1159af4e97c23d379236d065556aa17b6 100644 --- a/master/cdev.c +++ b/master/cdev.c @@ -50,18 +50,18 @@ /*****************************************************************************/ -/** \cond */ - -int eccdev_open(struct inode *, struct file *); -int eccdev_release(struct inode *, struct file *); -long eccdev_ioctl(struct file *, unsigned int, unsigned long); -int eccdev_mmap(struct file *, struct vm_area_struct *); +static int eccdev_open(struct inode *, struct file *); +static int eccdev_release(struct inode *, struct file *); +static long eccdev_ioctl(struct file *, unsigned int, unsigned long); +static int eccdev_mmap(struct file *, struct vm_area_struct *); static struct page *eccdev_vma_nopage( struct vm_area_struct *, unsigned long, int *); /*****************************************************************************/ +/** File operation callbacks for the EtherCAT character device. + */ static struct file_operations eccdev_fops = { .owner = THIS_MODULE, .open = eccdev_open, @@ -70,21 +70,21 @@ static struct file_operations eccdev_fops = { .mmap = eccdev_mmap }; +/** Callbacks for a virtual memory area retrieved with ecdevc_mmap(). + */ struct vm_operations_struct eccdev_vm_ops = { .nopage = eccdev_vma_nopage }; -/** \endcond */ - /*****************************************************************************/ /** Private data structure for file handles. */ typedef struct { - ec_cdev_t *cdev; - unsigned int requested; - uint8_t *process_data; - size_t process_data_size; + ec_cdev_t *cdev; /**< Character device. */ + unsigned int requested; /**< Master wac requested via this file handle. */ + uint8_t *process_data; /**< Total process data area. */ + size_t process_data_size; /**< Size of the \a process_data. */ } ec_cdev_priv_t; /*****************************************************************************/ @@ -2563,6 +2563,11 @@ long eccdev_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) /*****************************************************************************/ +/** Memory-map callback for the EtherCAT character device. + * + * The actual mapping will be done in the eccdev_vma_nopage() callback of the + * virtual memory area. + */ int eccdev_mmap( struct file *filp, struct vm_area_struct *vma @@ -2582,10 +2587,16 @@ int eccdev_mmap( /*****************************************************************************/ +/** Page fault callback for a virtual memory area. + * + * Called at the first access on a virtual-memory area retrieved with + * ecdev_mmap(). + */ struct page *eccdev_vma_nopage( - struct vm_area_struct *vma, - unsigned long address, - int *type + struct vm_area_struct *vma, /**< Virtual memory area initialized by + the kernel. */ + unsigned long address, /**< Requested virtual address. */ + int *type /**< Type output parameter. */ ) { unsigned long offset; diff --git a/master/fsm_master.h b/master/fsm_master.h index 74bbdfbf788eddabbb21ed5e224abeb3dedbb6d1..6ff8502dc05bb868e747fccc000951b5ee1086b4 100644 --- a/master/fsm_master.h +++ b/master/fsm_master.h @@ -71,7 +71,7 @@ typedef struct { ec_direction_t dir; /**< Direction. */ uint16_t offset; /**< Physical memory offset. */ size_t length; /**< Number of bytes. */ - uint8_t *data; + uint8_t *data; /**< Data to write / memory for read data. */ ec_internal_request_state_t state; /**< State of the request. */ } ec_phy_request_t; diff --git a/master/voe_handler.c b/master/voe_handler.c index 7ff9e2b11bee292ec4e12e5b78e2d318ad48e2f8..32fa1c53394adf6cf38dd783c3af9f8b3aeb1329 100644 --- a/master/voe_handler.c +++ b/master/voe_handler.c @@ -58,8 +58,6 @@ /*****************************************************************************/ -void ec_voe_handler_clear_data(ec_voe_handler_t *); - void ec_voe_handler_state_write_start(ec_voe_handler_t *); void ec_voe_handler_state_write_response(ec_voe_handler_t *); @@ -199,6 +197,8 @@ ec_request_state_t ecrt_voe_handler_execute(ec_voe_handler_t *voe) * State functions. *****************************************************************************/ +/** Start writing VoE data. + */ void ec_voe_handler_state_write_start(ec_voe_handler_t *voe) { ec_slave_t *slave = voe->config->slave; @@ -234,6 +234,8 @@ void ec_voe_handler_state_write_start(ec_voe_handler_t *voe) /*****************************************************************************/ +/** Wait for the mailbox response. + */ void ec_voe_handler_state_write_response(ec_voe_handler_t *voe) { ec_datagram_t *datagram = &voe->datagram; @@ -282,6 +284,8 @@ void ec_voe_handler_state_write_response(ec_voe_handler_t *voe) /*****************************************************************************/ +/** Start reading VoE data. + */ void ec_voe_handler_state_read_start(ec_voe_handler_t *voe) { ec_datagram_t *datagram = &voe->datagram; @@ -306,6 +310,8 @@ void ec_voe_handler_state_read_start(ec_voe_handler_t *voe) /*****************************************************************************/ +/** Check for new data in the mailbox. + */ void ec_voe_handler_state_read_check(ec_voe_handler_t *voe) { ec_datagram_t *datagram = &voe->datagram; @@ -356,6 +362,8 @@ void ec_voe_handler_state_read_check(ec_voe_handler_t *voe) /*****************************************************************************/ +/** Read the pending mailbox data. + */ void ec_voe_handler_state_read_response(ec_voe_handler_t *voe) { ec_datagram_t *datagram = &voe->datagram; @@ -419,12 +427,16 @@ void ec_voe_handler_state_read_response(ec_voe_handler_t *voe) /*****************************************************************************/ +/** Successful termination state function. + */ void ec_voe_handler_state_end(ec_voe_handler_t *voe) { } /*****************************************************************************/ +/** Failure termination state function. + */ void ec_voe_handler_state_error(ec_voe_handler_t *voe) { }