Welcome to mirror list, hosted at ThFree Co, Russian Federation.

ffImgfmt.h « MPCVideoDec « transform « filters « src - github.com/mpc-hc/mpc-hc.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ea61fbbe53fec7bc3bd22dd60d1870eda082b7a1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
#ifndef _FFIMGFMT_H_
#define _FFIMGFMT_H_

#include "ffmpeg/libavutil/pixfmt.h"

//================================ ffdshow ==================================
// the RGB related values in this enum refers to the "memory byte order" (byte order as stored in memory).
// under x86 architecture (little endians), the byte order is stored reversed (comparing to the write order),
// this means RGB will be stored in the memory as BGR.
// When working with DirectShow in the Red-Green-Blue colorspace, DirectShow always
// expects RGB at the "memory byte order", so RGB should be selected.
// When working with files, we are interested in the "write order", which is the opposite
// of the "memory byte order" (under x86), so you should select the opposite from the
// destination byte order for the file.
// (e.g. PNG images uses RGB order, so select BGR order
// BMP image uses BGR order, so select RGB order)

/* ffdshow colorspace ids, values should be unique including flag values, and must fit inside a uint64_t
 * (an enum should be used instead of defines, but GCC does not support an enum with type uint64_t ?)
 */

// Do not reorder or renumber! Values are stored in user's registry.
#define FF_CSP_NULL  (0ULL)

#define FF_CSP_420P  (1ULL << 0)    // 0x0000001
#define FF_CSP_422P  (1ULL << 1)    // 0x0000002
#define FF_CSP_444P  (1ULL << 2)    // 0x0000004
#define FF_CSP_411P  (1ULL << 3)    // 0x0000008
#define FF_CSP_410P  (1ULL << 4)    // 0x0000010

#define FF_CSP_YUY2  (1ULL << 5)    // 0x0000020
#define FF_CSP_UYVY  (1ULL << 6)    // 0x0000040
#define FF_CSP_YVYU  (1ULL << 7)    // 0x0000080
#define FF_CSP_VYUY  (1ULL << 8)    // 0x0000100

#define FF_CSP_ABGR  (1ULL << 9)    // 0x0000200 [a|b|g|r]
#define FF_CSP_RGBA  (1ULL << 10)   // 0x0000400 [r|g|b|a]
#define FF_CSP_BGR32 (1ULL << 11)   // 0x0000800
#define FF_CSP_BGR24 (1ULL << 12)   // 0x0001000
#define FF_CSP_BGR15 (1ULL << 13)   // 0x0002000
#define FF_CSP_BGR16 (1ULL << 14)   // 0x0004000
#define FF_CSP_RGB32 (1ULL << 15)   // 0x0008000
#define FF_CSP_RGB24 (1ULL << 16)   // 0x0010000
#define FF_CSP_RGB15 (1ULL << 17)   // 0x0020000
#define FF_CSP_RGB16 (1ULL << 18)   // 0x0040000

#define FF_CSP_CLJR  (1ULL << 19)   // 0x0080000
#define FF_CSP_Y800  (1ULL << 20)   // 0x0100000
#define FF_CSP_NV12  (1ULL << 21)   // 0x0200000

#define FF_CSP_420P10 (1ULL << 22)  // 0x0400000
#define FF_CSP_444P10 (1ULL << 23)  // 0x0800000
#define FF_CSP_P016   (1ULL << 24)  // 0x1000000 P016 in Media Fundation (MFVideoFormat_P016). 16bit version of NV12.
#define FF_CSP_P010   (1ULL << 25)  // 0x2000000 P010 in Media Fundation (MFVideoFormat_P010). same as FF_CSP_P016
#define FF_CSP_422P10 (1ULL << 26)  // 0x4000000
#define FF_CSP_P210   (1ULL << 27)  // 0x8000000
#define FF_CSP_P216   (1ULL << 28)  // 0x10000000

#define FF_CSP_AYUV   (1ULL << 29)  // 0x20000000
#define FF_CSP_Y416   (1ULL << 30)  // 0x40000000

