2019-06-01 10:08:55 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2016-06-16 14:09:38 -07:00
|
|
|
/*
|
|
|
|
* PCC (Platform Communications Channel) methods
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _PCC_H
|
|
|
|
#define _PCC_H
|
|
|
|
|
|
|
|
#include <linux/mailbox_controller.h>
|
|
|
|
#include <linux/mailbox_client.h>
|
|
|
|
|
2021-09-17 14:33:49 +01:00
|
|
|
struct pcc_mbox_chan {
|
|
|
|
struct mbox_chan *mchan;
|
|
|
|
u64 shmem_base_addr;
|
2024-11-20 14:02:14 -05:00
|
|
|
void __iomem *shmem;
|
2021-09-17 14:33:49 +01:00
|
|
|
u64 shmem_size;
|
|
|
|
u32 latency;
|
|
|
|
u32 max_access_rate;
|
|
|
|
u16 min_turnaround_time;
|
|
|
|
};
|
|
|
|
|
2023-09-27 17:26:10 +01:00
|
|
|
/* 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)
|
|
|
|
|
2017-10-11 08:54:57 +00:00
|
|
|
#define MAX_PCC_SUBSPACES 256
|
2024-11-20 14:02:14 -05:00
|
|
|
#define PCC_ACK_FLAG_MASK 0x1
|
2023-09-27 17:26:10 +01:00
|
|
|
|
2016-06-16 14:09:38 -07:00
|
|
|
#ifdef CONFIG_PCC
|
2021-09-17 14:33:50 +01:00
|
|
|
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);
|
2024-11-20 14:02:14 -05:00
|
|
|
extern int pcc_mbox_ioremap(struct mbox_chan *chan);
|
2016-06-16 14:09:38 -07:00
|
|
|
#else
|
2021-09-17 14:33:50 +01:00
|
|
|
static inline struct pcc_mbox_chan *
|
|
|
|
pcc_mbox_request_channel(struct mbox_client *cl, int subspace_id)
|
2016-06-16 14:09:38 -07:00
|
|
|
{
|
2016-10-14 16:20:21 -07:00
|
|
|
return ERR_PTR(-ENODEV);
|
2016-06-16 14:09:38 -07:00
|
|
|
}
|
2021-09-17 14:33:50 +01:00
|
|
|
static inline void pcc_mbox_free_channel(struct pcc_mbox_chan *chan) { }
|
2024-11-20 14:02:14 -05:00
|
|
|
static inline int pcc_mbox_ioremap(struct mbox_chan *chan)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
};
|
2016-06-16 14:09:38 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _PCC_H */
|