From: Sameer Vaze <svaze@qti.qualcomm.com>
To: Fan Zhang <fanzhang.oss@gmail.com>, Ashish Gupta <ashishg@marvell.com>
Cc: dev@dpdk.org, Sameer Vaze <svaze@qti.qualcomm.com>
Subject: [PATCH v3 1/4] compressdev: support for dictionaries and PDCP checksum
Date: Fri, 3 Oct 2025 13:48:58 -0600 [thread overview]
Message-ID: <20251003194901.3375364-1-svaze@qti.qualcomm.com> (raw)
In-Reply-To: <20251003165132.3201643-1-svaze@qti.qualcomm.com>
Adds definitions for PDCP checksums and apis to pass in
dictionaries
Signed-off-by: Sameer Vaze <svaze@qti.qualcomm.com>
---
v3:
* Renamed checksum validation enum
* Added missed comments for window size enum
lib/compressdev/rte_comp.h | 27 +++++++++++++++++++++++++++
1 file changed, 27 insertions(+)
diff --git a/lib/compressdev/rte_comp.h b/lib/compressdev/rte_comp.h
index 96d9b276dd..c5ff708a4c 100644
--- a/lib/compressdev/rte_comp.h
+++ b/lib/compressdev/rte_comp.h
@@ -101,6 +101,10 @@ enum rte_comp_op_status {
* is not an error case. Output data up to op.produced can be used and
* next op in the stream should continue on from op.consumed+1.
*/
+ RTE_COMP_OP_STATUS_CHECKSUM_VALIDATION_FAILED,
+ /**< Checksum validation failed. Either calculated does checksum not match
+ * the one provided or there was an error calculating the checksum
+ */
};
/** Compression Algorithms */
@@ -166,6 +170,10 @@ enum rte_comp_checksum_type {
/**< Generates a xxHash-32 checksum, as used by LZ4.
* https://github.com/Cyan4973/xxHash/blob/dev/doc/xxhash_spec.md
*/
+ RTE_COMP_CHECKSUM_3GPP_PDCP_UDC,
+ /**< Generates checksum as defined under Uplink Data Compression
+ * checksum as defined in the 3GPP PDCP specification
+ */
};
/** Compression Huffman Type - used by DEFLATE algorithm */
@@ -201,6 +209,11 @@ enum rte_comp_flush_flag {
*/
};
+#define DEFLATE_MAX_WINDOW_SIZE (1ULL << 15)
+/** Max window size supported by deflate. Used when setting or getting pre
+ * defined dictionaries
+ */
+
/** Compression transform types */
enum rte_comp_xform_type {
RTE_COMP_COMPRESS,
@@ -228,6 +241,18 @@ enum rte_comp_op_type {
struct rte_comp_deflate_params {
enum rte_comp_huffman huffman;
/**< Compression huffman encoding type */
+ uint8_t *dictionary;
+ /**< Pointer to memory containing dictionary to be used for deflate operations */
+ uint16_t dictionary_len;
+ /**< Length of dictionary to be used */
+};
+
+/** Parameters specific to the inflate algorithm */
+struct rte_comp_inflate_params {
+ uint8_t *dictionary;
+ /**< Pointer to memory containing dictionary to be used for inflate operations */
+ uint16_t dictionary_len;
+ /**< Length of dictionary to be used */
};
/**
@@ -321,6 +346,8 @@ struct rte_comp_decompress_xform {
* setup of stream or private_xform should fail.
*/
union {
+ struct rte_comp_inflate_params inflate;
+ /**< Parameters specific to the deflate algorithm */
struct rte_comp_lz4_params lz4;
/**< Parameters specific to the LZ4 algorithm */
}; /**< Algorithm specific parameters */
--
2.31.1
next prev parent reply other threads:[~2025-10-03 19:49 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-24 16:19 [PATCH 1/3] " Sameer Vaze
2025-09-24 16:19 ` [PATCH 2/3] compress/zlib: " Sameer Vaze
2025-09-24 16:19 ` [PATCH 3/3] app/compress-perf: " Sameer Vaze
2025-09-24 20:24 ` [PATCH 1/3] compressdev: " Patrick Robb
2025-09-26 16:15 ` Sameer Vaze
2025-09-26 20:50 ` Patrick Robb
2025-09-26 20:51 ` Patrick Robb
2025-09-30 20:03 ` [EXTERNAL] " Akhil Goyal
2025-10-02 16:37 ` Sameer Vaze
2025-10-03 7:27 ` Akhil Goyal
2025-10-03 16:56 ` Sameer Vaze
2025-10-03 16:51 ` [PATCH v2 " Sameer Vaze
2025-10-03 16:51 ` [PATCH v2 2/3] compress/zlib: " Sameer Vaze
2025-10-03 18:58 ` [EXTERNAL] " Akhil Goyal
2025-10-03 16:51 ` [PATCH v2 3/3] app/compress-perf: " Sameer Vaze
2025-10-03 19:05 ` [EXTERNAL] " Akhil Goyal
2025-10-03 18:47 ` [EXTERNAL] [PATCH v2 1/3] compressdev: " Akhil Goyal
2025-10-03 19:48 ` Sameer Vaze [this message]
2025-10-03 19:48 ` [PATCH v3 2/4] compress/zlib: " Sameer Vaze
2025-10-03 19:49 ` [PATCH v3 3/4] app/compress-perf: " Sameer Vaze
2025-10-03 19:49 ` [PATCH v3 4/4] doc: add doc for dictionary option Sameer Vaze
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20251003194901.3375364-1-svaze@qti.qualcomm.com \
--to=svaze@qti.qualcomm.com \
--cc=ashishg@marvell.com \
--cc=dev@dpdk.org \
--cc=fanzhang.oss@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).