#define FF_CSP_PAL8   (1ULL << 31)  // 0x80000000

#define FF_CSP_GBRP   (1ULL << 32)  // 0x100000000
#define FF_CSP_GBRP9  (1ULL << 33)  // 0x200000000
#define FF_CSP_GBRP10 (1ULL << 34)  // 0x400000000

#define FF_CSP_420P9  (1ULL << 35)  // 0x800000000
#define FF_CSP_422P9  (1ULL << 36)  // 0x1000000000
#define FF_CSP_444P9  (1ULL << 37)  // 0x2000000000

// Flags
#define FF_CSP_FLAGS_YUV_JPEG   (1ULL << 59)
#define FF_CSP_FLAGS_YUV_ORDER  (1ULL << 60) // UV ordered chroma planes (not VU as default)
#define FF_CSP_FLAGS_YUV_ADJ    (1ULL << 61) // YUV planes are stored consecutively in one memory block
#define FF_CSP_FLAGS_INTERLACED (1ULL << 62)
#define FF_CSP_FLAGS_VFLIP      (1ULL << 63) // flip mask

#define FF_CSPS_NUM 38

#define FF_CSP_UNSUPPORTED      (1ULL<<FF_CSPS_NUM)

#define FF_CSPS_MASK            (FF_CSP_UNSUPPORTED-1)
#define FF_CSPS_MASK_HIGH_BIT   (FF_CSP_420P10|FF_CSP_422P10|FF_CSP_444P10)
#define FF_CSPS_MASK_YUV_PLANAR (FF_CSP_420P|FF_CSP_422P|FF_CSP_444P|FF_CSP_411P|FF_CSP_410P)
#define FF_CSPS_MASK_RGB_PLANAR (FF_CSP_GBRP|FF_CSP_GBRP9|FF_CSP_GBRP10)
#define FF_CSPS_MASK_YUV_PACKED (FF_CSP_YUY2|FF_CSP_UYVY|FF_CSP_YVYU|FF_CSP_VYUY)
#define FF_CSPS_MASK_RGB        (FF_CSP_RGBA|FF_CSP_RGB32|FF_CSP_RGB24|FF_CSP_RGB15|FF_CSP_RGB16)
#define FF_CSPS_MASK_BGR        (FF_CSP_ABGR|FF_CSP_BGR32|FF_CSP_BGR24|FF_CSP_BGR15|FF_CSP_BGR16)
#define FF_CSPS_MASK_FFRGB      (FF_CSP_RGB32|FF_CSP_RGB24|FF_CSP_BGR32|FF_CSP_BGR24) // ffdshow converters output color spaces. Require dst stride to be multiple of 4.

#include <stddef.h>
typedef int stride_t;

//==================================== xvid4 =====================================

#define XVID4_CSP_PLANAR   (1<< 0) /* 4:2:0 planar */
#define XVID4_CSP_I420     (1<< 1) /* 4:2:0 packed(planar win32) */
#define XVID4_CSP_YV12     (1<< 2) /* 4:2:0 packed(planar win32) */
#define XVID4_CSP_YUY2     (1<< 3) /* 4:2:2 packed */
#define XVID4_CSP_UYVY     (1<< 4) /* 4:2:2 packed */
#define XVID4_CSP_YVYU     (1<< 5) /* 4:2:2 packed */
#define XVID4_CSP_BGRA     (1<< 6) /* 32-bit bgra packed */
#define XVID4_CSP_ABGR     (1<< 7) /* 32-bit abgr packed */
#define XVID4_CSP_RGBA     (1<< 8) /* 32-bit rgba packed */
#define XVID4_CSP_BGR      (1<< 9) /* 24-bit bgr packed */
#define XVID4_CSP_RGB555   (1<<10) /* 16-bit rgb555 packed */
#define XVID4_CSP_RGB565   (1<<11) /* 16-bit rgb565 packed */
#define XVID4_CSP_SLICE    (1<<12) /* decoder only: 4:2:0 planar, per slice rendering */
#define XVID4_CSP_INTERNAL (1<<13) /* decoder only: 4:2:0 planar, returns ptrs to internal buffers */
#define XVID4_CSP_NULL     (1<<14) /* decoder only: dont output anything */
#define XVID4_CSP_VFLIP    (1<<31) /* vertical flip mask */

