1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

netdev: fix return value and precondition doc

While reviewing #9942 I noticed that the documentation on the netdev
driver API is unclear and in some cases outright contradicting itself:

> ```
> @return              number of bytes used from @p value
> @return              `< 0` on error, 0 on success
> ```

IMHO this is unacceptable for such a central API where communication

This fixes a few things and also clarifies preconditions:

- Specifies negative `errno`s clearly so all drivers return the same
  when required
- Re-iterates parameter preconditions and special cases within the
  parameter documentation itself (might also help towards #9805?)
- Fixes contradictions within return value documentation
- Adds missing parameter documentation on `init()`.
This commit is contained in:
Martine Lenders 2018-10-02 10:17:45 +02:00 committed by Martine Lenders
parent 99e75948ef
commit aba75be827

View File

@ -299,10 +299,11 @@ typedef struct netdev_driver {
*
* @pre `(dev != NULL) && (iolist != NULL`
*
* @param[in] dev network device descriptor
* @param[in] dev Network device descriptor. Must not be NULL.
* @param[in] iolist io vector list to send
*
* @return number of bytes sent, or `< 0` on error
* @return negative errno on error
* @return number of bytes sent
*/
int (*send)(netdev_t *dev, const iolist_t *iolist);
@ -315,17 +316,22 @@ typedef struct netdev_driver {
* Supposed to be called from
* @ref netdev_t::event_callback "netdev->event_callback()"
*
* If buf == NULL and len == 0, returns the packet size without dropping it.
* If buf == NULL and len > 0, drops the packet and returns the packet size.
* If @p buf == NULL and @p len == 0, returns the packet size without
* dropping it.
* If @p buf == NULL and @p len > 0, drops the packet and returns the packet
* size.
*
* @param[in] dev network device descriptor
* @param[out] buf buffer to write into or NULL
* @param[in] len maximum number of bytes to read
* @param[in] dev network device descriptor. Must not be NULL.
* @param[out] buf buffer to write into or NULL to return the packet
* size.
* @param[in] len maximum number of bytes to read. If @p buf is NULL
* the currently buffered packet is dropped when
* @p len > 0. Must not be 0 when @p buf != NULL.
* @param[out] info status information for the received packet. Might
* be of different type for different netdev devices.
* May be NULL if not needed or applicable.
*
* @return `< 0` on error
* @return `-ENOBUFS` if supplied buffer is too small
* @return number of bytes read if buf != NULL
* @return packet size if buf == NULL
*/
@ -336,7 +342,10 @@ typedef struct netdev_driver {
*
* @pre `(dev != NULL)`
*
* @return `< 0` on error, 0 on success
* @param[in] dev network device descriptor. Must not be NULL.
*
* @return `< 0` on error
* @return 0 on success
*/
int (*init)(netdev_t *dev);
@ -354,7 +363,7 @@ typedef struct netdev_driver {
*
* See receive packet flow description for details.
*
* @param[in] dev network device descriptor
* @param[in] dev network device descriptor. Must not be NULL.
*/
void (*isr)(netdev_t *dev);
@ -362,6 +371,11 @@ typedef struct netdev_driver {
* @brief Get an option value from a given network device
*
* @pre `(dev != NULL)`
* @pre for scalar types of @ref netopt_t @p max_len must be of exactly that
* length (see [netopt documentation](@ref net_netopt) for type)
* @pre for array types of @ref netopt_t @p max_len must greater or equal the
* required length (see [netopt documentation](@ref net_netopt) for
* type)
*
* @param[in] dev network device descriptor
* @param[in] opt option type
@ -369,7 +383,7 @@ typedef struct netdev_driver {
* @param[in] max_len maximal amount of byte that fit into @p value
*
* @return number of bytes written to @p value
* @return `< 0` on error, 0 on success
* @return `-ENOTSUP` if @p opt is not provided by the device
*/
int (*get)(netdev_t *dev, netopt_t opt,
void *value, size_t max_len);
@ -378,14 +392,22 @@ typedef struct netdev_driver {
* @brief Set an option value for a given network device
*
* @pre `(dev != NULL)`
* @pre for scalar types of @ref netopt_t @p value_len must be of exactly
* that length (see [netopt documentation](@ref net_netopt) for type)
* @pre for array types of @ref netopt_t @p value_len must lesser or equal
* the required length (see [netopt documentation](@ref net_netopt) for
* type)
*
* @param[in] dev network device descriptor
* @param[in] opt option type
* @param[in] value value to set
* @param[in] value_len the length of @p value
*
* @return number of bytes used from @p value
* @return `< 0` on error, 0 on success
* @return number of bytes written to @p value
* @return `-ENOTSUP` if @p opt is not configurable for the
* device
* @return `-EINVAL` if @p value is an invalid value with
* regards to @p opt
*/
int (*set)(netdev_t *dev, netopt_t opt,
const void *value, size_t value_len);