mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-16 08:37:53 +07:00
a24532f8d1
The Broadcom PDC mailbox driver is a mailbox controller that manages data transfers to and from one or more offload engines. Signed-off-by: Rob Rice <rob.rice@broadcom.com> Reviewed-by: Scott Branden <scott.branden@broadcom.com> Reviewed-by: Ray Jui <ray.jui@broadcom.com> Signed-off-by: Jassi Brar <jaswinder.singh@linaro.org>
57 lines
1.2 KiB
C
57 lines
1.2 KiB
C
/*
|
|
* Copyright (C) 2016 Broadcom
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* Common header for Broadcom mailbox messages which is shared across
|
|
* Broadcom SoCs and Broadcom mailbox client drivers.
|
|
*/
|
|
|
|
#ifndef _LINUX_BRCM_MESSAGE_H_
|
|
#define _LINUX_BRCM_MESSAGE_H_
|
|
|
|
#include <linux/scatterlist.h>
|
|
|
|
enum brcm_message_type {
|
|
BRCM_MESSAGE_UNKNOWN = 0,
|
|
BRCM_MESSAGE_SPU,
|
|
BRCM_MESSAGE_SBA,
|
|
BRCM_MESSAGE_MAX,
|
|
};
|
|
|
|
struct brcm_sba_command {
|
|
u64 cmd;
|
|
#define BRCM_SBA_CMD_TYPE_A BIT(0)
|
|
#define BRCM_SBA_CMD_TYPE_B BIT(1)
|
|
#define BRCM_SBA_CMD_TYPE_C BIT(2)
|
|
#define BRCM_SBA_CMD_HAS_RESP BIT(3)
|
|
#define BRCM_SBA_CMD_HAS_OUTPUT BIT(4)
|
|
u64 flags;
|
|
dma_addr_t input;
|
|
size_t input_len;
|
|
dma_addr_t resp;
|
|
size_t resp_len;
|
|
dma_addr_t output;
|
|
size_t output_len;
|
|
};
|
|
|
|
struct brcm_message {
|
|
enum brcm_message_type type;
|
|
union {
|
|
struct {
|
|
struct scatterlist *src;
|
|
struct scatterlist *dst;
|
|
} spu;
|
|
struct {
|
|
struct brcm_sba_command *cmds;
|
|
unsigned int cmds_count;
|
|
} sba;
|
|
};
|
|
void *ctx;
|
|
int error;
|
|
};
|
|
|
|
#endif /* _LINUX_BRCM_MESSAGE_H_ */
|