FFmpeg
bswap.h
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef AVUTIL_RISCV_BSWAP_H
20 #define AVUTIL_RISCV_BSWAP_H
21 
22 #include <stdint.h>
23 #include "config.h"
24 #include "libavutil/attributes.h"
25 
26 #if defined (__riscv_zbb) && (__riscv_zbb > 0) && HAVE_INLINE_ASM
27 
28 static av_always_inline av_const uintptr_t av_bswap_xlen(uintptr_t x)
29 {
30  uintptr_t y;
31 
32  __asm__("rev8 %0, %1" : "=r" (y) : "r" (x));
33  return y;
34 }
35 
36 #define av_bswap16 av_bswap16
37 
38 static av_always_inline av_const uint_fast16_t av_bswap16(uint_fast16_t x)
39 {
40  return av_bswap_xlen(x) >> (__riscv_xlen - 16);
41 }
42 
43 #if (__riscv_xlen == 32)
44 #define av_bswap32 av_bswap_xlen
45 #define av_bswap64 av_bswap64
46 
47 static av_always_inline av_const uint64_t av_bswap64(uint64_t x)
48 {
49  return (((uint64_t)av_bswap32(x)) << 32) | av_bswap32(x >> 32);
50 }
51 
52 #else
53 #define av_bswap32 av_bswap32
54 
55 static av_always_inline av_const uint_fast32_t av_bswap32(uint_fast32_t x)
56 {
57  return av_bswap_xlen(x) >> (__riscv_xlen - 32);
58 }
59 
60 #if (__riscv_xlen == 64)
61 #define av_bswap64 av_bswap_xlen
62 
63 #else
64 #define av_bswap64 av_bswap64
65 
66 static av_always_inline av_const uint_fast64_t av_bswap64(uint_fast64_t x)
67 {
68  return av_bswap_xlen(x) >> (__riscv_xlen - 64);
69 }
70 
71 #endif /* __riscv_xlen > 64 */
72 #endif /* __riscv_xlen > 32 */
73 #endif /* __riscv_zbb */
74 #endif /* AVUTIL_RISCV_BSWAP_H */
av_const
#define av_const
Definition: attributes.h:84
av_bswap32
#define av_bswap32
Definition: bswap.h:33
av_bswap16
#define av_bswap16
Definition: bswap.h:31
attributes.h
av_always_inline
#define av_always_inline
Definition: attributes.h:49
__asm__
__asm__(".macro parse_r var r\n\t" "\\var = -1\n\t" _IFC_REG(0) _IFC_REG(1) _IFC_REG(2) _IFC_REG(3) _IFC_REG(4) _IFC_REG(5) _IFC_REG(6) _IFC_REG(7) _IFC_REG(8) _IFC_REG(9) _IFC_REG(10) _IFC_REG(11) _IFC_REG(12) _IFC_REG(13) _IFC_REG(14) _IFC_REG(15) _IFC_REG(16) _IFC_REG(17) _IFC_REG(18) _IFC_REG(19) _IFC_REG(20) _IFC_REG(21) _IFC_REG(22) _IFC_REG(23) _IFC_REG(24) _IFC_REG(25) _IFC_REG(26) _IFC_REG(27) _IFC_REG(28) _IFC_REG(29) _IFC_REG(30) _IFC_REG(31) ".iflt \\var\n\t" ".error \"Unable to parse register name \\r\"\n\t" ".endif\n\t" ".endm")
av_bswap64
static uint64_t av_const av_bswap64(uint64_t x)
Definition: bswap.h:75