xref: /netbsd-src/external/bsd/zstd/dist/programs/fileio_common.h (revision 3117ece4fc4a4ca4489ba793710b60b0d26bab6c)
1*3117ece4Schristos /*
2*3117ece4Schristos  * Copyright (c) Meta Platforms, Inc. and affiliates.
3*3117ece4Schristos  * All rights reserved.
4*3117ece4Schristos  *
5*3117ece4Schristos  * This source code is licensed under both the BSD-style license (found in the
6*3117ece4Schristos  * LICENSE file in the root directory of this source tree) and the GPLv2 (found
7*3117ece4Schristos  * in the COPYING file in the root directory of this source tree).
8*3117ece4Schristos  * You may select, at your option, one of the above-listed licenses.
9*3117ece4Schristos  */
10*3117ece4Schristos 
11*3117ece4Schristos #ifndef ZSTD_FILEIO_COMMON_H
12*3117ece4Schristos #define ZSTD_FILEIO_COMMON_H
13*3117ece4Schristos 
14*3117ece4Schristos #if defined (__cplusplus)
15*3117ece4Schristos extern "C" {
16*3117ece4Schristos #endif
17*3117ece4Schristos 
18*3117ece4Schristos #include "../lib/common/mem.h"     /* U32, U64 */
19*3117ece4Schristos #include "fileio_types.h"
20*3117ece4Schristos #include "platform.h"
21*3117ece4Schristos #include "timefn.h"     /* UTIL_getTime, UTIL_clockSpanMicro */
22*3117ece4Schristos 
23*3117ece4Schristos /*-*************************************
24*3117ece4Schristos *  Macros
25*3117ece4Schristos ***************************************/
26*3117ece4Schristos #define KB *(1 <<10)
27*3117ece4Schristos #define MB *(1 <<20)
28*3117ece4Schristos #define GB *(1U<<30)
29*3117ece4Schristos #undef MAX
30*3117ece4Schristos #define MAX(a,b) ((a)>(b) ? (a) : (b))
31*3117ece4Schristos 
32*3117ece4Schristos extern FIO_display_prefs_t g_display_prefs;
33*3117ece4Schristos 
34*3117ece4Schristos #define DISPLAY(...)         fprintf(stderr, __VA_ARGS__)
35*3117ece4Schristos #define DISPLAYOUT(...)      fprintf(stdout, __VA_ARGS__)
36*3117ece4Schristos #define DISPLAYLEVEL(l, ...) { if (g_display_prefs.displayLevel>=l) { DISPLAY(__VA_ARGS__); } }
37*3117ece4Schristos 
38*3117ece4Schristos extern UTIL_time_t g_displayClock;
39*3117ece4Schristos 
40*3117ece4Schristos #define REFRESH_RATE  ((U64)(SEC_TO_MICRO / 6))
41*3117ece4Schristos #define READY_FOR_UPDATE() (UTIL_clockSpanMicro(g_displayClock) > REFRESH_RATE || g_display_prefs.displayLevel >= 4)
42*3117ece4Schristos #define DELAY_NEXT_UPDATE() { g_displayClock = UTIL_getTime(); }
43*3117ece4Schristos #define DISPLAYUPDATE(l, ...) {                              \
44*3117ece4Schristos         if (g_display_prefs.displayLevel>=l && (g_display_prefs.progressSetting != FIO_ps_never)) { \
45*3117ece4Schristos             if (READY_FOR_UPDATE()) { \
46*3117ece4Schristos                 DELAY_NEXT_UPDATE();                         \
47*3117ece4Schristos                 DISPLAY(__VA_ARGS__);                        \
48*3117ece4Schristos                 if (g_display_prefs.displayLevel>=4) fflush(stderr);       \
49*3117ece4Schristos     }   }   }
50*3117ece4Schristos 
51*3117ece4Schristos #define SHOULD_DISPLAY_SUMMARY() \
52*3117ece4Schristos     (g_display_prefs.displayLevel >= 2 || g_display_prefs.progressSetting == FIO_ps_always)
53*3117ece4Schristos #define SHOULD_DISPLAY_PROGRESS()                       \
54*3117ece4Schristos     (g_display_prefs.progressSetting != FIO_ps_never && SHOULD_DISPLAY_SUMMARY())
55*3117ece4Schristos #define DISPLAY_PROGRESS(...) { if (SHOULD_DISPLAY_PROGRESS()) { DISPLAYLEVEL(1, __VA_ARGS__); }}
56*3117ece4Schristos #define DISPLAYUPDATE_PROGRESS(...) { if (SHOULD_DISPLAY_PROGRESS()) { DISPLAYUPDATE(1, __VA_ARGS__); }}
57*3117ece4Schristos #define DISPLAY_SUMMARY(...) { if (SHOULD_DISPLAY_SUMMARY()) { DISPLAYLEVEL(1, __VA_ARGS__); } }
58*3117ece4Schristos 
59*3117ece4Schristos #undef MIN  /* in case it would be already defined */
60*3117ece4Schristos #define MIN(a,b)    ((a) < (b) ? (a) : (b))
61*3117ece4Schristos 
62*3117ece4Schristos 
63*3117ece4Schristos #define EXM_THROW(error, ...)                                             \
64*3117ece4Schristos {                                                                         \
65*3117ece4Schristos     DISPLAYLEVEL(1, "zstd: ");                                            \
66*3117ece4Schristos     DISPLAYLEVEL(5, "Error defined at %s, line %i : \n", __FILE__, __LINE__); \
67*3117ece4Schristos     DISPLAYLEVEL(1, "error %i : ", error);                                \
68*3117ece4Schristos     DISPLAYLEVEL(1, __VA_ARGS__);                                         \
69*3117ece4Schristos     DISPLAYLEVEL(1, " \n");                                               \
70*3117ece4Schristos     exit(error);                                                          \
71*3117ece4Schristos }
72*3117ece4Schristos 
73*3117ece4Schristos #define CHECK_V(v, f)                                \
74*3117ece4Schristos     v = f;                                           \
75*3117ece4Schristos     if (ZSTD_isError(v)) {                           \
76*3117ece4Schristos         DISPLAYLEVEL(5, "%s \n", #f);                \
77*3117ece4Schristos         EXM_THROW(11, "%s", ZSTD_getErrorName(v));   \
78*3117ece4Schristos     }
79*3117ece4Schristos #define CHECK(f) { size_t err; CHECK_V(err, f); }
80*3117ece4Schristos 
81*3117ece4Schristos 
82*3117ece4Schristos /* Avoid fseek()'s 2GiB barrier with MSVC, macOS, *BSD, MinGW */
83*3117ece4Schristos #if defined(_MSC_VER) && _MSC_VER >= 1400
84*3117ece4Schristos #   define LONG_SEEK _fseeki64
85*3117ece4Schristos #   define LONG_TELL _ftelli64
86*3117ece4Schristos #elif !defined(__64BIT__) && (PLATFORM_POSIX_VERSION >= 200112L) /* No point defining Large file for 64 bit */
87*3117ece4Schristos #  define LONG_SEEK fseeko
88*3117ece4Schristos #  define LONG_TELL ftello
89*3117ece4Schristos #elif defined(__MINGW32__) && !defined(__STRICT_ANSI__) && !defined(__NO_MINGW_LFS) && defined(__MSVCRT__)
90*3117ece4Schristos #   define LONG_SEEK fseeko64
91*3117ece4Schristos #   define LONG_TELL ftello64
92*3117ece4Schristos #elif defined(_WIN32) && !defined(__DJGPP__)
93*3117ece4Schristos #   include <windows.h>
94*3117ece4Schristos     static int LONG_SEEK(FILE* file, __int64 offset, int origin) {
95*3117ece4Schristos         LARGE_INTEGER off;
96*3117ece4Schristos         DWORD method;
97*3117ece4Schristos         off.QuadPart = offset;
98*3117ece4Schristos         if (origin == SEEK_END)
99*3117ece4Schristos             method = FILE_END;
100*3117ece4Schristos         else if (origin == SEEK_CUR)
101*3117ece4Schristos             method = FILE_CURRENT;
102*3117ece4Schristos         else
103*3117ece4Schristos             method = FILE_BEGIN;
104*3117ece4Schristos 
105*3117ece4Schristos         if (SetFilePointerEx((HANDLE) _get_osfhandle(_fileno(file)), off, NULL, method))
106*3117ece4Schristos             return 0;
107*3117ece4Schristos         else
108*3117ece4Schristos             return -1;
109*3117ece4Schristos     }
110*3117ece4Schristos     static __int64 LONG_TELL(FILE* file) {
111*3117ece4Schristos         LARGE_INTEGER off, newOff;
112*3117ece4Schristos         off.QuadPart = 0;
113*3117ece4Schristos         newOff.QuadPart = 0;
114*3117ece4Schristos         SetFilePointerEx((HANDLE) _get_osfhandle(_fileno(file)), off, &newOff, FILE_CURRENT);
115*3117ece4Schristos         return newOff.QuadPart;
116*3117ece4Schristos     }
117*3117ece4Schristos #else
118*3117ece4Schristos #   define LONG_SEEK fseek
119*3117ece4Schristos #   define LONG_TELL ftell
120*3117ece4Schristos #endif
121*3117ece4Schristos 
122*3117ece4Schristos #if defined (__cplusplus)
123*3117ece4Schristos }
124*3117ece4Schristos #endif
125*3117ece4Schristos #endif /* ZSTD_FILEIO_COMMON_H */
126