X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fmisc.h;h=03ef55cdc8870c7a2914581fefcaaf790f68f012;hb=99219664085a35a32688564199e0d2c3dded5077;hp=2b788143b54cc975e2e86d0af92f29ec72e90374;hpb=f5abb40997eb68ef11102b726d8be747b3dd126e;p=u-boot diff --git a/include/misc.h b/include/misc.h index 2b788143b5..03ef55cdc8 100644 --- a/include/misc.h +++ b/include/misc.h @@ -37,6 +37,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 the response message size if OK, -ve on error + */ +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 * @@ -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 the response message size 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_ */