static __inline uint64_t csp_xvid4_2ffdshow(int csp)
{
    switch (csp) {
        case XVID4_CSP_BGR   :
            return FF_CSP_RGB24;
        case XVID4_CSP_YV12  :
            return FF_CSP_420P|FF_CSP_FLAGS_YUV_ADJ;
        case XVID4_CSP_YUY2  :
            return FF_CSP_YUY2;
        case XVID4_CSP_UYVY  :
            return FF_CSP_UYVY;
        case XVID4_CSP_I420  :
            return FF_CSP_420P|FF_CSP_FLAGS_YUV_ADJ|FF_CSP_FLAGS_YUV_ORDER;
        case XVID4_CSP_RGB555:
            return FF_CSP_RGB15;
        case XVID4_CSP_RGB565:
            return FF_CSP_RGB16;
        case XVID4_CSP_PLANAR:
            return FF_CSP_420P;
        case XVID4_CSP_YVYU  :
            return FF_CSP_YVYU;
        case XVID4_CSP_BGRA  :
            return FF_CSP_RGB32;
        case XVID4_CSP_ABGR  :
            return FF_CSP_ABGR;
        case XVID4_CSP_RGBA  :
            return FF_CSP_RGBA;
        default              :
            return FF_CSP_NULL;
    }
}

