summaryrefslogtreecommitdiff
path: root/include/acpi/pcc.h
blob: 9af3b502f83952d8662492de42c049c0af74f69f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * PCC (Platform Communications Channel) methods
 */

#ifndef _PCC_H
#define _PCC_H

#include <linux/mailbox_controller.h>
#include <linux/mailbox_client.h>

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;

	/* Set to true to indicate that the mailbox should manage
	 * writing the dat to the shared buffer. This differs from
	 * the case where the drivesr are writing to the buffer and
	 * using send_data only to  ring the doorbell.  If this flag
	 * is set, then the void * data parameter of send_data must
	 * point to a kernel-memory buffer formatted in accordance with
	 * the PCC specification.
	 *
	 * The active buffer management will include reading the
	 * notify_on_completion flag, and will then
	 * call mbox_chan_txdone when the acknowledgment interrupt is
	 * received.
	 */
	bool manage_writes;

	/* Optional callback that allows the driver
	 * to allocate the memory used for receiving
	 * messages.  The return value is the location
	 * inside the buffer where the mailbox should write the data.
	 */
	void *(*rx_alloc)(struct mbox_client *cl,  int size);
};

struct pcc_header {
	u32 signature;
	u32 flags;
	u32 length;
	u32 command;
};

/* 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

#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);
#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) { }
#endif

#endif /* _PCC_H */