Yann Collet | 32fb407 | 2017-08-18 16:52:05 -0700 | [diff] [blame] | 1 | /* |
Elliott Hughes | 44aba64 | 2023-09-12 20:18:59 +0000 | [diff] [blame] | 2 | * Copyright (c) Meta Platforms, Inc. and affiliates. |
Yann Collet | 32fb407 | 2017-08-18 16:52:05 -0700 | [diff] [blame] | 3 | * All rights reserved. |
| 4 | * |
| 5 | * This source code is licensed under both the BSD-style license (found in the |
| 6 | * LICENSE file in the root directory of this source tree) and the GPLv2 (found |
| 7 | * in the COPYING file in the root directory of this source tree). |
Yann Collet | 3128e03 | 2017-09-08 00:09:23 -0700 | [diff] [blame] | 8 | * You may select, at your option, one of the above-listed licenses. |
Yann Collet | 32fb407 | 2017-08-18 16:52:05 -0700 | [diff] [blame] | 9 | */ |
| 10 | |
| 11 | |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 12 | #include <stdio.h> |
| 13 | #include <stddef.h> |
| 14 | #include <stdlib.h> |
Nick Terrell | 5cc85cf | 2016-12-10 19:31:55 -0800 | [diff] [blame] | 15 | #include <stdint.h> |
Yann Collet | c261f71 | 2016-12-12 00:25:07 +0100 | [diff] [blame] | 16 | #include "mem.h" |
| 17 | #define ZSTD_STATIC_LINKING_ONLY |
| 18 | #include "zstd.h" |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 19 | |
Yann Collet | ff36513 | 2018-09-27 18:24:41 -0700 | [diff] [blame] | 20 | static int |
| 21 | compress(ZSTD_CStream *ctx, ZSTD_outBuffer out, const void *data, size_t size) |
| 22 | { |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 23 | ZSTD_inBuffer in = { data, size, 0 }; |
| 24 | while (in.pos < in.size) { |
| 25 | ZSTD_outBuffer tmp = out; |
| 26 | const size_t rc = ZSTD_compressStream(ctx, &tmp, &in); |
Yann Collet | ff36513 | 2018-09-27 18:24:41 -0700 | [diff] [blame] | 27 | if (ZSTD_isError(rc)) return 1; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 28 | } |
Yann Collet | ff36513 | 2018-09-27 18:24:41 -0700 | [diff] [blame] | 29 | { ZSTD_outBuffer tmp = out; |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 30 | const size_t rc = ZSTD_flushStream(ctx, &tmp); |
| 31 | if (rc != 0) { return 1; } |
| 32 | } |
| 33 | return 0; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 34 | } |
| 35 | |
Yann Collet | ff36513 | 2018-09-27 18:24:41 -0700 | [diff] [blame] | 36 | int main(int argc, const char** argv) |
| 37 | { |
| 38 | ZSTD_CStream* ctx; |
Elliott Hughes | 44aba64 | 2023-09-12 20:18:59 +0000 | [diff] [blame] | 39 | unsigned windowLog = 18; |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 40 | (void)argc; |
| 41 | (void)argv; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 42 | /* Create stream */ |
Elliott Hughes | 44aba64 | 2023-09-12 20:18:59 +0000 | [diff] [blame] | 43 | ctx = ZSTD_createCCtx(); |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 44 | if (!ctx) { return 1; } |
| 45 | /* Set parameters */ |
Elliott Hughes | 44aba64 | 2023-09-12 20:18:59 +0000 | [diff] [blame] | 46 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_windowLog, windowLog))) |
| 47 | return 2; |
| 48 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_chainLog, 13))) |
| 49 | return 2; |
| 50 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_hashLog, 14))) |
| 51 | return 2; |
| 52 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_searchLog, 1))) |
| 53 | return 2; |
| 54 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_minMatch, 7))) |
| 55 | return 2; |
| 56 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_targetLength, 16))) |
| 57 | return 2; |
| 58 | if (ZSTD_isError(ZSTD_CCtx_setParameter(ctx, ZSTD_c_strategy, ZSTD_fast))) |
| 59 | return 2; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 60 | { |
Nick Terrell | 5cc85cf | 2016-12-10 19:31:55 -0800 | [diff] [blame] | 61 | U64 compressed = 0; |
| 62 | const U64 toCompress = ((U64)1) << 33; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 63 | const size_t size = 1 << windowLog; |
| 64 | size_t pos = 0; |
| 65 | char *srcBuffer = (char*) malloc(1 << windowLog); |
| 66 | char *dstBuffer = (char*) malloc(ZSTD_compressBound(1 << windowLog)); |
| 67 | ZSTD_outBuffer out = { dstBuffer, ZSTD_compressBound(1 << windowLog), 0 }; |
| 68 | const char match[] = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; |
| 69 | const size_t randomData = (1 << windowLog) - 2*sizeof(match); |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 70 | size_t i; |
Yann Collet | c261f71 | 2016-12-12 00:25:07 +0100 | [diff] [blame] | 71 | printf("\n === Long Match Test === \n"); |
| 72 | printf("Creating random data to produce long matches \n"); |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 73 | for (i = 0; i < sizeof(match); ++i) { |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 74 | srcBuffer[i] = match[i]; |
| 75 | } |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 76 | for (i = 0; i < randomData; ++i) { |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 77 | srcBuffer[sizeof(match) + i] = (char)(rand() & 0xFF); |
| 78 | } |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 79 | for (i = 0; i < sizeof(match); ++i) { |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 80 | srcBuffer[sizeof(match) + randomData + i] = match[i]; |
| 81 | } |
Yann Collet | c261f71 | 2016-12-12 00:25:07 +0100 | [diff] [blame] | 82 | printf("Compressing, trying to generate a segfault \n"); |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 83 | if (compress(ctx, out, srcBuffer, size)) { |
| 84 | return 1; |
| 85 | } |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 86 | compressed += size; |
| 87 | while (compressed < toCompress) { |
| 88 | const size_t block = rand() % (size - pos + 1); |
| 89 | if (pos == size) { pos = 0; } |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 90 | if (compress(ctx, out, srcBuffer + pos, block)) { |
| 91 | return 1; |
| 92 | } |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 93 | pos += block; |
| 94 | compressed += block; |
| 95 | } |
Yann Collet | c261f71 | 2016-12-12 00:25:07 +0100 | [diff] [blame] | 96 | printf("Compression completed successfully (no error triggered)\n"); |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 97 | free(srcBuffer); |
| 98 | free(dstBuffer); |
| 99 | } |
Elliott Hughes | 44aba64 | 2023-09-12 20:18:59 +0000 | [diff] [blame] | 100 | ZSTD_freeCCtx(ctx); |
Nick Terrell | b547d21 | 2016-12-10 23:17:36 -0800 | [diff] [blame] | 101 | return 0; |
Nick Terrell | 0acae73 | 2016-12-10 19:12:13 -0800 | [diff] [blame] | 102 | } |