//================================= ffmpeg ===================================
static __inline uint64_t csp_lavc2ffdshow(enum PixelFormat pix_fmt)
{
    switch (pix_fmt) {
        case PIX_FMT_YUV420P :
        case PIX_FMT_YUVJ420P:
            return FF_CSP_420P;
        case PIX_FMT_YUV422P :
        case PIX_FMT_YUVJ422P:
            return FF_CSP_422P;
        case PIX_FMT_YUV444P :
        case PIX_FMT_YUVJ444P:
            return FF_CSP_444P;
        case PIX_FMT_YUV411P :
            return FF_CSP_411P;
        case PIX_FMT_YUV410P :
            return FF_CSP_410P;
        case PIX_FMT_YUYV422 :
            return FF_CSP_YUY2;
        case PIX_FMT_UYVY422 :
            return FF_CSP_UYVY;
        case PIX_FMT_YUV420P10:
            return FF_CSP_420P10;
        case PIX_FMT_YUV422P10:
            return FF_CSP_422P10;
        case PIX_FMT_YUV444P10:
            return FF_CSP_444P10;
        case PIX_FMT_BGR24   :
            return FF_CSP_RGB24;
        case PIX_FMT_RGB24   :
            return FF_CSP_BGR24;
        case PIX_FMT_RGB32   :
        case PIX_FMT_ARGB:
            return FF_CSP_RGB32;
        case PIX_FMT_RGB555  :
            return FF_CSP_RGB15;
        case PIX_FMT_RGB565  :
            return FF_CSP_RGB16;
        case PIX_FMT_GRAY8   :
            return FF_CSP_Y800;
        case PIX_FMT_PAL8    :
            return FF_CSP_PAL8;
        case PIX_FMT_NV12    :
            return FF_CSP_NV12;
        case PIX_FMT_GBRP    :
            return FF_CSP_GBRP;
        case PIX_FMT_GBRP9   :
            return FF_CSP_GBRP9;
        case PIX_FMT_GBRP10  :
            return FF_CSP_GBRP10;
        case PIX_FMT_YUV420P9:
            return FF_CSP_420P9;
        case PIX_FMT_YUV422P9:
            return FF_CSP_422P9;
        case PIX_FMT_YUV444P9:
            return FF_CSP_444P9;
        default              :
            return FF_CSP_NULL;
    }
}
static __inline enum PixelFormat csp_ffdshow2lavc(uint64_t pix_fmt)
{
    switch (pix_fmt&FF_CSPS_MASK) {
        case FF_CSP_420P:
            return pix_fmt&FF_CSP_FLAGS_YUV_JPEG?PIX_FMT_YUVJ420P:PIX_FMT_YUV420P;
        case FF_CSP_422P:
            return pix_fmt&FF_CSP_FLAGS_YUV_JPEG?PIX_FMT_YUVJ422P:PIX_FMT_YUV422P;
        case FF_CSP_444P:
            return pix_fmt&FF_CSP_FLAGS_YUV_JPEG?PIX_FMT_YUVJ444P:PIX_FMT_YUV444P;
        case FF_CSP_411P:
            return PIX_FMT_YUV411P;
        case FF_CSP_410P:
            return PIX_FMT_YUV410P;
        case FF_CSP_YUY2:
            return PIX_FMT_YUYV422;
        case FF_CSP_UYVY:
            return PIX_FMT_UYVY422;
        case FF_CSP_420P10:
            return PIX_FMT_YUV420P10;
        case FF_CSP_422P10:
            return PIX_FMT_YUV422P10;
        case FF_CSP_444P10:
            return PIX_FMT_YUV444P10;
        case FF_CSP_RGB24:
            return PIX_FMT_BGR24;
        case FF_CSP_BGR24:
            return PIX_FMT_RGB24;
        case FF_CSP_RGB32:
            return PIX_FMT_RGB32;
        case FF_CSP_BGR32:
            return PIX_FMT_BGR32;
        case FF_CSP_RGB15:
            return PIX_FMT_RGB555;
        case FF_CSP_RGB16:
            return PIX_FMT_RGB565;
        case FF_CSP_Y800:
            return PIX_FMT_GRAY8;
        case FF_CSP_PAL8:
            return PIX_FMT_PAL8;
        case FF_CSP_NV12:
            return PIX_FMT_NV12;
        case FF_CSP_ABGR:
            return PIX_FMT_ABGR;
        case FF_CSP_RGBA:
            return PIX_FMT_RGBA;
        case FF_CSP_GBRP:
            return PIX_FMT_GBRP;
        case FF_CSP_GBRP9:
            return PIX_FMT_GBRP9;
        case FF_CSP_GBRP10:
            return PIX_FMT_GBRP10;
        case FF_CSP_420P9:
            return PIX_FMT_YUV420P9;
        case FF_CSP_422P9:
            return PIX_FMT_YUV422P9;
        case FF_CSP_444P9:
            return PIX_FMT_YUV444P9;
        default         :
            return PIX_FMT_NB;
    }
}

#define SWS_IN_CSPS \
 (                  \
  FF_CSP_420P|      \
  FF_CSP_444P|      \
  FF_CSP_422P|      \
  FF_CSP_411P|      \
  FF_CSP_410P|      \
  FF_CSP_YUY2|      \
  FF_CSP_UYVY|      \
  FF_CSP_YVYU|      \
  FF_CSP_VYUY|      \
  FF_CSP_BGR32|     \
  FF_CSP_BGR24|     \
  FF_CSP_BGR16|     \
  FF_CSP_BGR15|     \
  FF_CSP_RGB32|     \
  FF_CSP_RGB24|     \
  FF_CSP_RGB16|     \
  FF_CSP_RGB15|     \
  FF_CSP_NV12|      \
  FF_CSP_420P10|    \
  FF_CSP_422P10|    \
  FF_CSP_444P10|    \
  FF_CSP_420P9|     \
  FF_CSP_422P9|     \
  FF_CSP_444P9|     \
  FF_CSP_Y800       \
 )
