xref: /linux/drivers/media/platform/amd/isp4/isp4_interface.h (revision 8c13415c8a4383447c21ec832b20b3b283f0e01a)
1*4c5feef6SBin Du /* SPDX-License-Identifier: GPL-2.0+ */
2*4c5feef6SBin Du /*
3*4c5feef6SBin Du  * Copyright (C) 2025 Advanced Micro Devices, Inc.
4*4c5feef6SBin Du  */
5*4c5feef6SBin Du 
6*4c5feef6SBin Du #ifndef _ISP4_INTERFACE_H_
7*4c5feef6SBin Du #define _ISP4_INTERFACE_H_
8*4c5feef6SBin Du 
9*4c5feef6SBin Du #include <drm/amd/isp.h>
10*4c5feef6SBin Du #include <linux/mutex.h>
11*4c5feef6SBin Du #include <linux/platform_device.h>
12*4c5feef6SBin Du #include <linux/spinlock.h>
13*4c5feef6SBin Du 
14*4c5feef6SBin Du struct isp4fw_resp;
15*4c5feef6SBin Du 
16*4c5feef6SBin Du #define ISP4IF_RB_MAX 25
17*4c5feef6SBin Du #define ISP4IF_RESP_CHAN_TO_RB_OFFSET 9
18*4c5feef6SBin Du #define ISP4IF_RB_PMBMAP_MEM_SIZE (SZ_16M - 1)
19*4c5feef6SBin Du #define ISP4IF_RB_PMBMAP_MEM_CHUNK \
20*4c5feef6SBin Du 	(ISP4IF_RB_PMBMAP_MEM_SIZE / (ISP4IF_RB_MAX - 1))
21*4c5feef6SBin Du #define ISP4IF_HOST2FW_COMMAND_SIZE sizeof(struct isp4fw_cmd)
22*4c5feef6SBin Du #define ISP4IF_MAX_NUM_HOST2FW_COMMAND 40
23*4c5feef6SBin Du #define ISP4IF_FW_CMD_BUF_SIZE \
24*4c5feef6SBin Du 	(ISP4IF_MAX_NUM_HOST2FW_COMMAND * ISP4IF_HOST2FW_COMMAND_SIZE)
25*4c5feef6SBin Du #define ISP4IF_RB_FULL_SLEEP_US (33 * USEC_PER_MSEC)
26*4c5feef6SBin Du #define ISP4IF_RB_FULL_TIMEOUT_US (10 * ISP4IF_RB_FULL_SLEEP_US)
27*4c5feef6SBin Du 
28*4c5feef6SBin Du #define ISP4IF_META_INFO_BUF_SIZE ALIGN(sizeof(struct isp4fw_meta_info), 0x8000)
29*4c5feef6SBin Du #define ISP4IF_MAX_STREAM_BUF_COUNT 8
30*4c5feef6SBin Du 
31*4c5feef6SBin Du #define ISP4IF_FW_LOG_RINGBUF_SIZE SZ_2M
32*4c5feef6SBin Du 
33*4c5feef6SBin Du enum isp4if_stream_id {
34*4c5feef6SBin Du 	ISP4IF_STREAM_ID_GLOBAL = 0,
35*4c5feef6SBin Du 	ISP4IF_STREAM_ID_1 = 1,
36*4c5feef6SBin Du 	ISP4IF_STREAM_ID_MAX = 4
37*4c5feef6SBin Du };
38*4c5feef6SBin Du 
39*4c5feef6SBin Du enum isp4if_status {
40*4c5feef6SBin Du 	ISP4IF_STATUS_PWR_OFF,
41*4c5feef6SBin Du 	ISP4IF_STATUS_PWR_ON,
42*4c5feef6SBin Du 	ISP4IF_STATUS_FW_RUNNING,
43*4c5feef6SBin Du 	ISP4IF_FSM_STATUS_MAX
44*4c5feef6SBin Du };
45*4c5feef6SBin Du 
46*4c5feef6SBin Du struct isp4if_gpu_mem_info {
47*4c5feef6SBin Du 	u64 mem_size;
48*4c5feef6SBin Du 	u64 gpu_mc_addr;
49*4c5feef6SBin Du 	void *sys_addr;
50*4c5feef6SBin Du 	void *mem_handle;
51*4c5feef6SBin Du };
52*4c5feef6SBin Du 
53*4c5feef6SBin Du struct isp4if_img_buf_info {
54*4c5feef6SBin Du 	struct {
55*4c5feef6SBin Du 		void *sys_addr;
56*4c5feef6SBin Du 		u64 mc_addr;
57*4c5feef6SBin Du 		u32 len;
58*4c5feef6SBin Du 	} planes[3];
59*4c5feef6SBin Du };
60*4c5feef6SBin Du 
61*4c5feef6SBin Du struct isp4if_img_buf_node {
62*4c5feef6SBin Du 	struct list_head node;
63*4c5feef6SBin Du 	struct isp4if_img_buf_info buf_info;
64*4c5feef6SBin Du };
65*4c5feef6SBin Du 
66*4c5feef6SBin Du struct isp4if_cmd_element {
67*4c5feef6SBin Du 	struct list_head list;
68*4c5feef6SBin Du 	u32 seq_num;
69*4c5feef6SBin Du 	u32 cmd_id;
70*4c5feef6SBin Du 	struct completion cmd_done;
71*4c5feef6SBin Du 	atomic_t refcnt;
72*4c5feef6SBin Du };
73*4c5feef6SBin Du 
74*4c5feef6SBin Du struct isp4_interface {
75*4c5feef6SBin Du 	struct device *dev;
76*4c5feef6SBin Du 	void __iomem *mmio;
77*4c5feef6SBin Du 
78*4c5feef6SBin Du 	spinlock_t cmdq_lock; /* used for cmdq access */
79*4c5feef6SBin Du 	spinlock_t bufq_lock; /* used for bufq access */
80*4c5feef6SBin Du 	struct mutex isp4if_mutex; /* used to send fw cmd and read fw log */
81*4c5feef6SBin Du 
82*4c5feef6SBin Du 	struct list_head cmdq; /* commands sent to fw */
83*4c5feef6SBin Du 	struct list_head bufq; /* buffers sent to fw */
84*4c5feef6SBin Du 
85*4c5feef6SBin Du 	enum isp4if_status status;
86*4c5feef6SBin Du 	u32 host2fw_seq_num;
87*4c5feef6SBin Du 
88*4c5feef6SBin Du 	/* ISP fw buffers */
89*4c5feef6SBin Du 	struct isp4if_gpu_mem_info *fw_log_buf;
90*4c5feef6SBin Du 	struct isp4if_gpu_mem_info *fw_cmd_resp_buf;
91*4c5feef6SBin Du 	struct isp4if_gpu_mem_info *fw_mem_pool;
92*4c5feef6SBin Du 	struct isp4if_gpu_mem_info *meta_info_buf[ISP4IF_MAX_STREAM_BUF_COUNT];
93*4c5feef6SBin Du };
94*4c5feef6SBin Du 
95*4c5feef6SBin Du static inline void isp4if_split_addr64(u64 addr, u32 *lo, u32 *hi)
96*4c5feef6SBin Du {
97*4c5feef6SBin Du 	if (lo)
98*4c5feef6SBin Du 		*lo = addr & 0xffffffff;
99*4c5feef6SBin Du 
100*4c5feef6SBin Du 	if (hi)
101*4c5feef6SBin Du 		*hi = addr >> 32;
102*4c5feef6SBin Du }
103*4c5feef6SBin Du 
104*4c5feef6SBin Du static inline u64 isp4if_join_addr64(u32 lo, u32 hi)
105*4c5feef6SBin Du {
106*4c5feef6SBin Du 	return (((u64)hi) << 32) | (u64)lo;
107*4c5feef6SBin Du }
108*4c5feef6SBin Du 
109*4c5feef6SBin Du int isp4if_f2h_resp(struct isp4_interface *ispif, enum isp4if_stream_id stream,
110*4c5feef6SBin Du 		    struct isp4fw_resp *resp);
111*4c5feef6SBin Du 
112*4c5feef6SBin Du int isp4if_send_command(struct isp4_interface *ispif, u32 cmd_id,
113*4c5feef6SBin Du 			const void *package, u32 package_size);
114*4c5feef6SBin Du 
115*4c5feef6SBin Du int isp4if_send_command_sync(struct isp4_interface *ispif, u32 cmd_id,
116*4c5feef6SBin Du 			     const void *package, u32 package_size);
117*4c5feef6SBin Du 
118*4c5feef6SBin Du struct isp4if_cmd_element *isp4if_rm_cmd_from_cmdq(struct isp4_interface *ispif,
119*4c5feef6SBin Du 						   u32 seq_num, u32 cmd_id);
120*4c5feef6SBin Du 
121*4c5feef6SBin Du void isp4if_clear_cmdq(struct isp4_interface *ispif);
122*4c5feef6SBin Du 
123*4c5feef6SBin Du void isp4if_clear_bufq(struct isp4_interface *ispif);
124*4c5feef6SBin Du 
125*4c5feef6SBin Du void isp4if_dealloc_buffer_node(struct isp4if_img_buf_node *buf_node);
126*4c5feef6SBin Du 
127*4c5feef6SBin Du struct isp4if_img_buf_node *
128*4c5feef6SBin Du isp4if_alloc_buffer_node(struct isp4if_img_buf_info *buf_info);
129*4c5feef6SBin Du 
130*4c5feef6SBin Du struct isp4if_img_buf_node *isp4if_dequeue_buffer(struct isp4_interface *ispif);
131*4c5feef6SBin Du 
132*4c5feef6SBin Du int isp4if_queue_buffer(struct isp4_interface *ispif,
133*4c5feef6SBin Du 			struct isp4if_img_buf_node *buf_node);
134*4c5feef6SBin Du 
135*4c5feef6SBin Du int isp4if_stop(struct isp4_interface *ispif);
136*4c5feef6SBin Du 
137*4c5feef6SBin Du int isp4if_start(struct isp4_interface *ispif);
138*4c5feef6SBin Du 
139*4c5feef6SBin Du int isp4if_deinit(struct isp4_interface *ispif);
140*4c5feef6SBin Du 
141*4c5feef6SBin Du int isp4if_init(struct isp4_interface *ispif, struct device *dev,
142*4c5feef6SBin Du 		void __iomem *isp_mmio);
143*4c5feef6SBin Du 
144*4c5feef6SBin Du #endif /* _ISP4_INTERFACE_H_ */
145