blob: 18da8211547683d70f3b9495cccf418fe90451fa [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Rob Ricea24532f2016-06-30 15:59:23 -04002/*
3 * Copyright (C) 2016 Broadcom
4 *
Rob Ricea24532f2016-06-30 15:59:23 -04005 * Common header for Broadcom mailbox messages which is shared across
6 * Broadcom SoCs and Broadcom mailbox client drivers.
7 */
8
9#ifndef _LINUX_BRCM_MESSAGE_H_
10#define _LINUX_BRCM_MESSAGE_H_
11
12#include <linux/scatterlist.h>
13
14enum brcm_message_type {
15 BRCM_MESSAGE_UNKNOWN = 0,
Anup Pateldbc049e2017-03-15 12:10:00 +053016 BRCM_MESSAGE_BATCH,
Rob Ricea24532f2016-06-30 15:59:23 -040017 BRCM_MESSAGE_SPU,
18 BRCM_MESSAGE_SBA,
19 BRCM_MESSAGE_MAX,
20};
21
22struct brcm_sba_command {
23 u64 cmd;
Anup Pateldbc049e2017-03-15 12:10:00 +053024 u64 *cmd_dma;
25 dma_addr_t cmd_dma_addr;
Rob Ricea24532f2016-06-30 15:59:23 -040026#define BRCM_SBA_CMD_TYPE_A BIT(0)
27#define BRCM_SBA_CMD_TYPE_B BIT(1)
28#define BRCM_SBA_CMD_TYPE_C BIT(2)
29#define BRCM_SBA_CMD_HAS_RESP BIT(3)
30#define BRCM_SBA_CMD_HAS_OUTPUT BIT(4)
31 u64 flags;
Rob Ricea24532f2016-06-30 15:59:23 -040032 dma_addr_t resp;
33 size_t resp_len;
Anup Pateldbc049e2017-03-15 12:10:00 +053034 dma_addr_t data;
35 size_t data_len;
Rob Ricea24532f2016-06-30 15:59:23 -040036};
37
38struct brcm_message {
39 enum brcm_message_type type;
40 union {
41 struct {
Anup Pateldbc049e2017-03-15 12:10:00 +053042 struct brcm_message *msgs;
43 unsigned int msgs_queued;
44 unsigned int msgs_count;
45 } batch;
46 struct {
Rob Ricea24532f2016-06-30 15:59:23 -040047 struct scatterlist *src;
48 struct scatterlist *dst;
49 } spu;
50 struct {
51 struct brcm_sba_command *cmds;
52 unsigned int cmds_count;
53 } sba;
54 };
55 void *ctx;
56 int error;
57};
58
59#endif /* _LINUX_BRCM_MESSAGE_H_ */