#define SWS_OUT_CSPS \
 (                   \
  FF_CSP_420P|       \
  FF_CSP_444P|       \
  FF_CSP_422P|       \
  FF_CSP_411P|       \
  FF_CSP_410P|       \
  FF_CSP_YUY2|       \
  FF_CSP_UYVY|       \
  FF_CSP_YVYU|       \
  FF_CSP_VYUY|       \
  FF_CSP_RGB32|      \
  FF_CSP_RGB24|      \
  FF_CSP_RGB16|      \
  FF_CSP_RGB15|      \
  FF_CSP_BGR32|      \
  FF_CSP_BGR24|      \
  FF_CSP_BGR16|      \
  FF_CSP_BGR15|      \
  FF_CSP_NV12|       \
  FF_CSP_420P10|     \
  FF_CSP_422P10|     \
  FF_CSP_444P10|     \
  FF_CSP_420P9|      \
  FF_CSP_422P9|      \
  FF_CSP_444P9|      \
  FF_CSP_Y800        \
 )

static __inline uint64_t csp_supSWSin(uint64_t x)
{
    return (x&FF_CSPS_MASK)&(SWS_IN_CSPS|FF_CSPS_MASK_HIGH_BIT);
}
static __inline uint64_t csp_supSWSout(uint64_t x)
{
    return (x&FF_CSPS_MASK)&(SWS_OUT_CSPS|FF_CSPS_MASK_HIGH_BIT);
}

#endif

#if defined(__cplusplus) && !defined(FF_CSP_ONLY)

#ifndef _FFIMGFMTCPP_H_
#define _FFIMGFMTCPP_H_

#include "array_allocator.h"
#include "char_t.h"

struct TcspInfo {
    uint64_t id;
    const char_t *name;
    int Bpp; // Bytes per pixel for each plane.
    int bpp; // bits per pixel for all plane. (Memory usage, not the effective bit depth)
    unsigned int numPlanes;
    unsigned int shiftX[4], shiftY[4];
    unsigned int black[4];
    FOURCC fcc, fcccsp;
    const GUID *subtype;
    int packedLumaOffset, packedChromaOffset;
};
extern const TcspInfo cspInfos[];
struct TcspInfos :std::vector<const TcspInfo*,array_allocator<const TcspInfo*,FF_CSPS_NUM*2> > {
private:
    struct TsortFc {
    private:
        uint64_t csp,outPrimaryCSP;
    public:
        TsortFc(uint64_t Icsp,uint64_t IoutPrimaryCSP):csp(Icsp),outPrimaryCSP(IoutPrimaryCSP) {}
        bool operator ()(const TcspInfo* &csp1,const TcspInfo* &csp2);
    };
public:
    void sort(uint64_t csp, uint64_t outPrimaryCSP);
};

static __inline const TcspInfo* csp_getInfo(uint64_t csp)
{
    switch (csp&(FF_CSPS_MASK|FF_CSP_FLAGS_YUV_ORDER)) {
        case FF_CSP_420P|FF_CSP_FLAGS_YUV_ORDER: {
            extern TcspInfo cspInfoIYUV;
            return &cspInfoIYUV;
        }
        default:
            csp&=FF_CSPS_MASK;
            if (csp==0) {
                return NULL;
            }
            int i=0;
            while (csp>>=1) {
                i++;
            }
            if (i<=FF_CSPS_NUM) {
                return &cspInfos[i];
            } else {
                return NULL;
            }
    }
}
const TcspInfo* csp_getInfoFcc(FOURCC fcc);

