dma-fence: Add some more fence-merge-unwrap tests
[drm/drm-misc.git] / include / acpi / pcc.h
blob699c1a37b8e7846362bae35477eb5736be15d79e
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3 * PCC (Platform Communications Channel) methods
4 */
6 #ifndef _PCC_H
7 #define _PCC_H
9 #include <linux/mailbox_controller.h>
10 #include <linux/mailbox_client.h>
12 struct pcc_mbox_chan {
13 struct mbox_chan *mchan;
14 u64 shmem_base_addr;
15 void __iomem *shmem;
16 u64 shmem_size;
17 u32 latency;
18 u32 max_access_rate;
19 u16 min_turnaround_time;
22 /* Generic Communications Channel Shared Memory Region */
23 #define PCC_SIGNATURE 0x50434300
24 /* Generic Communications Channel Command Field */
25 #define PCC_CMD_GENERATE_DB_INTR BIT(15)
26 /* Generic Communications Channel Status Field */
27 #define PCC_STATUS_CMD_COMPLETE BIT(0)
28 #define PCC_STATUS_SCI_DOORBELL BIT(1)
29 #define PCC_STATUS_ERROR BIT(2)
30 #define PCC_STATUS_PLATFORM_NOTIFY BIT(3)
31 /* Initiator Responder Communications Channel Flags */
32 #define PCC_CMD_COMPLETION_NOTIFY BIT(0)
34 #define MAX_PCC_SUBSPACES 256
35 #define PCC_ACK_FLAG_MASK 0x1
37 #ifdef CONFIG_PCC
38 extern struct pcc_mbox_chan *
39 pcc_mbox_request_channel(struct mbox_client *cl, int subspace_id);
40 extern void pcc_mbox_free_channel(struct pcc_mbox_chan *chan);
41 extern int pcc_mbox_ioremap(struct mbox_chan *chan);
42 #else
43 static inline struct pcc_mbox_chan *
44 pcc_mbox_request_channel(struct mbox_client *cl, int subspace_id)
46 return ERR_PTR(-ENODEV);
48 static inline void pcc_mbox_free_channel(struct pcc_mbox_chan *chan) { }
49 static inline int pcc_mbox_ioremap(struct mbox_chan *chan)
51 return 0;
53 #endif
55 #endif /* _PCC_H */