[U-Boot] [PATCH V3 1/6] misc: add "call" uclass op

Simon Glass sjg at chromium.org
Sat Aug 6 03:40:35 CEST 2016


Hi Stephen,

On 5 August 2016 at 11:03, Stephen Warren <swarren at wwwdotorg.org> wrote:
> From: Stephen Warren <swarren at nvidia.com>
>
> The call op requests that the callee pass a message to the underlying HW
> or device, wait for a response, and then pass back the response error code
> and message to the callee. It is useful for drivers that represent some
> kind of messaging or IPC channel to a remote device.
>
> Signed-off-by: Stephen Warren <swarren at nvidia.com>
> ---
> v3: New patch.
> ---
>  drivers/misc/misc-uclass.c | 11 +++++++++++
>  include/misc.h             | 35 +++++++++++++++++++++++++++++++++++
>  2 files changed, 46 insertions(+)

Acked-by: Simon Glass <sjg at chromium.org>

One suggestion below.

>
> diff --git a/drivers/misc/misc-uclass.c b/drivers/misc/misc-uclass.c
> index 13a6ea508b14..d9eea3dac5c0 100644
> --- a/drivers/misc/misc-uclass.c
> +++ b/drivers/misc/misc-uclass.c
> @@ -45,6 +45,17 @@ int misc_ioctl(struct udevice *dev, unsigned long request, void *buf)
>         return ops->ioctl(dev, request, buf);
>  }
>
> +int misc_call(struct udevice *dev, int msgid, void *tx_msg, int tx_size,
> +             void *rx_msg, int rx_size)
> +{
> +       const struct misc_ops *ops = device_get_ops(dev);
> +
> +       if (!ops->call)
> +               return -ENOSYS;
> +
> +       return ops->call(dev, msgid, tx_msg, tx_size, rx_msg, rx_size);
> +}
> +
>  UCLASS_DRIVER(misc) = {
>         .id             = UCLASS_MISC,
>         .name           = "misc",
> diff --git a/include/misc.h b/include/misc.h
> index 2b788143b54c..ba417380416a 100644
> --- a/include/misc.h
> +++ b/include/misc.h
> @@ -38,6 +38,27 @@ int misc_write(struct udevice *dev, int offset, void *buf, int size);
>  int misc_ioctl(struct udevice *dev, unsigned long request, void *buf);
>
>  /*
> + * Send a message to the device and wait for a response.
> + *
> + * The caller provides the message type/ID and payload to be sent.
> + * The callee constructs any message header required, transmits it to the
> + * target, waits for a response, checks any error code in the response,
> + * strips any message header from the response, and returns the error code
> + * (or a parsed version of it) and the response message payload.
> + *
> + * @dev: the device.
> + * @msgid: the message ID/number to send.
> + * tx_msg: the request/transmit message payload.
> + * tx_size: the size of the buffer pointed at by tx_msg.
> + * rx_msg: the buffer to receive the response message payload. May be NULL if
> + *         the caller only cares about the error code.
> + * rx_size: the size of the buffer pointed at by rx_msg.
> + * @return 0 if OK, -ve on error

How about returning the number of bytes received? It might be that
rx_size is the receive buffer size, but fewer bytes are returned.

> + */
> +int misc_call(struct udevice *dev, int msgid, void *tx_msg, int tx_size,
> +             void *rx_msg, int rx_size);
> +
> +/*
>   * struct misc_ops - Driver model Misc operations
>   *
>   * The uclass interface is implemented by all miscellaneous devices which
> @@ -74,6 +95,20 @@ struct misc_ops {
>          * @return: 0 if OK, -ve on error
>          */
>         int (*ioctl)(struct udevice *dev, unsigned long request, void *buf);
> +       /*
> +        * Send a message to the device and wait for a response.
> +        *
> +        * @dev: the device
> +        * @msgid: the message ID/number to send
> +        * tx_msg: the request/transmit message payload
> +        * tx_size: the size of the buffer pointed at by tx_msg
> +        * rx_msg: the buffer to receive the response message payload. May be
> +        *         NULL if the caller only cares about the error code.
> +        * rx_size: the size of the buffer pointed at by rx_msg
> +        * @return 0 if OK, -ve on error
> +        */
> +       int (*call)(struct udevice *dev, int msgid, void *tx_msg, int tx_size,
> +                   void *rx_msg, int rx_size);
>  };
>
>  #endif /* _MISC_H_ */
> --
> 2.9.2
>

Regards,
Simon


More information about the U-Boot mailing list