static __inline uint64_t csp_isYUVplanar(uint64_t x)
{
    return x&FF_CSPS_MASK&FF_CSPS_MASK_YUV_PLANAR;
}
static __inline uint64_t csp_isRGBplanar(uint64_t x)
{
    return x&FF_CSPS_MASK&FF_CSPS_MASK_RGB_PLANAR;
}
static __inline uint64_t csp_isYUVplanarHighBit(uint64_t x)
{
    return x & FF_CSPS_MASK & FF_CSPS_MASK_HIGH_BIT;
}
static __inline uint64_t csp_isYUVpacked(uint64_t x)
{
    return x&FF_CSPS_MASK&FF_CSPS_MASK_YUV_PACKED;
}
static __inline uint64_t csp_isYUV(uint64_t x)
{
    return csp_isYUVpacked(x)|csp_isYUVplanar(x);
}
static __inline uint64_t csp_isYUV_NV(uint64_t x)
{
    return csp_isYUVpacked(x)|csp_isYUVplanar(x)|(x & (FF_CSP_NV12|FF_CSP_P016|FF_CSP_P010|FF_CSP_P210|FF_CSP_P216));
}
static __inline uint64_t csp_isRGB_RGB(uint64_t x)
{
    return x&FF_CSPS_MASK&FF_CSPS_MASK_RGB;
}
static __inline uint64_t csp_isRGB_BGR(uint64_t x)
{
    return x&FF_CSPS_MASK&FF_CSPS_MASK_BGR;
}
static __inline uint64_t csp_isRGB(uint64_t x)
{
    return csp_isRGB_RGB(x)|csp_isRGB_BGR(x);
}
static __inline uint64_t csp_supXvid(uint64_t x)
{
    return (x&FF_CSPS_MASK)&(FF_CSP_RGB24|FF_CSP_420P|FF_CSP_YUY2|FF_CSP_UYVY|FF_CSP_YVYU|FF_CSP_VYUY|FF_CSP_RGB15|FF_CSP_RGB16|FF_CSP_RGB32|FF_CSP_ABGR|FF_CSP_RGBA|FF_CSP_BGR24);
}

bool csp_inFOURCCmask(uint64_t x,FOURCC fcc);

extern char_t* csp_getName2(const TcspInfo *cspInfo,uint64_t csp,char_t *buf,size_t len);
extern char_t* csp_getName(uint64_t csp,char_t *buf,size_t len);
extern uint64_t csp_bestMatch(uint64_t inCSP,uint64_t wantedCSPS,int *rank=NULL, uint64_t outPrimaryCSP=0);

static __inline void csp_yuv_adj_to_plane(uint64_t &csp,const TcspInfo *cspInfo,unsigned int dy,unsigned char *data[4],stride_t stride[4])
{
    if (csp_isYUVplanar(csp) && (csp & FF_CSP_FLAGS_YUV_ADJ)) {
        csp&=~FF_CSP_FLAGS_YUV_ADJ;
        data[2]=data[0]+stride[0]*(dy>>cspInfo->shiftY[0]);
        stride[1]=stride[0]>>cspInfo->shiftX[1];
        data[1]=data[2]+stride[1]*(dy>>cspInfo->shiftY[1]);
        stride[2]=stride[0]>>cspInfo->shiftX[2];
    } else if ((csp & (FF_CSP_NV12|FF_CSP_P016|FF_CSP_P010|FF_CSP_P210|FF_CSP_P216)) && (csp & FF_CSP_FLAGS_YUV_ADJ)) {
        csp&=~FF_CSP_FLAGS_YUV_ADJ;
        data[1] = data[0] + stride[0] *dy;
        stride[1] = stride[0];
    }

}
static __inline void csp_yuv_order(uint64_t &csp,unsigned char *data[4],stride_t stride[4])
{
    if (csp_isYUVplanar(csp) && (csp&FF_CSP_FLAGS_YUV_ORDER)) {
        csp&=~FF_CSP_FLAGS_YUV_ORDER;
        std::swap(data[1],data[2]);
        std::swap(stride[1],stride[2]);
    }
}
static __inline void csp_vflip(uint64_t &csp,const TcspInfo *cspInfo,unsigned char *data[],stride_t stride[],unsigned int dy)
{
    if (csp&FF_CSP_FLAGS_VFLIP) {
        csp&=~FF_CSP_FLAGS_VFLIP;
        for (unsigned int i=0; i<cspInfo->numPlanes; i++) {
            data[i]+=stride[i]*((dy>>cspInfo->shiftY[i])-1);
            stride[i]*=-1;
        }
    }
}

uint64_t getBMPcolorspace(const BITMAPINFOHEADER *hdr,const TcspInfos &forcedCsps);

struct TcspFcc {
    const char_t *name;
    FOURCC fcc;
    uint64_t csp;
    bool flip;
    bool supEnc;
};
extern const TcspFcc cspFccs[];

#endif

#endif