]> git.proxmox.com Git - ceph.git/blame - ceph/src/seastar/dpdk/drivers/crypto/dpaa2_sec/hw/desc/common.h
import 15.2.0 Octopus source
[ceph.git] / ceph / src / seastar / dpdk / drivers / crypto / dpaa2_sec / hw / desc / common.h
CommitLineData
9f95a23c 1/* SPDX-License-Identifier: (BSD-3-Clause OR GPL-2.0)
11fdf7f2
TL
2 *
3 * Copyright 2008-2016 Freescale Semiconductor Inc.
9f95a23c 4 * Copyright 2016 NXP
11fdf7f2 5 *
11fdf7f2
TL
6 */
7
8#ifndef __DESC_COMMON_H__
9#define __DESC_COMMON_H__
10
11#include "hw/rta.h"
12
13/**
14 * DOC: Shared Descriptor Constructors - shared structures
15 *
16 * Data structures shared between algorithm, protocol implementations.
17 */
18
19/**
20 * struct alginfo - Container for algorithm details
21 * @algtype: algorithm selector; for valid values, see documentation of the
22 * functions where it is used.
23 * @keylen: length of the provided algorithm key, in bytes
24 * @key: address where algorithm key resides; virtual address if key_type is
25 * RTA_DATA_IMM, physical (bus) address if key_type is RTA_DATA_PTR or
26 * RTA_DATA_IMM_DMA.
27 * @key_enc_flags: key encryption flags; see encrypt_flags parameter of KEY
28 * command for valid values.
29 * @key_type: enum rta_data_type
30 * @algmode: algorithm mode selector; for valid values, see documentation of the
31 * functions where it is used.
32 */
33struct alginfo {
34 uint32_t algtype;
35 uint32_t keylen;
36 uint64_t key;
37 uint32_t key_enc_flags;
38 enum rta_data_type key_type;
39 uint16_t algmode;
40};
41
42#define INLINE_KEY(alginfo) inline_flags(alginfo->key_type)
43
44/**
45 * rta_inline_query() - Provide indications on which data items can be inlined
46 * and which shall be referenced in a shared descriptor.
47 * @sd_base_len: Shared descriptor base length - bytes consumed by the commands,
48 * excluding the data items to be inlined (or corresponding
49 * pointer if an item is not inlined). Each cnstr_* function that
50 * generates descriptors should have a define mentioning
51 * corresponding length.
52 * @jd_len: Maximum length of the job descriptor(s) that will be used
53 * together with the shared descriptor.
54 * @data_len: Array of lengths of the data items trying to be inlined
55 * @inl_mask: 32bit mask with bit x = 1 if data item x can be inlined, 0
56 * otherwise.
57 * @count: Number of data items (size of @data_len array); must be <= 32
58 *
59 * Return: 0 if data can be inlined / referenced, negative value if not. If 0,
60 * check @inl_mask for details.
61 */
62static inline int
63rta_inline_query(unsigned int sd_base_len,
64 unsigned int jd_len,
65 unsigned int *data_len,
66 uint32_t *inl_mask,
67 unsigned int count)
68{
69 int rem_bytes = (int)(CAAM_DESC_BYTES_MAX - sd_base_len - jd_len);
70 unsigned int i;
71
72 *inl_mask = 0;
73 for (i = 0; (i < count) && (rem_bytes > 0); i++) {
74 if (rem_bytes - (int)(data_len[i] +
75 (count - i - 1) * CAAM_PTR_SZ) >= 0) {
76 rem_bytes -= data_len[i];
77 *inl_mask |= (1 << i);
78 } else {
79 rem_bytes -= CAAM_PTR_SZ;
80 }
81 }
82
83 return (rem_bytes >= 0) ? 0 : -1;
84}
85
86/**
87 * struct protcmd - Container for Protocol Operation Command fields
88 * @optype: command type
89 * @protid: protocol Identifier
90 * @protinfo: protocol Information
91 */
92struct protcmd {
93 uint32_t optype;
94 uint32_t protid;
95 uint16_t protinfo;
96};
97
98#endif /* __DESC_COMMON_H__ */