mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 09:55:29 +07:00
97fb5e8d9b
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 and only version 2 as published by the free software foundation this program is distributed in the hope that it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 294 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Alexios Zavras <alexios.zavras@intel.com> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190529141900.825281744@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
48 lines
1.3 KiB
C
48 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (c) 2011-2014, The Linux Foundation. All rights reserved.
|
|
*/
|
|
|
|
#ifndef _DMA_H_
|
|
#define _DMA_H_
|
|
|
|
#include <linux/dmaengine.h>
|
|
|
|
/* maximum data transfer block size between BAM and CE */
|
|
#define QCE_BAM_BURST_SIZE 64
|
|
|
|
#define QCE_AUTHIV_REGS_CNT 16
|
|
#define QCE_AUTH_BYTECOUNT_REGS_CNT 4
|
|
#define QCE_CNTRIV_REGS_CNT 4
|
|
|
|
struct qce_result_dump {
|
|
u32 auth_iv[QCE_AUTHIV_REGS_CNT];
|
|
u32 auth_byte_count[QCE_AUTH_BYTECOUNT_REGS_CNT];
|
|
u32 encr_cntr_iv[QCE_CNTRIV_REGS_CNT];
|
|
u32 status;
|
|
u32 status2;
|
|
};
|
|
|
|
#define QCE_IGNORE_BUF_SZ (2 * QCE_BAM_BURST_SIZE)
|
|
#define QCE_RESULT_BUF_SZ \
|
|
ALIGN(sizeof(struct qce_result_dump), QCE_BAM_BURST_SIZE)
|
|
|
|
struct qce_dma_data {
|
|
struct dma_chan *txchan;
|
|
struct dma_chan *rxchan;
|
|
struct qce_result_dump *result_buf;
|
|
void *ignore_buf;
|
|
};
|
|
|
|
int qce_dma_request(struct device *dev, struct qce_dma_data *dma);
|
|
void qce_dma_release(struct qce_dma_data *dma);
|
|
int qce_dma_prep_sgs(struct qce_dma_data *dma, struct scatterlist *sg_in,
|
|
int in_ents, struct scatterlist *sg_out, int out_ents,
|
|
dma_async_tx_callback cb, void *cb_param);
|
|
void qce_dma_issue_pending(struct qce_dma_data *dma);
|
|
int qce_dma_terminate_all(struct qce_dma_data *dma);
|
|
struct scatterlist *
|
|
qce_sgtable_add(struct sg_table *sgt, struct scatterlist *sg_add);
|
|
|
|
#endif /* _DMA_H_ */
|