xref: /rk3399_rockchip-uboot/include/misc.h (revision 2bce72c867415b4a0d75f2222eb048451a7832cf)
14395e06eSThomas Chou /*
24395e06eSThomas Chou  * Copyright (C) 2015 Thomas Chou <thomas@wytron.com.tw>
34395e06eSThomas Chou  *
44395e06eSThomas Chou  * SPDX-License-Identifier:	GPL-2.0+
54395e06eSThomas Chou  */
64395e06eSThomas Chou 
74395e06eSThomas Chou #ifndef _MISC_H_
84395e06eSThomas Chou #define _MISC_H_
94395e06eSThomas Chou 
10dbfe5ed5SJoseph Chen #include <asm-generic/ioctl.h>
11dbfe5ed5SJoseph Chen 
12dbfe5ed5SJoseph Chen /*
13dbfe5ed5SJoseph Chen  * Request command to be sent for misc_ioctl().
14dbfe5ed5SJoseph Chen  */
15dbfe5ed5SJoseph Chen #define IOCTL_REQ_START		_IO('m', 0x01)
16dbfe5ed5SJoseph Chen #define IOCTL_REQ_STOP		_IO('m', 0x02)
17dbfe5ed5SJoseph Chen #define IOCTL_REQ_POLL		_IO('m', 0x03)
1874dce6feSJason Zhu #define IOCTL_REQ_CAPABILITY	_IO('m', 0x04)
19656bdb59SJoseph Chen #define IOCTL_REQ_DATA_SIZE	_IO('m', 0x05)
20dbfe5ed5SJoseph Chen 
215b7d3298SJason Zhu enum misc_mode {
225b7d3298SJason Zhu 	DECOM_LZ4	= BIT(0),
235b7d3298SJason Zhu 	DECOM_GZIP	= BIT(1),
245b7d3298SJason Zhu 	DECOM_ZLIB	= BIT(2),
255b7d3298SJason Zhu 	OTP_S		= BIT(3),
265b7d3298SJason Zhu 	OTP_NS		= BIT(4),
275b7d3298SJason Zhu };
285b7d3298SJason Zhu 
294395e06eSThomas Chou /*
304395e06eSThomas Chou  * Read the device to buffer, optional.
314395e06eSThomas Chou  *
324395e06eSThomas Chou  * @dev: the device
334395e06eSThomas Chou  * @offset: offset to read the device
344395e06eSThomas Chou  * @buf: pointer to data buffer
354395e06eSThomas Chou  * @size: data size in bytes to read the device
364395e06eSThomas Chou  * @return: 0 if OK, -ve on error
374395e06eSThomas Chou  */
384395e06eSThomas Chou int misc_read(struct udevice *dev, int offset, void *buf, int size);
394395e06eSThomas Chou /*
404395e06eSThomas Chou  * Write buffer to the device, optional.
414395e06eSThomas Chou  *
424395e06eSThomas Chou  * @dev: the device
434395e06eSThomas Chou  * @offset: offset to write the device
444395e06eSThomas Chou  * @buf: pointer to data buffer
454395e06eSThomas Chou  * @size: data size in bytes to write the device
464395e06eSThomas Chou  * @return: 0 if OK, -ve on error
474395e06eSThomas Chou  */
484395e06eSThomas Chou int misc_write(struct udevice *dev, int offset, void *buf, int size);
494395e06eSThomas Chou /*
504395e06eSThomas Chou  * Assert command to the device, optional.
514395e06eSThomas Chou  *
524395e06eSThomas Chou  * @dev: the device
534395e06eSThomas Chou  * @request: command to be sent to the device
54f5abb409SRobert P. J. Day  * @buf: pointer to buffer related to the request
554395e06eSThomas Chou  * @return: 0 if OK, -ve on error
564395e06eSThomas Chou  */
574395e06eSThomas Chou int misc_ioctl(struct udevice *dev, unsigned long request, void *buf);
584395e06eSThomas Chou 
594395e06eSThomas Chou /*
60b647f554SStephen Warren  * Send a message to the device and wait for a response.
61b647f554SStephen Warren  *
62b647f554SStephen Warren  * The caller provides the message type/ID and payload to be sent.
63b647f554SStephen Warren  * The callee constructs any message header required, transmits it to the
64b647f554SStephen Warren  * target, waits for a response, checks any error code in the response,
65b647f554SStephen Warren  * strips any message header from the response, and returns the error code
66b647f554SStephen Warren  * (or a parsed version of it) and the response message payload.
67b647f554SStephen Warren  *
68b647f554SStephen Warren  * @dev: the device.
69b647f554SStephen Warren  * @msgid: the message ID/number to send.
70b647f554SStephen Warren  * tx_msg: the request/transmit message payload.
71b647f554SStephen Warren  * tx_size: the size of the buffer pointed at by tx_msg.
72b647f554SStephen Warren  * rx_msg: the buffer to receive the response message payload. May be NULL if
73b647f554SStephen Warren  *         the caller only cares about the error code.
74b647f554SStephen Warren  * rx_size: the size of the buffer pointed at by rx_msg.
75b647f554SStephen Warren  * @return the response message size if OK, -ve on error
76b647f554SStephen Warren  */
77b647f554SStephen Warren int misc_call(struct udevice *dev, int msgid, void *tx_msg, int tx_size,
78b647f554SStephen Warren 	      void *rx_msg, int rx_size);
79b647f554SStephen Warren 
80b647f554SStephen Warren /*
81374c241cSJoseph Chen  * Get a misc device by capability
82374c241cSJoseph Chen  *
83374c241cSJoseph Chen  * The caller can get a misc device according to capability request, the driver
84374c241cSJoseph Chen  * must implement the IOCTL_REQ_CAPABILITY callback.
85374c241cSJoseph Chen  *
86374c241cSJoseph Chen  * @capability: the value of enum misc_mode.
87374c241cSJoseph Chen  * @return the require device if OK, NULL on error
88374c241cSJoseph Chen  */
89374c241cSJoseph Chen struct udevice *misc_get_device_by_capability(u32 capability);
90374c241cSJoseph Chen 
91374c241cSJoseph Chen /*
924395e06eSThomas Chou  * struct misc_ops - Driver model Misc operations
934395e06eSThomas Chou  *
944395e06eSThomas Chou  * The uclass interface is implemented by all miscellaneous devices which
954395e06eSThomas Chou  * use driver model.
964395e06eSThomas Chou  */
974395e06eSThomas Chou struct misc_ops {
984395e06eSThomas Chou 	/*
994395e06eSThomas Chou 	 * Read the device to buffer, optional.
1004395e06eSThomas Chou 	 *
1014395e06eSThomas Chou 	 * @dev: the device
1024395e06eSThomas Chou 	 * @offset: offset to read the device
1034395e06eSThomas Chou 	 * @buf: pointer to data buffer
1044395e06eSThomas Chou 	 * @size: data size in bytes to read the device
1054395e06eSThomas Chou 	 * @return: 0 if OK, -ve on error
1064395e06eSThomas Chou 	 */
1074395e06eSThomas Chou 	int (*read)(struct udevice *dev, int offset, void *buf, int size);
1084395e06eSThomas Chou 	/*
1094395e06eSThomas Chou 	 * Write buffer to the device, optional.
1104395e06eSThomas Chou 	 *
1114395e06eSThomas Chou 	 * @dev: the device
1124395e06eSThomas Chou 	 * @offset: offset to write the device
1134395e06eSThomas Chou 	 * @buf: pointer to data buffer
1144395e06eSThomas Chou 	 * @size: data size in bytes to write the device
1154395e06eSThomas Chou 	 * @return: 0 if OK, -ve on error
1164395e06eSThomas Chou 	 */
1174395e06eSThomas Chou 	int (*write)(struct udevice *dev, int offset, const void *buf,
1184395e06eSThomas Chou 		     int size);
1194395e06eSThomas Chou 	/*
1204395e06eSThomas Chou 	 * Assert command to the device, optional.
1214395e06eSThomas Chou 	 *
1224395e06eSThomas Chou 	 * @dev: the device
1234395e06eSThomas Chou 	 * @request: command to be sent to the device
124f5abb409SRobert P. J. Day 	 * @buf: pointer to buffer related to the request
1254395e06eSThomas Chou 	 * @return: 0 if OK, -ve on error
1264395e06eSThomas Chou 	 */
1274395e06eSThomas Chou 	int (*ioctl)(struct udevice *dev, unsigned long request, void *buf);
128b647f554SStephen Warren 	/*
129b647f554SStephen Warren 	 * Send a message to the device and wait for a response.
130b647f554SStephen Warren 	 *
131b647f554SStephen Warren 	 * @dev: the device
132b647f554SStephen Warren 	 * @msgid: the message ID/number to send
133b647f554SStephen Warren 	 * tx_msg: the request/transmit message payload
134b647f554SStephen Warren 	 * tx_size: the size of the buffer pointed at by tx_msg
135b647f554SStephen Warren 	 * rx_msg: the buffer to receive the response message payload. May be
136b647f554SStephen Warren 	 *         NULL if the caller only cares about the error code.
137b647f554SStephen Warren 	 * rx_size: the size of the buffer pointed at by rx_msg
138b647f554SStephen Warren 	 * @return the response message size if OK, -ve on error
139b647f554SStephen Warren 	 */
140b647f554SStephen Warren 	int (*call)(struct udevice *dev, int msgid, void *tx_msg, int tx_size,
141b647f554SStephen Warren 		    void *rx_msg, int rx_size);
1424395e06eSThomas Chou };
1434395e06eSThomas Chou 
1441cef1b20SJoseph Chen /* generic layer for otp */
1451cef1b20SJoseph Chen struct udevice *misc_otp_get_device(u32 capability);
1461cef1b20SJoseph Chen int misc_otp_read(struct udevice *dev, int offset, void *buf, int size);
1471cef1b20SJoseph Chen int misc_otp_write(struct udevice *dev, int offset, const void *buf, int size);
1481cef1b20SJoseph Chen 
1491cef1b20SJoseph Chen /* generic layer for decompress */
1501cef1b20SJoseph Chen struct decom_param {
1511cef1b20SJoseph Chen 	unsigned long addr_src;
1521cef1b20SJoseph Chen 	unsigned long addr_dst;
153e1e885d3SJoseph Chen 	u64 size_src;	/* compressed */
154e1e885d3SJoseph Chen 	u64 size_dst;	/* decompressed, to be filled for output */
1551cef1b20SJoseph Chen 	enum misc_mode mode;
156*2bce72c8SJoseph Chen 	u32 flags;
1571cef1b20SJoseph Chen };
1581cef1b20SJoseph Chen 
159*2bce72c8SJoseph Chen /* function flags for decompress */
160*2bce72c8SJoseph Chen #define DCOMP_FLG_IRQ_ONESHOT	BIT(0)
161*2bce72c8SJoseph Chen 
162656bdb59SJoseph Chen void misc_decompress_async(u8 comp);
163656bdb59SJoseph Chen void misc_decompress_sync(u8 comp);
164656bdb59SJoseph Chen int misc_decompress_cleanup(void);
165656bdb59SJoseph Chen int misc_decompress_process(unsigned long dst, unsigned long src,
166656bdb59SJoseph Chen 			    unsigned long src_len, u32 cap, bool sync,
167*2bce72c8SJoseph Chen 			    u64 *size, u32 flags);
1684395e06eSThomas Chou #endif	/* _MISC_H_ */
169