/* SPDX-License-Identifier: GPL-2.0-only */ /* * PCC (Platform Communications Channel) methods */ #ifndef _PCC_H #define _PCC_H #include #include struct pcc_mbox_chan { struct mbox_chan *mchan; u64 shmem_base_addr; void __iomem *shmem; u64 shmem_size; u32 latency; u32 max_access_rate; u16 min_turnaround_time; }; /* Generic Communications Channel Shared Memory Region */ #define PCC_SIGNATURE 0x50434300 /* Generic Communications Channel Command Field */ #define PCC_CMD_GENERATE_DB_INTR BIT(15) /* Generic Communications Channel Status Field */ #define PCC_STATUS_CMD_COMPLETE BIT(0) #define PCC_STATUS_SCI_DOORBELL BIT(1) #define PCC_STATUS_ERROR BIT(2) #define PCC_STATUS_PLATFORM_NOTIFY BIT(3) /* Initiator Responder Communications Channel Flags */ #define PCC_CMD_COMPLETION_NOTIFY BIT(0) #define MAX_PCC_SUBSPACES 256 #define PCC_ACK_FLAG_MASK 0x1 #ifdef CONFIG_PCC extern struct pcc_mbox_chan * pcc_mbox_request_channel(struct mbox_client *cl, int subspace_id); extern void pcc_mbox_free_channel(struct pcc_mbox_chan *chan); extern int pcc_mbox_ioremap(struct mbox_chan *chan); #else static inline struct pcc_mbox_chan * pcc_mbox_request_channel(struct mbox_client *cl, int subspace_id) { return ERR_PTR(-ENODEV); } static inline void pcc_mbox_free_channel(struct pcc_mbox_chan *chan) { } static inline int pcc_mbox_ioremap(struct mbox_chan *chan) { return 0; }; #endif #endif /* _PCC_H */