OSDN Git Service

Merge commit '95f1004bdfdf2d26c330c1d4b7c4ac9352d60b18'
[android-x86/external-ffmpeg.git] / libavutil / utils.c
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 #include "config.h"
20 #include "avutil.h"
21 #include "avassert.h"
22 #include "samplefmt.h"
23 #include "internal.h"
24
25 /**
26  * @file
27  * various utility functions
28  */
29
30 #include "libavutil/ffversion.h"
31 const char av_util_ffversion[] = "FFmpeg version " FFMPEG_VERSION;
32
33 const char *av_version_info(void)
34 {
35     return FFMPEG_VERSION;
36 }
37
38 unsigned avutil_version(void)
39 {
40     static int checks_done;
41     if (checks_done)
42         return LIBAVUTIL_VERSION_INT;
43
44 #if FF_API_VDPAU
45     av_assert0(AV_PIX_FMT_VDA_VLD == 81); //check if the pix fmt enum has not had anything inserted or removed by mistake
46 #endif
47     av_assert0(AV_SAMPLE_FMT_DBLP == 9);
48     av_assert0(AVMEDIA_TYPE_ATTACHMENT == 4);
49     av_assert0(AV_PICTURE_TYPE_BI == 7);
50     av_assert0(LIBAVUTIL_VERSION_MICRO >= 100);
51     av_assert0(HAVE_MMX2 == HAVE_MMXEXT);
52
53     av_assert0(((size_t)-1) > 0); // C guarantees this but if false on a platform we care about revert at least b284e1ffe343d6697fb950d1ee517bafda8a9844
54
55     if (av_sat_dadd32(1, 2) != 5) {
56         av_log(NULL, AV_LOG_FATAL, "Libavutil has been built with a broken binutils, please upgrade binutils and rebuild\n");
57         abort();
58     }
59
60     if (llrint(1LL<<60) != 1LL<<60) {
61         av_log(NULL, AV_LOG_ERROR, "Libavutil has been linked to a broken llrint()\n");
62     }
63
64     checks_done = 1;
65     return LIBAVUTIL_VERSION_INT;
66 }
67
68 const char *avutil_configuration(void)
69 {
70     return FFMPEG_CONFIGURATION;
71 }
72
73 const char *avutil_license(void)
74 {
75 #define LICENSE_PREFIX "libavutil license: "
76     return LICENSE_PREFIX FFMPEG_LICENSE + sizeof(LICENSE_PREFIX) - 1;
77 }
78
79 const char *av_get_media_type_string(enum AVMediaType media_type)
80 {
81     switch (media_type) {
82     case AVMEDIA_TYPE_VIDEO:      return "video";
83     case AVMEDIA_TYPE_AUDIO:      return "audio";
84     case AVMEDIA_TYPE_DATA:       return "data";
85     case AVMEDIA_TYPE_SUBTITLE:   return "subtitle";
86     case AVMEDIA_TYPE_ATTACHMENT: return "attachment";
87     default:                      return NULL;
88     }
89 }
90
91 char av_get_picture_type_char(enum AVPictureType pict_type)
92 {
93     switch (pict_type) {
94     case AV_PICTURE_TYPE_I:  return 'I';
95     case AV_PICTURE_TYPE_P:  return 'P';
96     case AV_PICTURE_TYPE_B:  return 'B';
97     case AV_PICTURE_TYPE_S:  return 'S';
98     case AV_PICTURE_TYPE_SI: return 'i';
99     case AV_PICTURE_TYPE_SP: return 'p';
100     case AV_PICTURE_TYPE_BI: return 'b';
101     default:                 return '?';
102     }
103 }
104
105 unsigned av_int_list_length_for_size(unsigned elsize,
106                                      const void *list, uint64_t term)
107 {
108     unsigned i;
109
110     if (!list)
111         return 0;
112 #define LIST_LENGTH(type) \
113     { type t = term, *l = (type *)list; for (i = 0; l[i] != t; i++); }
114     switch (elsize) {
115     case 1: LIST_LENGTH(uint8_t);  break;
116     case 2: LIST_LENGTH(uint16_t); break;
117     case 4: LIST_LENGTH(uint32_t); break;
118     case 8: LIST_LENGTH(uint64_t); break;
119     default: av_assert0(!"valid element size");
120     }
121     return i;
122 }
123
124 char *av_fourcc_make_string(char *buf, uint32_t fourcc)
125 {
126     int i;
127     char *orig_buf = buf;
128     size_t buf_size = AV_FOURCC_MAX_STRING_SIZE;
129
130     for (i = 0; i < 4; i++) {
131         const int c = fourcc & 0xff;
132         const int print_chr = (c >= '0' && c <= '9') ||
133                               (c >= 'a' && c <= 'z') ||
134                               (c >= 'A' && c <= 'Z') ||
135                               (c && strchr(". -_", c));
136         const int len = snprintf(buf, buf_size, print_chr ? "%c" : "[%d]", c);
137         if (len < 0)
138             break;
139         buf += len;
140         buf_size = buf_size > len ? buf_size - len : 0;
141         fourcc >>= 8;
142     }
143
144     return orig_buf;
145 }
146
147 AVRational av_get_time_base_q(void)
148 {
149     return (AVRational){1, AV_TIME_BASE};
150 }
151
152 void av_assert0_fpu(void) {
153 #if HAVE_MMX_INLINE
154     uint16_t state[14];
155      __asm volatile (
156         "fstenv %0 \n\t"
157         : "+m" (state)
158         :
159         : "memory"
160     );
161     av_assert0((state[4] & 3) == 3);
162 #endif
163 }