FFmpeg
timer.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_TIMER_H
20 #define AVUTIL_RISCV_TIMER_H
21 
22 #include "config.h"
23 
24 #if HAVE_INLINE_ASM
25 #include <stdint.h>
26 
27 static inline uint64_t rdcycle64(void)
28 {
29 #if (__riscv_xlen >= 64)
30  uintptr_t cycles;
31 
32  __asm__ volatile ("rdcycle %0" : "=r"(cycles));
33 
34 #else
35  uint64_t cycles;
36  uint32_t hi, lo, check;
37 
38  __asm__ volatile (
39  "1: rdcycleh %0\n"
40  " rdcycle %1\n"
41  " rdcycleh %2\n"
42  " bne %0, %2, 1b\n" : "=r" (hi), "=r" (lo), "=r" (check));
43 
44  cycles = (((uint64_t)hi) << 32) | lo;
45 
46 #endif
47  return cycles;
48 }
49 
50 #define AV_READ_TIME rdcycle64
51 
52 #endif
53 #endif /* AVUTIL_RISCV_TIMER_H */
check
#define check(x, y, S, v)
Definition: motion_est_template.c:405
__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")