aboutsummaryrefslogtreecommitdiffhomepage
path: root/demux
diff options
context:
space:
mode:
Diffstat (limited to 'demux')
-rw-r--r--demux/demux_raw.c322
1 files changed, 162 insertions, 160 deletions
diff --git a/demux/demux_raw.c b/demux/demux_raw.c
index 54d237e11c..4b3e8844a4 100644
--- a/demux/demux_raw.c
+++ b/demux/demux_raw.c
@@ -43,10 +43,10 @@ static int samplerate = 44100;
static int aformat = AF_FORMAT_S16_NE;
const m_option_t demux_rawaudio_opts[] = {
- { "channels", &channels, &m_option_type_chmap, CONF_MIN, 1 },
- { "rate", &samplerate, CONF_TYPE_INT,CONF_RANGE,1000,8*48000, NULL },
- { "format", &aformat, CONF_TYPE_AFMT, 0, 0, 0, NULL },
- {NULL, NULL, 0, 0, 0, 0, NULL}
+ { "channels", &channels, &m_option_type_chmap, CONF_MIN, 1 },
+ { "rate", &samplerate, CONF_TYPE_INT, CONF_RANGE, 1000, 8 * 48000, NULL },
+ { "format", &aformat, CONF_TYPE_AFMT, 0, 0, 0, NULL },
+ {NULL, NULL, 0, 0, 0, 0, NULL}
};
static int vformat = MP_FOURCC_I420;
@@ -55,181 +55,183 @@ static char *codec;
static int width = 0;
static int height = 0;
static float fps = 25;
-static int imgsize=0;
+static int imgsize = 0;
const m_option_t demux_rawvideo_opts[] = {
- // size:
- { "w", &width, CONF_TYPE_INT,CONF_RANGE,1,8192, NULL },
- { "h", &height, CONF_TYPE_INT,CONF_RANGE,1,8192, NULL },
- // format:
- { "format", &vformat, CONF_TYPE_FOURCC, 0, 0 , 0, NULL },
- { "mp-format", &mp_format, CONF_TYPE_IMGFMT, 0, 0 , 0, NULL },
- { "codec", &codec, CONF_TYPE_STRING, 0, 0 , 0, NULL },
- // misc:
- { "fps", &fps, CONF_TYPE_FLOAT,CONF_RANGE,0.001,1000, NULL },
- { "size", &imgsize, CONF_TYPE_INT, CONF_RANGE, 1 , 8192*8192*4, NULL },
-
- {NULL, NULL, 0, 0, 0, 0, NULL}
+ // size:
+ { "w", &width, CONF_TYPE_INT, CONF_RANGE, 1, 8192, NULL },
+ { "h", &height, CONF_TYPE_INT, CONF_RANGE, 1, 8192, NULL },
+ // format:
+ { "format", &vformat, CONF_TYPE_FOURCC, 0, 0, 0, NULL },
+ { "mp-format", &mp_format, CONF_TYPE_IMGFMT, 0, 0, 0, NULL },
+ { "codec", &codec, CONF_TYPE_STRING, 0, 0, 0, NULL },
+ // misc:
+ { "fps", &fps, CONF_TYPE_FLOAT, CONF_RANGE, 0.001, 1000, NULL },
+ { "size", &imgsize, CONF_TYPE_INT, CONF_RANGE, 1, 8192 * 8192 * 4, NULL },
+
+ {NULL, NULL, 0, 0, 0, 0, NULL}
};
-static int demux_rawaudio_open(demuxer_t* demuxer, enum demux_check check)
+static int demux_rawaudio_open(demuxer_t *demuxer, enum demux_check check)
{
- struct sh_stream *sh;
- sh_audio_t* sh_audio;
- WAVEFORMATEX* w;
-
- if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE)
- return -1;
-
- if ((aformat & AF_FORMAT_SPECIAL_MASK) != 0)
- return -1;
-
- sh = new_sh_stream(demuxer, STREAM_AUDIO);
- sh_audio = sh->audio;
- sh_audio->gsh->codec = "mp-pcm";
- sh_audio->format = aformat;
- sh_audio->wf = w = malloc(sizeof(*w));
- w->wFormatTag = 0;
- sh_audio->channels = channels;
- w->nChannels = sh_audio->channels.num;
- w->nSamplesPerSec = sh_audio->samplerate = samplerate;
- int samplesize = (af_fmt2bits(aformat) + 7) / 8;
- w->nAvgBytesPerSec = samplerate * samplesize * w->nChannels;
- w->nBlockAlign = w->nChannels * samplesize;
- w->wBitsPerSample = 8 * samplesize;
- w->cbSize = 0;
-
- demuxer->movi_start = demuxer->stream->start_pos;
- demuxer->movi_end = demuxer->stream->end_pos;
-
- struct priv *p = talloc_ptrtype(demuxer, p);
- demuxer->priv = p;
- *p = (struct priv) {
- .frame_size = samplesize * sh_audio->channels.num,
- .frame_rate = samplerate,
- };
-
- return 0;
+ struct sh_stream *sh;
+ sh_audio_t *sh_audio;
+ WAVEFORMATEX *w;
+
+ if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE)
+ return -1;
+
+ if ((aformat & AF_FORMAT_SPECIAL_MASK) != 0)
+ return -1;
+
+ sh = new_sh_stream(demuxer, STREAM_AUDIO);
+ sh_audio = sh->audio;
+ sh_audio->gsh->codec = "mp-pcm";
+ sh_audio->format = aformat;
+ sh_audio->wf = w = malloc(sizeof(*w));
+ w->wFormatTag = 0;
+ sh_audio->channels = channels;
+ w->nChannels = sh_audio->channels.num;
+ w->nSamplesPerSec = sh_audio->samplerate = samplerate;
+ int samplesize = (af_fmt2bits(aformat) + 7) / 8;
+ w->nAvgBytesPerSec = samplerate * samplesize * w->nChannels;
+ w->nBlockAlign = w->nChannels * samplesize;
+ w->wBitsPerSample = 8 * samplesize;
+ w->cbSize = 0;
+
+ demuxer->movi_start = demuxer->stream->start_pos;
+ demuxer->movi_end = demuxer->stream->end_pos;
+
+ struct priv *p = talloc_ptrtype(demuxer, p);
+ demuxer->priv = p;
+ *p = (struct priv) {
+ .frame_size = samplesize * sh_audio->channels.num,
+ .frame_rate = samplerate,
+ };
+
+ return 0;
}
-static int demux_rawvideo_open(demuxer_t* demuxer, enum demux_check check)
+static int demux_rawvideo_open(demuxer_t *demuxer, enum demux_check check)
{
- struct sh_stream *sh;
- sh_video_t* sh_video;
-
- if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE)
- return -1;
-
- if(!width || !height){
- mp_msg(MSGT_DEMUX,MSGL_ERR,"rawvideo: width or height not specified!\n");
- return -1;
- }
-
- const char *decoder = "rawvideo";
- int imgfmt = vformat;
- if (mp_format) {
- decoder = "mp-rawvideo";
- imgfmt = mp_format;
- if (!imgsize) {
- struct mp_imgfmt_desc desc = mp_imgfmt_get_desc(mp_format);
- for (int p = 0; p < desc.num_planes; p++) {
- imgsize += ((width >> desc.xs[p]) * (height >> desc.ys[p]) *
- desc.bpp[p] + 7) / 8;
- }
- }
- } else if (codec && codec[0]) {
- decoder = talloc_strdup(demuxer, codec);
- }
-
- if (!imgsize) {
- int bpp = 0;
- switch(vformat){
- case MP_FOURCC_I420: case MP_FOURCC_IYUV:
- case MP_FOURCC_NV12: case MP_FOURCC_NV21:
- case MP_FOURCC_HM12:
- case MP_FOURCC_YV12:
- bpp = 12;
- break;
- case MP_FOURCC_RGB12: case MP_FOURCC_BGR12:
- case MP_FOURCC_RGB15: case MP_FOURCC_BGR15:
- case MP_FOURCC_RGB16: case MP_FOURCC_BGR16:
- case MP_FOURCC_YUY2: case MP_FOURCC_UYVY:
- bpp = 16;
- break;
- case MP_FOURCC_RGB8: case MP_FOURCC_BGR8:
- case MP_FOURCC_Y800: case MP_FOURCC_Y8:
- bpp = 8;
- break;
- case MP_FOURCC_RGB24: case MP_FOURCC_BGR24:
- bpp = 24;
- break;
- case MP_FOURCC_RGB32: case MP_FOURCC_BGR32:
- bpp = 32;
- break;
+ struct sh_stream *sh;
+ sh_video_t *sh_video;
+
+ if (check != DEMUX_CHECK_REQUEST && check != DEMUX_CHECK_FORCE)
+ return -1;
+
+ if (!width || !height) {
+ mp_msg(MSGT_DEMUX, MSGL_ERR, "rawvideo: width or height not specified!\n");
+ return -1;
}
- if (!bpp) {
- mp_msg(MSGT_DEMUX,MSGL_ERR,"rawvideo: img size not specified and unknown format!\n");
- return -1;
+
+ const char *decoder = "rawvideo";
+ int imgfmt = vformat;
+ if (mp_format) {
+ decoder = "mp-rawvideo";
+ imgfmt = mp_format;
+ if (!imgsize) {
+ struct mp_imgfmt_desc desc = mp_imgfmt_get_desc(mp_format);
+ for (int p = 0; p < desc.num_planes; p++) {
+ imgsize += ((width >> desc.xs[p]) * (height >> desc.ys[p]) *
+ desc.bpp[p] + 7) / 8;
+ }
+ }
+ } else if (codec && codec[0])
+ decoder = talloc_strdup(demuxer, codec);
+
+ if (!imgsize) {
+ int bpp = 0;
+ switch (vformat) {
+ case MP_FOURCC_I420: case MP_FOURCC_IYUV:
+ case MP_FOURCC_NV12: case MP_FOURCC_NV21:
+ case MP_FOURCC_HM12:
+ case MP_FOURCC_YV12:
+ bpp = 12;
+ break;
+ case MP_FOURCC_RGB12: case MP_FOURCC_BGR12:
+ case MP_FOURCC_RGB15: case MP_FOURCC_BGR15:
+ case MP_FOURCC_RGB16: case MP_FOURCC_BGR16:
+ case MP_FOURCC_YUY2: case MP_FOURCC_UYVY:
+ bpp = 16;
+ break;
+ case MP_FOURCC_RGB8: case MP_FOURCC_BGR8:
+ case MP_FOURCC_Y800: case MP_FOURCC_Y8:
+ bpp = 8;
+ break;
+ case MP_FOURCC_RGB24: case MP_FOURCC_BGR24:
+ bpp = 24;
+ break;
+ case MP_FOURCC_RGB32: case MP_FOURCC_BGR32:
+ bpp = 32;
+ break;
+ }
+ if (!bpp) {
+ mp_msg(MSGT_DEMUX, MSGL_ERR,
+ "rawvideo: img size not specified and unknown format!\n");
+ return -1;
+ }
+ imgsize = width * height * bpp / 8;
}
- imgsize = width * height * bpp / 8;
- }
-
- sh = new_sh_stream(demuxer, STREAM_VIDEO);
- sh_video = sh->video;
- sh_video->gsh->codec=decoder;
- sh_video->format=imgfmt;
- sh_video->fps=fps;
- sh_video->disp_w=width;
- sh_video->disp_h=height;
- sh_video->i_bps=fps*imgsize;
-
- demuxer->movi_start = demuxer->stream->start_pos;
- demuxer->movi_end = demuxer->stream->end_pos;
-
- struct priv *p = talloc_ptrtype(demuxer, p);
- demuxer->priv = p;
- *p = (struct priv) {
- .frame_size = imgsize,
- .frame_rate = fps,
- };
-
- return 0;
+
+ sh = new_sh_stream(demuxer, STREAM_VIDEO);
+ sh_video = sh->video;
+ sh_video->gsh->codec = decoder;
+ sh_video->format = imgfmt;
+ sh_video->fps = fps;
+ sh_video->disp_w = width;
+ sh_video->disp_h = height;
+ sh_video->i_bps = fps * imgsize;
+
+ demuxer->movi_start = demuxer->stream->start_pos;
+ demuxer->movi_end = demuxer->stream->end_pos;
+
+ struct priv *p = talloc_ptrtype(demuxer, p);
+ demuxer->priv = p;
+ *p = (struct priv) {
+ .frame_size = imgsize,
+ .frame_rate = fps,
+ };
+
+ return 0;
}
-static int raw_fill_buffer(demuxer_t* demuxer)
+static int raw_fill_buffer(demuxer_t *demuxer)
{
- struct priv *p = demuxer->priv;
+ struct priv *p = demuxer->priv;
- if (demuxer->stream->eof)
- return 0;
+ if (demuxer->stream->eof)
+ return 0;
- struct demux_packet *dp = new_demux_packet(p->frame_size);
- dp->pos = stream_tell(demuxer->stream) - demuxer->movi_start;
- dp->pts = (dp->pos / p->frame_size) / p->frame_rate;
+ struct demux_packet *dp = new_demux_packet(p->frame_size);
+ dp->pos = stream_tell(demuxer->stream) - demuxer->movi_start;
+ dp->pts = (dp->pos / p->frame_size) / p->frame_rate;
- int len = stream_read(demuxer->stream, dp->buffer, dp->len);
- resize_demux_packet(dp, len);
- demuxer_add_packet(demuxer, demuxer->streams[0], dp);
+ int len = stream_read(demuxer->stream, dp->buffer, dp->len);
+ resize_demux_packet(dp, len);
+ demuxer_add_packet(demuxer, demuxer->streams[0], dp);
- return 1;
+ return 1;
}
-static void raw_seek(demuxer_t *demuxer,float rel_seek_secs,float audio_delay,int flags){
- struct priv *p = demuxer->priv;
- stream_t* s = demuxer->stream;
- stream_update_size(s);
- int64_t start = s->start_pos;
- int64_t end = s->end_pos;
- int64_t pos = (flags & SEEK_ABSOLUTE) ? start : stream_tell(s);
- if (flags & SEEK_FACTOR)
- pos += (end - start) * rel_seek_secs;
- else
- pos += rel_seek_secs * p->frame_rate * p->frame_size;
- if(pos < 0)
- pos = 0;
- if (end && pos > end)
- pos = end;
- stream_seek(s, (pos / p->frame_size) * p->frame_size);
+static void raw_seek(demuxer_t *demuxer, float rel_seek_secs, float audio_delay,
+ int flags)
+{
+ struct priv *p = demuxer->priv;
+ stream_t *s = demuxer->stream;
+ stream_update_size(s);
+ int64_t start = s->start_pos;
+ int64_t end = s->end_pos;
+ int64_t pos = (flags & SEEK_ABSOLUTE) ? start : stream_tell(s);
+ if (flags & SEEK_FACTOR)
+ pos += (end - start) * rel_seek_secs;
+ else
+ pos += rel_seek_secs * p->frame_rate * p->frame_size;
+ if (pos < 0)
+ pos = 0;
+ if (end && pos > end)
+ pos = end;
+ stream_seek(s, (pos / p->frame_size) * p->frame_size);
}
static int raw_control(demuxer_t *demuxer, int cmd, void *arg)