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