From 3b20eb25e7b95fafdccbb594c947a69c5d027b2c Mon Sep 17 00:00:00 2001 From: Mans Rullgard Date: Mon, 15 Oct 2012 22:24:41 +0100 Subject: [PATCH 1/7] avserver: move avserver-specific code from ffmdec.c to avserver.c This way avserver only depends on the data structures of the ffm demuxer, which it already does, and not also on private functions being exported by the library. Signed-off-by: Mans Rullgard --- avserver.c | 32 ++++++++++++++++++++++++++++++++ libavformat/ffm.h | 4 ---- libavformat/ffmdec.c | 33 --------------------------------- 3 files changed, 32 insertions(+), 37 deletions(-) diff --git a/avserver.c b/avserver.c index 6b01b15b6f..994edcd04c 100644 --- a/avserver.c +++ b/avserver.c @@ -39,6 +39,7 @@ #include "libavutil/avstring.h" #include "libavutil/lfg.h" #include "libavutil/dict.h" +#include "libavutil/intreadwrite.h" #include "libavutil/mathematics.h" #include "libavutil/random_seed.h" #include "libavutil/parseutils.h" @@ -323,6 +324,37 @@ static AVLFG random_state; static FILE *logfile = NULL; +static int64_t ffm_read_write_index(int fd) +{ + uint8_t buf[8]; + + lseek(fd, 8, SEEK_SET); + if (read(fd, buf, 8) != 8) + return AVERROR(EIO); + return AV_RB64(buf); +} + +static int ffm_write_write_index(int fd, int64_t pos) +{ + uint8_t buf[8]; + int i; + + for(i=0;i<8;i++) + buf[i] = (pos >> (56 - i * 8)) & 0xff; + lseek(fd, 8, SEEK_SET); + if (write(fd, buf, 8) != 8) + return AVERROR(EIO); + return 8; +} + +static void ffm_set_write_index(AVFormatContext *s, int64_t pos, + int64_t file_size) +{ + FFMContext *ffm = s->priv_data; + ffm->write_index = pos; + ffm->file_size = file_size; +} + /* FIXME: make avserver work with IPv6 */ /* resolve host with also IP address parsing */ static int resolve_host(struct in_addr *sin_addr, const char *hostname) diff --git a/libavformat/ffm.h b/libavformat/ffm.h index 6ce5e0408c..70c3e887a0 100644 --- a/libavformat/ffm.h +++ b/libavformat/ffm.h @@ -56,8 +56,4 @@ typedef struct FFMContext { uint8_t packet[FFM_PACKET_SIZE]; } FFMContext; -int64_t ffm_read_write_index(int fd); -int ffm_write_write_index(int fd, int64_t pos); -void ffm_set_write_index(AVFormatContext *s, int64_t pos, int64_t file_size); - #endif /* AVFORMAT_FFM_H */ diff --git a/libavformat/ffmdec.c b/libavformat/ffmdec.c index 50c7416811..e6730eb2f5 100644 --- a/libavformat/ffmdec.c +++ b/libavformat/ffmdec.c @@ -24,39 +24,6 @@ #include "avformat.h" #include "internal.h" #include "ffm.h" -#if CONFIG_AVSERVER -#include - -int64_t ffm_read_write_index(int fd) -{ - uint8_t buf[8]; - - lseek(fd, 8, SEEK_SET); - if (read(fd, buf, 8) != 8) - return AVERROR(EIO); - return AV_RB64(buf); -} - -int ffm_write_write_index(int fd, int64_t pos) -{ - uint8_t buf[8]; - int i; - - for(i=0;i<8;i++) - buf[i] = (pos >> (56 - i * 8)) & 0xff; - lseek(fd, 8, SEEK_SET); - if (write(fd, buf, 8) != 8) - return AVERROR(EIO); - return 8; -} - -void ffm_set_write_index(AVFormatContext *s, int64_t pos, int64_t file_size) -{ - FFMContext *ffm = s->priv_data; - ffm->write_index = pos; - ffm->file_size = file_size; -} -#endif // CONFIG_AVSERVER static int ffm_is_avail_data(AVFormatContext *s, int size) { From 21de6ba5c12fbdd2ad86e5faf8aa12be8f5f6408 Mon Sep 17 00:00:00 2001 From: Luca Barbato Date: Sat, 13 Oct 2012 19:10:57 +0200 Subject: [PATCH 2/7] nut: export codec_tag provided by rawvideo Raw audio does not provide valid audio tags while rawvideo does. The fate refs have to be updated because it undoes the previous tag change. --- libavformat/nutenc.c | 2 +- tests/ref/lavfi/crop | 2 +- tests/ref/lavfi/crop_scale | 2 +- tests/ref/lavfi/crop_scale_vflip | 2 +- tests/ref/lavfi/crop_vflip | 2 +- tests/ref/lavfi/null | 2 +- tests/ref/lavfi/pixdesc | 114 +++++++++++++++---------------- tests/ref/lavfi/pixfmts_copy | 114 +++++++++++++++---------------- tests/ref/lavfi/pixfmts_crop | 82 +++++++++++----------- tests/ref/lavfi/pixfmts_hflip | 82 +++++++++++----------- tests/ref/lavfi/pixfmts_null | 114 +++++++++++++++---------------- tests/ref/lavfi/pixfmts_pad | 34 ++++----- tests/ref/lavfi/pixfmts_scale | 114 +++++++++++++++---------------- tests/ref/lavfi/pixfmts_vflip | 114 +++++++++++++++---------------- tests/ref/lavfi/scale200 | 2 +- tests/ref/lavfi/scale500 | 2 +- tests/ref/lavfi/vflip | 2 +- tests/ref/lavfi/vflip_crop | 2 +- tests/ref/lavfi/vflip_vflip | 2 +- 19 files changed, 395 insertions(+), 395 deletions(-) diff --git a/libavformat/nutenc.c b/libavformat/nutenc.c index 6338924f48..9985cd9b4c 100644 --- a/libavformat/nutenc.c +++ b/libavformat/nutenc.c @@ -385,7 +385,7 @@ static int write_streamheader(AVFormatContext *avctx, AVIOContext *bc, AVStream } ff_put_v(bc, 4); - if (!codec_tag) + if (!codec_tag || codec->codec_id == AV_CODEC_ID_RAWVIDEO) codec_tag = codec->codec_tag; if (codec_tag) { diff --git a/tests/ref/lavfi/crop b/tests/ref/lavfi/crop index 81ce4d10fb..32041c2184 100644 --- a/tests/ref/lavfi/crop +++ b/tests/ref/lavfi/crop @@ -1 +1 @@ -crop 64e8f986d4cc67ec6797f5adb486e43f +crop 3d163f156eaddf41d2be20736f973539 diff --git a/tests/ref/lavfi/crop_scale b/tests/ref/lavfi/crop_scale index 4eb20c8f84..82e5394496 100644 --- a/tests/ref/lavfi/crop_scale +++ b/tests/ref/lavfi/crop_scale @@ -1 +1 @@ -crop_scale 011cb96fad3d86823e4441e305814834 +crop_scale 0a3d45d58b805b8c47416b9239535f94 diff --git a/tests/ref/lavfi/crop_scale_vflip b/tests/ref/lavfi/crop_scale_vflip index a89297a808..07c729af0d 100644 --- a/tests/ref/lavfi/crop_scale_vflip +++ b/tests/ref/lavfi/crop_scale_vflip @@ -1 +1 @@ -crop_scale_vflip f2b3800ab986d147b8ed5ebae67152df +crop_scale_vflip e88a4dfb960d0bb28ee875567bedde5d diff --git a/tests/ref/lavfi/crop_vflip b/tests/ref/lavfi/crop_vflip index 759d744a91..a3f8200222 100644 --- a/tests/ref/lavfi/crop_vflip +++ b/tests/ref/lavfi/crop_vflip @@ -1 +1 @@ -crop_vflip f9a15b41ea4034a15d39a2b6f649f1c5 +crop_vflip 628542e17b6900ee79b1429183ae01b0 diff --git a/tests/ref/lavfi/null b/tests/ref/lavfi/null index dcb6bdf56e..3c3b7b742d 100644 --- a/tests/ref/lavfi/null +++ b/tests/ref/lavfi/null @@ -1 +1 @@ -null 46235acb958138b6a77976601b7045ec +null eba2f135a08829387e2f698ff72a2939 diff --git a/tests/ref/lavfi/pixdesc b/tests/ref/lavfi/pixdesc index c142ba2b9e..dc1b8572dc 100644 --- a/tests/ref/lavfi/pixdesc +++ b/tests/ref/lavfi/pixdesc @@ -1,66 +1,66 @@ -abgr 73847fb78ab01d040bc65307aa2e772d -argb 68262dbda747e9552cf04a06632a7cee -bgr24 e288c39c730970ee1056e858adc094a2 -bgr444be d15710f070a201afe2da5bd2fc1c5c76 -bgr444le fb261abd38568e10f8ebb0be52c207ce -bgr48be 754a33cf60aed44a890d194eb571ec2c -bgr48le 605447329b7242e41e6e4bcc36f87d06 -bgr4_byte 9028891b9beedf5e1e37f627980da330 -bgr555be 9e49d38ab65413f382cafd46ac469640 -bgr555le fe4784e5d4f66130fa63dee552e4720d -bgr565be 90625bce942c002aa1b55e6d77d515e2 -bgr565le d036946273d95741eb7a0593988a7090 -bgr8 2180b117a65abfd26a70458c535aa9b1 -bgra 328a76e72c55508cdf04dc93a5b056fc -gray 847f04953fd848b8c86164d9ba93f54b -gray16be 56cb2303e2f5f2d3a9260db3d6de26ab -gray16le 56cb2303e2f5f2d3a9260db3d6de26ab -monob 0bcbf98de0e633e6ccb62efeb9ab58ef -monow 37c78ca41610436acf9adf5bca7faea7 -nv12 d5e62031f9870c9d7ff5544475f6e590 -nv21 1f695aff75622765316c3dea6e3f2647 -rgb24 8008d64571c68fce43c083b83513eac3 -rgb444be 40308261161f0c54c0b5a11ce1286d11 -rgb444le b7a68135e696901059751d6a55f40df6 -rgb48be 3044840d35ce6550f77942f8204ba13d -rgb48le 8b57ae0801998fc463cfd601761d1686 -rgb4_byte 109b9756a6dc5fae6486af9aad150ead -rgb555be e9a77d923399e647c8f588b3be4cc393 +abgr 037bf9df6a765520ad6d490066bf4b89 +argb c442a8261c2265a07212ef0f72e35f5a +bgr24 0d0cb38ab3fa0b2ec0865c14f78b217b +bgr444be d9ea9307d21b162225b8b2c524cf9477 +bgr444le 88035350e9da3a8f67387890b956f0bc +bgr48be 00624e6c7ec7ab19897ba2f0a3257fe8 +bgr48le d02c235ebba7167881ca2d576497ff84 +bgr4_byte 50d23cc82d9dcef2fd12adb81fb9b806 +bgr555be 49f01b1f1f0c84fd9e776dd34cc3c280 +bgr555le 378d6ac4223651a1adcbf94a3d0d807b +bgr565be 257cf78afa35dc31e9696f139c916715 +bgr565le 1dfdd03995c287e3c754b164bf26a355 +bgr8 24bd566170343d06fec6fccfff5abc54 +bgra 76a18a5151242fa137133f604cd624d2 +gray db08f7f0751900347e6b8649e4164d21 +gray16be 7becf34ae825a3df3969bf4c6bfeb5e2 +gray16le 10bd87059b5c189f3caef2837f4f2b5c +monob 668ebe8b8103b9046b251b2fa8a1d88f +monow 9251497f3b0634f1165d12d5a289d943 +nv12 e0af357888584d36eec5aa0f673793ef +nv21 9a3297f3b34baa038b1f37cb202b512f +rgb24 b41eba9651e1b5fe386289b506188105 +rgb444be 9e89db334568c6b2e3d5d0540f4ba960 +rgb444le 0a68cb6de8bf530aa30c5c1205c25155 +rgb48be cc139ec1dd9451f0e049c0cb3a0c8aa2 +rgb48le 86c5608904f75360d492dbc5c9589969 +rgb4_byte c93ba89b74c504e7f5ae9d9ab1546c73 +rgb555be 912a62c5e53bfcbac2a0340e10973cf2 rgb555le a937a0fc764fb57dc1b3af87cba0273c -rgb565be 538c8b97606f6d98a7002e4c22b40393 -rgb565le 87ec337363dce156cd18792d22d522a4 -rgb8 c5d664ba16c5cb12d2aaad7d4a68ffca -rgba ff1a9f355d43f9d25f07a191b5aa906c -uyvy422 de111a00fa0d71375fea25768d6efe9b -yuv410p 08cf06ff43081c2224f5c310ea7a14ae -yuv411p de4c4062be12f1aacf19b741a8733c2b -yuv420p 46235acb958138b6a77976601b7045ec -yuv420p10be 7605e266c088d0fcf68c7b27c3ceff5f -yuv420p10le 4228ee628c6deec123a13b9784516cc7 -yuv420p16be 5cc2373d3d047895a2ebddc4c1283707 -yuv420p16le 5cc2373d3d047895a2ebddc4c1283707 +rgb565be 9cadf742e05ddc23a3b5b270f89aad3c +rgb565le d39aa298bb525e9be8860351c6f62dab +rgb8 4a9d8e4f2f154e83a7e1735be6300700 +rgba 93a5b3712e6eb8c5b9a09ffc7b9fbc12 +uyvy422 adcf64516a19fce44df77082bdb16291 +yuv410p 2d9225153c83ee1132397d619d94d1b3 +yuv411p 8b298af3e43348ca1b11eb8a3252ac6c +yuv420p eba2f135a08829387e2f698ff72a2939 +yuv420p10be 299fe1d785a3d3dd5e70778700d7fb06 +yuv420p10le 8aee004e765a5383be0954f5e916b72f +yuv420p16be 16c009a235cd52b74791a895423152a3 +yuv420p16le 2d59c4f1d0314a5a957a7cfc4b6fabcc yuv420p9be ce880fa07830e5297c22acf6e20555ce yuv420p9le 16543fda8f87d94a6cf857d2e8d4461a -yuv422p bbdc2c9ebbb9cba2683b8215e821bd18 -yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71 -yuv422p10le d0607c260a45c973e6639f4e449730ad -yuv422p16be 3e7a4994a087400beee8e2ff1010619a -yuv422p16le e7b0ad57d34744cfbd01f66accc5beb1 +yuv422p c9bba4529821d796a6ab09f6a5fd355a +yuv422p10be 11af7dfafe8bc025c7e3bd82b830fe8a +yuv422p10le ec04efb76efa79bf0d02b21572371a56 +yuv422p16be 5499502e1c29534a158a1fe60e889f60 +yuv422p16le e3d61fde6978591596bc36b914386623 yuv422p9be 29b71579946940a8c00fa844c9dff507 yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a -yuv440p b8fa0df5e6823acbdd1c83b83a44eff7 -yuv444p bf2748223e2c506109b1484ab7c5192c -yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6 -yuv444p10le 767179dd82846cf00ee4c340c9c1ab74 -yuv444p16be 7e0bfc40d54fb52fa422dafc37780c9b -yuv444p16le 405cc935bfb502ad26900804875b0a81 +yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf +yuv444p 0a98447b78fd476aa39686da6a74fa2e +yuv444p10be 71be185a2fb7a353eb024df9bc63212d +yuv444p10le c1c6b30a12065c7901c0a267e4861a0f +yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90 +yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4 yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054 yuv444p9le f0606604a5c08becab6ba500124c4b7c -yuva420p daf3a17f2dddd6bf9c0281f561e574fd +yuva420p a29884f3f3dfe1e00b961bc17bef3d47 yuva422p 92b6815f465297284cdb843711682cee yuva444p c523716e4900cfe515eaab1d7124fdd9 -yuvj420p 2ec5ee97b265396d426ab2fcf42f5f75 -yuvj422p 40048ec9d2151b927128b7ac93dec259 -yuvj440p 7551571a073caf98805460d31f43a012 -yuvj444p e52f0ea5bf6fb63fcea819f524b5b67e -yuyv422 492785131c4ffe8ec838fd42c51abaca +yuvj420p 32eec78ba51857b16ce9b813a49b7189 +yuvj422p 0dfa0ed434f73be51428758c69e082cb +yuvj440p 657501a28004e27a592757a7509f5189 +yuvj444p 98d3d054f2ec09a75eeed5d328dc75b7 +yuyv422 f2569f2b5069a0ee0cecae33de0455e3 diff --git a/tests/ref/lavfi/pixfmts_copy b/tests/ref/lavfi/pixfmts_copy index c142ba2b9e..dc1b8572dc 100644 --- a/tests/ref/lavfi/pixfmts_copy +++ b/tests/ref/lavfi/pixfmts_copy @@ -1,66 +1,66 @@ -abgr 73847fb78ab01d040bc65307aa2e772d -argb 68262dbda747e9552cf04a06632a7cee -bgr24 e288c39c730970ee1056e858adc094a2 -bgr444be d15710f070a201afe2da5bd2fc1c5c76 -bgr444le fb261abd38568e10f8ebb0be52c207ce -bgr48be 754a33cf60aed44a890d194eb571ec2c -bgr48le 605447329b7242e41e6e4bcc36f87d06 -bgr4_byte 9028891b9beedf5e1e37f627980da330 -bgr555be 9e49d38ab65413f382cafd46ac469640 -bgr555le fe4784e5d4f66130fa63dee552e4720d -bgr565be 90625bce942c002aa1b55e6d77d515e2 -bgr565le d036946273d95741eb7a0593988a7090 -bgr8 2180b117a65abfd26a70458c535aa9b1 -bgra 328a76e72c55508cdf04dc93a5b056fc -gray 847f04953fd848b8c86164d9ba93f54b -gray16be 56cb2303e2f5f2d3a9260db3d6de26ab -gray16le 56cb2303e2f5f2d3a9260db3d6de26ab -monob 0bcbf98de0e633e6ccb62efeb9ab58ef -monow 37c78ca41610436acf9adf5bca7faea7 -nv12 d5e62031f9870c9d7ff5544475f6e590 -nv21 1f695aff75622765316c3dea6e3f2647 -rgb24 8008d64571c68fce43c083b83513eac3 -rgb444be 40308261161f0c54c0b5a11ce1286d11 -rgb444le b7a68135e696901059751d6a55f40df6 -rgb48be 3044840d35ce6550f77942f8204ba13d -rgb48le 8b57ae0801998fc463cfd601761d1686 -rgb4_byte 109b9756a6dc5fae6486af9aad150ead -rgb555be e9a77d923399e647c8f588b3be4cc393 +abgr 037bf9df6a765520ad6d490066bf4b89 +argb c442a8261c2265a07212ef0f72e35f5a +bgr24 0d0cb38ab3fa0b2ec0865c14f78b217b +bgr444be d9ea9307d21b162225b8b2c524cf9477 +bgr444le 88035350e9da3a8f67387890b956f0bc +bgr48be 00624e6c7ec7ab19897ba2f0a3257fe8 +bgr48le d02c235ebba7167881ca2d576497ff84 +bgr4_byte 50d23cc82d9dcef2fd12adb81fb9b806 +bgr555be 49f01b1f1f0c84fd9e776dd34cc3c280 +bgr555le 378d6ac4223651a1adcbf94a3d0d807b +bgr565be 257cf78afa35dc31e9696f139c916715 +bgr565le 1dfdd03995c287e3c754b164bf26a355 +bgr8 24bd566170343d06fec6fccfff5abc54 +bgra 76a18a5151242fa137133f604cd624d2 +gray db08f7f0751900347e6b8649e4164d21 +gray16be 7becf34ae825a3df3969bf4c6bfeb5e2 +gray16le 10bd87059b5c189f3caef2837f4f2b5c +monob 668ebe8b8103b9046b251b2fa8a1d88f +monow 9251497f3b0634f1165d12d5a289d943 +nv12 e0af357888584d36eec5aa0f673793ef +nv21 9a3297f3b34baa038b1f37cb202b512f +rgb24 b41eba9651e1b5fe386289b506188105 +rgb444be 9e89db334568c6b2e3d5d0540f4ba960 +rgb444le 0a68cb6de8bf530aa30c5c1205c25155 +rgb48be cc139ec1dd9451f0e049c0cb3a0c8aa2 +rgb48le 86c5608904f75360d492dbc5c9589969 +rgb4_byte c93ba89b74c504e7f5ae9d9ab1546c73 +rgb555be 912a62c5e53bfcbac2a0340e10973cf2 rgb555le a937a0fc764fb57dc1b3af87cba0273c -rgb565be 538c8b97606f6d98a7002e4c22b40393 -rgb565le 87ec337363dce156cd18792d22d522a4 -rgb8 c5d664ba16c5cb12d2aaad7d4a68ffca -rgba ff1a9f355d43f9d25f07a191b5aa906c -uyvy422 de111a00fa0d71375fea25768d6efe9b -yuv410p 08cf06ff43081c2224f5c310ea7a14ae -yuv411p de4c4062be12f1aacf19b741a8733c2b -yuv420p 46235acb958138b6a77976601b7045ec -yuv420p10be 7605e266c088d0fcf68c7b27c3ceff5f -yuv420p10le 4228ee628c6deec123a13b9784516cc7 -yuv420p16be 5cc2373d3d047895a2ebddc4c1283707 -yuv420p16le 5cc2373d3d047895a2ebddc4c1283707 +rgb565be 9cadf742e05ddc23a3b5b270f89aad3c +rgb565le d39aa298bb525e9be8860351c6f62dab +rgb8 4a9d8e4f2f154e83a7e1735be6300700 +rgba 93a5b3712e6eb8c5b9a09ffc7b9fbc12 +uyvy422 adcf64516a19fce44df77082bdb16291 +yuv410p 2d9225153c83ee1132397d619d94d1b3 +yuv411p 8b298af3e43348ca1b11eb8a3252ac6c +yuv420p eba2f135a08829387e2f698ff72a2939 +yuv420p10be 299fe1d785a3d3dd5e70778700d7fb06 +yuv420p10le 8aee004e765a5383be0954f5e916b72f +yuv420p16be 16c009a235cd52b74791a895423152a3 +yuv420p16le 2d59c4f1d0314a5a957a7cfc4b6fabcc yuv420p9be ce880fa07830e5297c22acf6e20555ce yuv420p9le 16543fda8f87d94a6cf857d2e8d4461a -yuv422p bbdc2c9ebbb9cba2683b8215e821bd18 -yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71 -yuv422p10le d0607c260a45c973e6639f4e449730ad -yuv422p16be 3e7a4994a087400beee8e2ff1010619a -yuv422p16le e7b0ad57d34744cfbd01f66accc5beb1 +yuv422p c9bba4529821d796a6ab09f6a5fd355a +yuv422p10be 11af7dfafe8bc025c7e3bd82b830fe8a +yuv422p10le ec04efb76efa79bf0d02b21572371a56 +yuv422p16be 5499502e1c29534a158a1fe60e889f60 +yuv422p16le e3d61fde6978591596bc36b914386623 yuv422p9be 29b71579946940a8c00fa844c9dff507 yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a -yuv440p b8fa0df5e6823acbdd1c83b83a44eff7 -yuv444p bf2748223e2c506109b1484ab7c5192c -yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6 -yuv444p10le 767179dd82846cf00ee4c340c9c1ab74 -yuv444p16be 7e0bfc40d54fb52fa422dafc37780c9b -yuv444p16le 405cc935bfb502ad26900804875b0a81 +yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf +yuv444p 0a98447b78fd476aa39686da6a74fa2e +yuv444p10be 71be185a2fb7a353eb024df9bc63212d +yuv444p10le c1c6b30a12065c7901c0a267e4861a0f +yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90 +yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4 yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054 yuv444p9le f0606604a5c08becab6ba500124c4b7c -yuva420p daf3a17f2dddd6bf9c0281f561e574fd +yuva420p a29884f3f3dfe1e00b961bc17bef3d47 yuva422p 92b6815f465297284cdb843711682cee yuva444p c523716e4900cfe515eaab1d7124fdd9 -yuvj420p 2ec5ee97b265396d426ab2fcf42f5f75 -yuvj422p 40048ec9d2151b927128b7ac93dec259 -yuvj440p 7551571a073caf98805460d31f43a012 -yuvj444p e52f0ea5bf6fb63fcea819f524b5b67e -yuyv422 492785131c4ffe8ec838fd42c51abaca +yuvj420p 32eec78ba51857b16ce9b813a49b7189 +yuvj422p 0dfa0ed434f73be51428758c69e082cb +yuvj440p 657501a28004e27a592757a7509f5189 +yuvj444p 98d3d054f2ec09a75eeed5d328dc75b7 +yuyv422 f2569f2b5069a0ee0cecae33de0455e3 diff --git a/tests/ref/lavfi/pixfmts_crop b/tests/ref/lavfi/pixfmts_crop index 4c21df2e78..cbbcf90bbf 100644 --- a/tests/ref/lavfi/pixfmts_crop +++ b/tests/ref/lavfi/pixfmts_crop @@ -1,42 +1,42 @@ -abgr 3ea75d2191e50fd995e79d3167eaf4ac -argb 1c7637a98e2bfe24bfaea711ded47de4 -bgr24 bf4d4419dbcf9fe22d7dccf137ab53fb -bgr48be e4d08743c85666faebd9e0b854baeda3 -bgr48le 3507b459228017b619ca3b3eb5bd909d -bgr4_byte 666299d8a2a910bcc4cf43e9432f7c24 -bgr555be 4bf6af9379dab0d27bf9b4b81ecfd4b7 -bgr555le b30a66789470a32c87342195fb9d5d5c -bgr565be 335f53034b43d7ef1eac018e1c2ca8d6 -bgr565le c82b62ee67c177b886158d2a19dbd739 -bgr8 c4a9b1d280bd24ed0fc4173b2ce7bde3 -bgra 240b45176dbc6a852ea8ca8b146812ab -gray 529771169f0fdb6db6a9013c59bbd25c -gray16be cbb5c394080a5f5bbfbbdc20dbf32dcb -gray16le cbb5c394080a5f5bbfbbdc20dbf32dcb -rgb24 08a1446a5547ccc42eefdc0027d35d07 -rgb48be 8734db0ab3316e65fe7693ac6561bacc -rgb48le 7565b41f4fc1003990b979ee66ebdb7e -rgb4_byte 590390da81f5d2fde68714a8b107cf91 -rgb555be ea50843338dc30f06b8b6d394bef45ae +abgr cd761690872843d1b7ab0c695393c751 +argb 2ec6ef18769bcd651c2e8904d5a3ee67 +bgr24 3450fd00cf1493d1ded75544d82ba3ec +bgr48be 18ca4002732f278cc9f525215c2fca41 +bgr48le 395a4c187c4e95217d089bd3df9f3654 +bgr4_byte 2f6ac3cdd4676ab4e2982bdf0664945b +bgr555be d3a7c273604723adeb7e5f5dd1c4272b +bgr555le d22442fc13b464f9ba455b08df4e981f +bgr565be fadceef4a64ad6873fcb43ddee0deb3c +bgr565le 891664e5a54ae5968901347da92bc5e9 +bgr8 4b7159e05765bd4703180072d86423c8 +bgra 395c9f706fccda721471acaa5c96c16c +gray 8c4850e66562a587a292dc728a65ea4a +gray16be daa5a6b98fb4a280c57c57bff1a2ab5a +gray16le 84f5ea7259073edcb893113b42213c8e +rgb24 3b90ed64b687d3dc186c6ef521dc71a8 +rgb48be e6fd353c0eb9bea889423954414bea35 +rgb48le 68a1723da11ce08b502d42e204376503 +rgb4_byte 6958029f73c6cdfed4f71020d816f027 +rgb555be 41a7d1836837bc90f2cae19a9c9df3b3 rgb555le eeb78f8ce6186fba55c941469e60ba67 -rgb565be e572eefa20d4bffca22fb556ff1a618a -rgb565le e3677d571880329ff30fd065eb5b442f -rgb8 819dfa784f263ae580a4e84873e60dcf -rgba f44a3fb71c1d1ebbdecc848939453e93 -yuv410p 3ddd9a2cc90bd5c0d065474fa53e4317 -yuv411p e4ab76b73fbeb140e446768137676cd0 -yuv420p 686a5142f158b7fdc55054d35b47b65e -yuv420p16be e8b764460634b89b676fa535b7426f28 -yuv420p16le e8b764460634b89b676fa535b7426f28 -yuv422p 7e6dc6dc64a2064d40965d7f8100046b -yuv422p16be dd6937520aea93bd44d3a283f20a0474 -yuv422p16le d4d4f1609a608ff8d5b3c8773aecd4ea -yuv440p 027343c5aa141b8bcd80c33cd39373d9 -yuv444p b320c72c56eef223b58ac1d033797ee3 -yuv444p16be 32152e1fcb2f0099f85bde4fb6ef9f5a -yuv444p16le a4df69f0d2ad486b607d86c0c1740504 -yuva420p 05375eeabd41ece7adc70018cf4cc26a -yuvj420p ecb32a5326230237d073dc8c6e6c63b4 -yuvj422p d41c5038dbe61cf9900ddd67e02fa206 -yuvj440p 722479c15d4cbd1980006a197ec5781c -yuvj444p e4e0af5f712e2500b16af39336b7438d +rgb565be b2d1cb525f3a0cfe27753c0d479b2fa9 +rgb565le 6a49700680be9a0d434411825a769556 +rgb8 88b0398c265d1ed7a837dc084fa0917c +rgba fd00b24c7597268c32759a84a1de2de4 +yuv410p a9f2eaa747bf988b7bebe4f442b9c67a +yuv411p 3334d3aef8dba238658090ac172375d1 +yuv420p bfea0188ddd4889787c403caae119cc7 +yuv420p16be 8365eff38b8c329aeb95fc605fa229bb +yuv420p16le 5e8dd38d973d5854abe1ad4efad20cc1 +yuv422p f2f930a91fe00d4252c4720b5ecd8961 +yuv422p16be 167e4338811a7d272925a4c6417d60da +yuv422p16le 3359395d5875d581fa1e975013d30114 +yuv440p 2472417d980e395ad6843cbb8b633b29 +yuv444p 1f151980486848c96bc5585ced99003e +yuv444p16be 1ce8fcd4712d525af983e6179d6a4f9e +yuv444p16le 5f1441e18345aadb3f881dac99c6c08a +yuva420p 7536753dfbc7932560fb50c921369a0e +yuvj420p 21f891093006d42d7683b0e1d773a657 +yuvj422p 9a43d474c407590ad8f213880586b45e +yuvj440p 977351350450ebdbf7a9d20020c6b5a5 +yuvj444p 4a50ba26859dad91dcf7000de0d0efa1 diff --git a/tests/ref/lavfi/pixfmts_hflip b/tests/ref/lavfi/pixfmts_hflip index de21812f76..3741713ee2 100644 --- a/tests/ref/lavfi/pixfmts_hflip +++ b/tests/ref/lavfi/pixfmts_hflip @@ -1,42 +1,42 @@ -abgr 66fb925bedc5155194719dffc2c526b5 -argb e972281410a51a47fa21fce9ec52cab5 -bgr24 54739cc1861449697e7877ca37c95750 -bgr48be 7d4c05f2365aa9f3d1ca17c6f8bba55b -bgr48le 75230cb9bc1381def64609d23797ca30 -bgr4_byte ecf6c84ef788e77eca91f070bfc45efc -bgr555be 4c447c3c3017f49f52bfc9facdfe3efe -bgr555le 6c0d129b668964175c67374ea302343e -bgr565be 3f56b0a17d103c75423c290e037c17bb -bgr565le 5486be524bd8c8bd947862fa359e0847 -bgr8 d9bb81c2c61befec69cd901420748b1f -bgra 0de156867e10a7c5626d667dcfe92697 -gray d0b67c9c9c4bdd4c5554f859026490df -gray16be c87c394fdc24a0b932a02717b37c727c -gray16le c87c394fdc24a0b932a02717b37c727c -rgb24 8121483b7fbfd04b4f207d095df0ee69 -rgb48be 7ddbbb77f57a3f2f95521bafab8e526e -rgb48le 1a3b85db28a0bcb0d16e149f5f85ac3e -rgb4_byte 5353b86cf87796ba6ad3a99c5b5c8f8f -rgb555be 01986e19988788506941bacf6584dc3a +abgr 49468c6c9ceee5d52b08b1270a909323 +argb 50ba9f16c6475530602f2983278b82d0 +bgr24 cc53d2011d097972db0d22756c3699e3 +bgr48be 815192d3757c66de97b0d51818acbe0f +bgr48le 8e4184ac6eae251b4bace51dba7d790c +bgr4_byte aac987e7d1a6a96477cfc0b48a4285de +bgr555be bc07265898440116772200390d70c092 +bgr555le ccee08679bac84a1f960c6c9070c5538 +bgr565be e088789ce46224b87c6e46610ef19add +bgr565le 3703466e19e1b52e03a34fd244a8e8e4 +bgr8 50b505a889f0428242305acb642da107 +bgra 01ca21e7e6a8d1281b4553bde8e8a404 +gray 03efcb4ab52a24c0af0e03cfd26c9377 +gray16be 9bcbca979601ddc4869f846f08f3d1dd +gray16le c1b8965adcc7f847ee343149ff507073 +rgb24 754f1722fc738590cc407ac65749bfe8 +rgb48be d690412ca5fada031b5da47b87096248 +rgb48le c901feb564232f5d0bc0eabd66dae3e7 +rgb4_byte c8a3f995fcf3e0919239ea2c413ddc29 +rgb555be 045ce8607d3910586f4d97481dda8632 rgb555le 8778ee0cf58ce9ad1d99a1eca9f95e87 -rgb565be 3b1181680a9a484ae7d931ca6a3b41ed -rgb565le bdef88bd73ab43a9e18ab64e17c69b5d -rgb8 2ce33cb6718894f4797f5bae9d61b99f -rgba 86948ec56f3f88c9141212d083a3f21f -yuv410p 41c16c3c27b3d709a1a961c774034536 -yuv411p d55b274b5bcbd9292f7b5fff25922733 -yuv420p 6879e666af6a09bed20ee2d593431150 -yuv420p16be cd2f72ae9d8ea1c1b0bfecd8d09d7526 -yuv420p16le cd2f72ae9d8ea1c1b0bfecd8d09d7526 -yuv422p 75b88fe7ab04c45211517c10e30f4899 -yuv422p16be 1e2d97feb13a0e3ca84e43dc81959edb -yuv422p16le 05525fb698a3ba60e7a1d9e5dbbdfc8c -yuv440p 4fba8a5673b7fbe8f85dfe461099caa9 -yuv444p 308403326851b9cc7ccb76e6ed30ea7e -yuv444p16be 05987c028fc245b56f0277f817e1038d -yuv444p16le 20a15ccef6c0b610dfec596e6f721d57 -yuva420p a9f7c23658929c65112d75d5726d2247 -yuvj420p 0f1581aea00551ba2e49d8b180989197 -yuvj422p 052d108d1ef6c9f8c915b59732bffa74 -yuvj440p 11139dfaa9a0fe49aa9948c94dff0b83 -yuvj444p 9355e3071a619724296b65c8f150e191 +rgb565be c8022a1b2470e72f124e4389fad4c372 +rgb565le 2cb690eb3fcb72da3771ad6a48931158 +rgb8 9e462b811b9b6173397b9cfc1f6b2f17 +rgba d3d0dc1ecef3ed72f26a2986d0efc204 +yuv410p acb543ebbbf63eefe533e6faffc006da +yuv411p c626cf6d191139b4ca7efc0155f957f1 +yuv420p 2d5c80f9ba2ddd85b2aeda3564cc7d64 +yuv420p16be 758b0c1e2113b15e7afde48da4e4d024 +yuv420p16le 480ccd951dcb806bc875d307e02e50a0 +yuv422p 6e728f4eb9eae287c224f396d84be6ea +yuv422p16be a05d43cd62b790087bd37083174557de +yuv422p16le 6954abebcbc62d81068d58d0c62bdd5b +yuv440p a99e2b57ed601f39852715c9d675d0d3 +yuv444p 947e47f7bb5fdccc659d19b7df2b6fc3 +yuv444p16be 58c012e5ab73b066ef3c2b6411a395f1 +yuv444p16le 32c12794e184042a59738ab2de608c8d +yuva420p d83ec0c01498189f179ec574918185f1 +yuvj420p df3aaaec3bb157c3bde5f0365af30f4f +yuvj422p d113871528d510a192797af59df9c05c +yuvj440p 07f5ff12ced85aba1b5cf51692fff4bb +yuvj444p 8d95f6b4d4c9b4b0389d36df686bfa46 diff --git a/tests/ref/lavfi/pixfmts_null b/tests/ref/lavfi/pixfmts_null index c142ba2b9e..dc1b8572dc 100644 --- a/tests/ref/lavfi/pixfmts_null +++ b/tests/ref/lavfi/pixfmts_null @@ -1,66 +1,66 @@ -abgr 73847fb78ab01d040bc65307aa2e772d -argb 68262dbda747e9552cf04a06632a7cee -bgr24 e288c39c730970ee1056e858adc094a2 -bgr444be d15710f070a201afe2da5bd2fc1c5c76 -bgr444le fb261abd38568e10f8ebb0be52c207ce -bgr48be 754a33cf60aed44a890d194eb571ec2c -bgr48le 605447329b7242e41e6e4bcc36f87d06 -bgr4_byte 9028891b9beedf5e1e37f627980da330 -bgr555be 9e49d38ab65413f382cafd46ac469640 -bgr555le fe4784e5d4f66130fa63dee552e4720d -bgr565be 90625bce942c002aa1b55e6d77d515e2 -bgr565le d036946273d95741eb7a0593988a7090 -bgr8 2180b117a65abfd26a70458c535aa9b1 -bgra 328a76e72c55508cdf04dc93a5b056fc -gray 847f04953fd848b8c86164d9ba93f54b -gray16be 56cb2303e2f5f2d3a9260db3d6de26ab -gray16le 56cb2303e2f5f2d3a9260db3d6de26ab -monob 0bcbf98de0e633e6ccb62efeb9ab58ef -monow 37c78ca41610436acf9adf5bca7faea7 -nv12 d5e62031f9870c9d7ff5544475f6e590 -nv21 1f695aff75622765316c3dea6e3f2647 -rgb24 8008d64571c68fce43c083b83513eac3 -rgb444be 40308261161f0c54c0b5a11ce1286d11 -rgb444le b7a68135e696901059751d6a55f40df6 -rgb48be 3044840d35ce6550f77942f8204ba13d -rgb48le 8b57ae0801998fc463cfd601761d1686 -rgb4_byte 109b9756a6dc5fae6486af9aad150ead -rgb555be e9a77d923399e647c8f588b3be4cc393 +abgr 037bf9df6a765520ad6d490066bf4b89 +argb c442a8261c2265a07212ef0f72e35f5a +bgr24 0d0cb38ab3fa0b2ec0865c14f78b217b +bgr444be d9ea9307d21b162225b8b2c524cf9477 +bgr444le 88035350e9da3a8f67387890b956f0bc +bgr48be 00624e6c7ec7ab19897ba2f0a3257fe8 +bgr48le d02c235ebba7167881ca2d576497ff84 +bgr4_byte 50d23cc82d9dcef2fd12adb81fb9b806 +bgr555be 49f01b1f1f0c84fd9e776dd34cc3c280 +bgr555le 378d6ac4223651a1adcbf94a3d0d807b +bgr565be 257cf78afa35dc31e9696f139c916715 +bgr565le 1dfdd03995c287e3c754b164bf26a355 +bgr8 24bd566170343d06fec6fccfff5abc54 +bgra 76a18a5151242fa137133f604cd624d2 +gray db08f7f0751900347e6b8649e4164d21 +gray16be 7becf34ae825a3df3969bf4c6bfeb5e2 +gray16le 10bd87059b5c189f3caef2837f4f2b5c +monob 668ebe8b8103b9046b251b2fa8a1d88f +monow 9251497f3b0634f1165d12d5a289d943 +nv12 e0af357888584d36eec5aa0f673793ef +nv21 9a3297f3b34baa038b1f37cb202b512f +rgb24 b41eba9651e1b5fe386289b506188105 +rgb444be 9e89db334568c6b2e3d5d0540f4ba960 +rgb444le 0a68cb6de8bf530aa30c5c1205c25155 +rgb48be cc139ec1dd9451f0e049c0cb3a0c8aa2 +rgb48le 86c5608904f75360d492dbc5c9589969 +rgb4_byte c93ba89b74c504e7f5ae9d9ab1546c73 +rgb555be 912a62c5e53bfcbac2a0340e10973cf2 rgb555le a937a0fc764fb57dc1b3af87cba0273c -rgb565be 538c8b97606f6d98a7002e4c22b40393 -rgb565le 87ec337363dce156cd18792d22d522a4 -rgb8 c5d664ba16c5cb12d2aaad7d4a68ffca -rgba ff1a9f355d43f9d25f07a191b5aa906c -uyvy422 de111a00fa0d71375fea25768d6efe9b -yuv410p 08cf06ff43081c2224f5c310ea7a14ae -yuv411p de4c4062be12f1aacf19b741a8733c2b -yuv420p 46235acb958138b6a77976601b7045ec -yuv420p10be 7605e266c088d0fcf68c7b27c3ceff5f -yuv420p10le 4228ee628c6deec123a13b9784516cc7 -yuv420p16be 5cc2373d3d047895a2ebddc4c1283707 -yuv420p16le 5cc2373d3d047895a2ebddc4c1283707 +rgb565be 9cadf742e05ddc23a3b5b270f89aad3c +rgb565le d39aa298bb525e9be8860351c6f62dab +rgb8 4a9d8e4f2f154e83a7e1735be6300700 +rgba 93a5b3712e6eb8c5b9a09ffc7b9fbc12 +uyvy422 adcf64516a19fce44df77082bdb16291 +yuv410p 2d9225153c83ee1132397d619d94d1b3 +yuv411p 8b298af3e43348ca1b11eb8a3252ac6c +yuv420p eba2f135a08829387e2f698ff72a2939 +yuv420p10be 299fe1d785a3d3dd5e70778700d7fb06 +yuv420p10le 8aee004e765a5383be0954f5e916b72f +yuv420p16be 16c009a235cd52b74791a895423152a3 +yuv420p16le 2d59c4f1d0314a5a957a7cfc4b6fabcc yuv420p9be ce880fa07830e5297c22acf6e20555ce yuv420p9le 16543fda8f87d94a6cf857d2e8d4461a -yuv422p bbdc2c9ebbb9cba2683b8215e821bd18 -yuv422p10be bdc13b630fd668b34c6fe1aae28dfc71 -yuv422p10le d0607c260a45c973e6639f4e449730ad -yuv422p16be 3e7a4994a087400beee8e2ff1010619a -yuv422p16le e7b0ad57d34744cfbd01f66accc5beb1 +yuv422p c9bba4529821d796a6ab09f6a5fd355a +yuv422p10be 11af7dfafe8bc025c7e3bd82b830fe8a +yuv422p10le ec04efb76efa79bf0d02b21572371a56 +yuv422p16be 5499502e1c29534a158a1fe60e889f60 +yuv422p16le e3d61fde6978591596bc36b914386623 yuv422p9be 29b71579946940a8c00fa844c9dff507 yuv422p9le 062b7f9cbb972bf36b5bdb1a7623701a -yuv440p b8fa0df5e6823acbdd1c83b83a44eff7 -yuv444p bf2748223e2c506109b1484ab7c5192c -yuv444p10be e65cbae7e4f1892c23defbc8e8052cf6 -yuv444p10le 767179dd82846cf00ee4c340c9c1ab74 -yuv444p16be 7e0bfc40d54fb52fa422dafc37780c9b -yuv444p16le 405cc935bfb502ad26900804875b0a81 +yuv440p 5a064afe2b453bb52cdb3f176b1aa1cf +yuv444p 0a98447b78fd476aa39686da6a74fa2e +yuv444p10be 71be185a2fb7a353eb024df9bc63212d +yuv444p10le c1c6b30a12065c7901c0a267e4861a0f +yuv444p16be 1c6ea2c2f5e539006112ceec3d4e7d90 +yuv444p16le 20f86bc2f68d2b3f1f2b48b97b2189f4 yuv444p9be 6ab31f4c12b533ce318ecdff83cdd054 yuv444p9le f0606604a5c08becab6ba500124c4b7c -yuva420p daf3a17f2dddd6bf9c0281f561e574fd +yuva420p a29884f3f3dfe1e00b961bc17bef3d47 yuva422p 92b6815f465297284cdb843711682cee yuva444p c523716e4900cfe515eaab1d7124fdd9 -yuvj420p 2ec5ee97b265396d426ab2fcf42f5f75 -yuvj422p 40048ec9d2151b927128b7ac93dec259 -yuvj440p 7551571a073caf98805460d31f43a012 -yuvj444p e52f0ea5bf6fb63fcea819f524b5b67e -yuyv422 492785131c4ffe8ec838fd42c51abaca +yuvj420p 32eec78ba51857b16ce9b813a49b7189 +yuvj422p 0dfa0ed434f73be51428758c69e082cb +yuvj440p 657501a28004e27a592757a7509f5189 +yuvj444p 98d3d054f2ec09a75eeed5d328dc75b7 +yuyv422 f2569f2b5069a0ee0cecae33de0455e3 diff --git a/tests/ref/lavfi/pixfmts_pad b/tests/ref/lavfi/pixfmts_pad index c92c4062f1..03db5a7efd 100644 --- a/tests/ref/lavfi/pixfmts_pad +++ b/tests/ref/lavfi/pixfmts_pad @@ -1,17 +1,17 @@ -abgr 2c47ea5ec3da5dc7f4d2e141fd6841b9 -argb 67430e1f50e4be0913d2cf7d2b6ba4ba -bgr24 5c2e45d97a6c4704882588a7ffae238d -bgra 4030517e296b927680860ba9b0a52e23 -rgb24 2df6b34af4c559b8cfc58a2aeeaa65d5 -rgba e43c083a669144b3c17a833bb19b001d -yuv410p 1d752918e7825f189b9ad001e644545a -yuv411p 7422262bf0395696b8a93c0740ba6e4e -yuv420p d42c9cb1b2185d204012bb19115ad4b0 -yuv422p 2b58291021951d7b24464cdf8b3ca7a0 -yuv440p a5faea7fe20425e5fe17739078e22be6 -yuv444p 4d369cf27838adf636fcaba7dde5e0ea -yuva420p 8d9eb742292e8c99c33fb427111f8064 -yuvj420p 02373f923648cc7e856c3c2ba5c8f927 -yuvj422p 3d34416c03bb783befe22ca76a00e863 -yuvj440p 9f0ba799129481b00483ef81c9b97991 -yuvj444p ee4a9c1fafb0a33f39975f3b82e5e1c4 +abgr e8e5e350c856c051d502cd435a2aa0bd +argb a98e0a1213824ee4566d4891468bb614 +bgr24 ac7417cea8d6e799a31a3c9a39b8f202 +bgra 6113a09a023cb2b08e9cad78eb1eb37a +rgb24 65eed443acc66c4f02bab6df4ebed515 +rgba 74d4158ad0c626e9a7c6923b9ca73294 +yuv410p a5210eb6a9b10c3269899b935df9a2d6 +yuv411p a23380c9698e2d80c9fa8a8b6d4f6854 +yuv420p f8733600369adaea28aa445dbdf2ed4c +yuv422p 3e0d822c11c716e7636387b1bf27c5ff +yuv440p 225dd7fbc8cceb24c26b765187d43a9e +yuv444p 45484f0411d336ce94636da0395f4692 +yuva420p 919722724765dc3a716c38fa53b20580 +yuvj420p 4f20e2799966c21a9d9e0788b0956925 +yuvj422p e4d84b0683f77a76f1c17d976eff127c +yuvj440p 33511c43339aa32533ab832861c150c3 +yuvj444p 82f0badd9d0c062bbfa0d9d73d7240a3 diff --git a/tests/ref/lavfi/pixfmts_scale b/tests/ref/lavfi/pixfmts_scale index f2bd0d79e2..acd40e3451 100644 --- a/tests/ref/lavfi/pixfmts_scale +++ b/tests/ref/lavfi/pixfmts_scale @@ -1,66 +1,66 @@ -abgr f4b0c8dbb5bdfec99958a28e2d324ac9 -argb 16ca3931f0dbe94e398ea48a5bf58b70 -bgr24 888ec832a959f32a4e3904080dbb73ac -bgr444be d95f525f577fa72db9657caf164df1e5 -bgr444le 153fe93cbfb5f6dc847871f87bd21c0a -bgr48be 36d5cf796df5ec2bdbeca030a33023f8 -bgr48le 0f8ecc15b505571b56aa7b9b5989f523 -bgr4_byte 67d4eed793b35b806ca8280319bd5afe -bgr555be b297460489fd56ca5f2ea4ae65021f49 -bgr555le 356e789afbc2a0405af7153b5e729bf7 -bgr565be 58a1111d00a0c3291dfa69c86e9641dc -bgr565le 0842a7981c039178405cd7788e9370e0 -bgr8 4e2078f78e5e3d36bd31ae5ee6ef7c6a -bgra 98dc319426077e7754516e92e4f85aa6 -gray 9737d613a3bcdc2b36f74cc7ac4a51d9 -gray16be 278ab69e5754945d985b299d5e1fa35a -gray16le fe0bce884a330dab249a26edaa0d2ec0 -monob 682379f77415663f1dec565f2fd54489 -monow 1cd1c265dc23d0b1ac65dd4307a99d59 -nv12 1c44aec0a654fab88edfeadc39e09e4e -nv21 9a8aebe1a3883862320c73feee73a7a0 -rgb24 b3c88f4ccc3a47604c81527fb946fc81 -rgb444be 91ccc230a97958e4e6c6bdbffebdafa4 -rgb444le b784ed1a3ebd2038798cf9e68a3a5363 -rgb48be 93ecaa3d1a411f5518ec44ea30ac2a1f -rgb48le a04c290a53f76e8a1eaaa79a7d803591 -rgb4_byte f1a1f3d0958a0e427ae42b30cb0aa387 -rgb555be 74cdf63552a6bb2516f81bed47bf6904 +abgr d894cb97f6c80eb21bdbe8a4eea62d86 +argb 54346f2b2eef10919e0f247241df3b24 +bgr24 570f8d6b51a838aed022ef67535f6bdc +bgr444be 25fe04f73a3bad4140d1c4f96ca5b670 +bgr444le 2fde227e6cea6dca5decdd0b7c0866f7 +bgr48be 390d3058a12a99c2b153ed7922508bea +bgr48le 39fe06feb4ec1d9730dccc04a0cfac4c +bgr4_byte ee1d35a7baf8e9016891929a2f565c0b +bgr555be de8901c1358834fddea060fcb3a67beb +bgr555le 36b745067197f9ca8c1731cac51329c9 +bgr565be 922a2503767036ae9536f4f7823c04ee +bgr565le 3a514a298c6161a071ddf9963c06509d +bgr8 7f007fa6c153a16e808a9c51605a4016 +bgra a5e7040f9a80cccd65e5acf2ca09ace5 +gray d7786a7d9d99ac74230cc045cab5632c +gray16be b554d6c1cc8da23967445be4dd3e4a86 +gray16le 715a33aa1c19cb26b14f5cc000e7a3d1 +monob 88c4c050758e64d120f50c7eff694381 +monow d31772ebaa877fc2a78565937f7f9673 +nv12 4676d59db43d657dc12841f6bc3ab452 +nv21 69c699510ff1fb777b118ebee1002f14 +rgb24 514692e28e8ff6860e415ce4fcf6eb8c +rgb444be 12254053ae93373869fca18b2afcba31 +rgb444le badbd68b59c87df6ae73248309637634 +rgb48be 8fac63787a711886030f8e056872b488 +rgb48le ab92f2763a2eb264c3870cc758f97149 +rgb4_byte d81ffd3add95842a618eec81024f0b5c +rgb555be 4607309f9f217d51cbb53d13b84b4537 rgb555le a350ef1dc2c9688ed49e7ba018843795 -rgb565be 3dff89b6f3fcab02c752041737fb42aa -rgb565le 3a6252b6a1ad70f2478c08da07d27261 -rgb8 89f284975ee055c2e8c01143facb7c06 -rgba fb2184a9bc2186f7b3c4fec1cfab7048 -uyvy422 eb46505182922bf2ce2bfdf70d45e8b9 -yuv410p 6518712b80313c0415770ce7dd669e54 -yuv411p a00f5d54beb3b75b2a60b754d04532dc -yuv420p 0c9995813a18c9f5d050ff706d5fd4a6 -yuv420p10be c143e77e97d2f7d62c3b518857ba9f9b -yuv420p10le 72d90eccf5c34691ff057dafb7447aa2 -yuv420p16be 8467c2c5a44275b7a0d3a0372986ce9d -yuv420p16le 3934438e67be71b72589ec15d700eaac +rgb565be 678ce231c4ea13629c1353b1df4ffbef +rgb565le 6f4bb711238baa762d73305213f8d035 +rgb8 091d0170b354ef0e97312b95feb5483f +rgba a3d362f222098a00e63867f612018659 +uyvy422 314bd486277111a95d9369b944fa0400 +yuv410p 7df8f6d69b56a8dcb6c7ee908e5018b5 +yuv411p 1143e7c5cc28fe0922b051b17733bc4c +yuv420p fdad2d8df8985e3d17e73c71f713cb14 +yuv420p10be 27f28a6e09b1c04d0f755035a5db1f43 +yuv420p10le a5a1692e026590ba2eddb46b9b827529 +yuv420p16be d7270efce54eb59c7b01c14157a1b890 +yuv420p16le e85abf00bad940a922b623c91c9026d7 yuv420p9be bb87fddca65d1742412c8d2b1caf96c6 yuv420p9le 828eec50014a41258a5423c1fe56ac97 -yuv422p c4f6a86378430e898952b5566dfe5606 -yuv422p10be cea7ca6b0e66d6f29539885896c88603 -yuv422p10le a10c4a5837547716f13cd61918b145f9 -yuv422p16be c9c8e130f19c1c01936296f7177ff98d -yuv422p16le c652b73e866e1f9aa1acb7dfb0bc7a57 +yuv422p 918e37701ee7377d16a8a6c119c56a40 +yuv422p10be 315654908d50718e175aae018c484732 +yuv422p10le 91bbc78a9a56f659b55abc17722dcc09 +yuv422p16be e7e34fe9264784763ab6cb406524c0f3 +yuv422p16le c435b76b08204dda6908640fb5fd4621 yuv422p9be 82494823944912f73cebc58ad2979bbd yuv422p9le fc69c8a21f473916a4b4225636b97e06 -yuv440p 8187c98127e06b4fb1b34cc592147fd3 -yuv444p c5cfe213b7559f76df493d8ea2f64a9c -yuv444p10be e9d3c8e744b8b0d8187ca092fa203fc9 -yuv444p10le 02f0a336e9da062a64df1ba487e102c5 -yuv444p16be afaaf3fb1ba4764e5f9ea873e3f34c7e -yuv444p16le 69300728abdbbe8da82dd7116f04a599 +yuv440p 461503fdb9b90451020aa3b25ddf041c +yuv444p 81b2eba962d12e8d64f003ac56f6faf2 +yuv444p10be fb304d77c6d2e18df5938662a22176f0 +yuv444p10le b17136913eb066dca6be6af645b9f7e8 +yuv444p16be 0da9bed80f5542682ab286f3261cf24c +yuv444p16le a0c5d3c7bf3f181db503cf8e450d1335 yuv444p9be 9ac2643ce7f7e5c4e17c8c9fd8494d4a yuv444p9le 896a1cc9cccca1ba410dd53942d33cc4 -yuva420p fdb69fb6cc9e3aa983374c9db8f29eec +yuva420p 8673a9131fb47de69788863f93a50eb7 yuva422p 3c76ebeca0a7d3aa5f8e31ef80a86ffe yuva444p 3268c6abe5e3cdbd16552a1eddced816 -yuvj420p 010ce3f530e23e3dddb78c7b32aa4ed4 -yuvj422p 7ac51d77ebf61c0372c56c7c7ff5913f -yuvj440p 2bb582a8e6beddaa8bf3d96858d903ac -yuvj444p 674375ff81cbd8bb96bca4566f620ba7 -yuyv422 9d6d9667443e4359b392e5e7af5a82ec +yuvj420p 30427bd6caf5bda93a173dbebe759e09 +yuvj422p fc8288f64fd149573f73cf8da05d8e6d +yuvj440p 508ac7a9ddeb6d1794a1100ba7a1664c +yuvj444p 73aebe144085b22d1189caf6ca07e18c +yuyv422 169e19ac91b257bd84ace0fdf56559ad diff --git a/tests/ref/lavfi/pixfmts_vflip b/tests/ref/lavfi/pixfmts_vflip index f980d07a39..a4dffb9c22 100644 --- a/tests/ref/lavfi/pixfmts_vflip +++ b/tests/ref/lavfi/pixfmts_vflip @@ -1,66 +1,66 @@ -abgr 39270c968598bac0ef53faaa5f9ab7cd -argb 099dc071d7385b2958e36604c2fbf4ef -bgr24 d7fd19a5e2ddec014ec483a6f807f773 -bgr444be 315a3d2b921326db4aeef512c674834f -bgr444le 42ad8afaa17d8256eb5c8616af5b5fc3 -bgr48be 159bb03b8383a8231c7faf4462bf4a3f -bgr48le 4ce6287c9dc835366d695afefdfa6da7 -bgr4_byte 384ddc3c9797f08f468b33328952d7c0 -bgr555be 105658d99e190e5b64f5858484606501 -bgr555le e1761ffd7aa99b66e0e026b7b4a20ae5 -bgr565be ac19809e846662b237112d117d0cf056 -bgr565le 5bcafb5b24abf9feaf95b70380cd4494 -bgr8 92aff068b09448adc0643f6c807a78fc -bgra e03d3ee0b977f6d86e5116b20494bef5 -gray 6c44273c4a4a9676078fb2680259d9d6 -gray16be 9816387666a24fbec942cf1636ae7bac -gray16le 9816387666a24fbec942cf1636ae7bac -monob 1173d22fcaa1dcd26c0bd5a906928033 -monow 77021318fe158b1a08f2fd5e712a5e6c -nv12 539436fde931a45cb438d7902de7b6c0 -nv21 c6357ecd64dae698e25c3ca3f2331500 -rgb24 1af81a69b65c340b3b8f43150c568f4e -rgb444be 9ccc19256e99503a5656bb88f0faf8b7 -rgb444le 5a23015e7df8a0f45dd2a86cbe8ca37c -rgb48be 074f11f466ff6fc2bfebdad3136e0d6b -rgb48le da585c76f8411e58d31c94a51b66e8c4 -rgb4_byte d4349af4d8868b8740fcf1dad1363e77 -rgb555be 8e983bde68651b279f6b9fdc89eb1416 +abgr 25e72e9dbd01ab00727c976d577f7be5 +argb 19869bf1a5ac0b6af4d8bbe2c104533c +bgr24 89108a4ba00201f79b75b9305c42352d +bgr444be 9ef12c42fb791948ca4423c452dc6b9a +bgr444le 3650ecfc163abd1596c0cd29d130c4b0 +bgr48be 2f23931844f57641f3737348182d118c +bgr48le 4242a026012b6c135a6aa138a6d67031 +bgr4_byte 407fcf564ed764c38e1d748f700ab921 +bgr555be f739d2519f7e9d494359bf67a3821537 +bgr555le bd7b3ec4d684dfad075d89a606cb8b74 +bgr565be f19e9a4786395e1ddcd51399c98c9f6c +bgr565le fdb617533e1e7ff512ea5b6b6233e738 +bgr8 c60f93fd152c6903391d1fe9decd3547 +bgra 7f9b799fb48544e49ce93e91d7f9fca8 +gray 30d9014a9d43b5f37e7aa64be3a3ecfc +gray16be 6b84b85d3326182fa1217e138249edc5 +gray16le 66bb8faa09dc149734aca3c768a6d4e1 +monob d0cf8732677a5360b6160133043590d8 +monow ff9869d067ecb94eb9d90c9750c31fea +nv12 046f00f598ce14d9854a3534a5c99114 +nv21 01ea369dd2d0d3ed7451dc5c8d61497f +rgb24 eaefabc168d0b14576bab45bc1e56e1e +rgb444be 06722e03f8404e7d2226665ed2444a32 +rgb444le 185c9a5d9c2877484310d4196ef4cd6f +rgb48be 62dd185862ed142283bd300eb6dbd216 +rgb48le dcb76353268bc5862194d131762220da +rgb4_byte 8c6ff02df0b06dd2d574836c3741b2a2 +rgb555be 40dc33cfb5cf56aac1c5a290ac486c36 rgb555le 4f8eaad29a17e0f8e9d8ab743e76b999 -rgb565be a9483bdaec8840b6e7b2256dda00bfad -rgb565le fc681b3d23ad9ef7e8c83c93e4ef37b1 -rgb8 85d929a91b543b3ed871f3b5d702e47c -rgba 330bd6168e46c0d5eb4acbdbb50afa2e -uyvy422 5fb09cfbc5c15e900522e86fdc0bab46 -yuv410p a2f9fa925a788be39635d9d25d5a33e1 -yuv411p 481acae2a62cb6cb59948353fb1bdcf0 -yuv420p 2a723a3b78a86381fd9331e85385f612 -yuv420p10be df97d20b3b4a10c174d4360552c4160d -yuv420p10le 4b5249208602b941332945c926f80ae9 -yuv420p16be d7c65e21af4366760c9196cb54841577 -yuv420p16le d7c65e21af4366760c9196cb54841577 +rgb565be b57623ad9df74648339311a0edcebc7b +rgb565le 73f247a3315dceaea3022ac7c197c5ef +rgb8 13a8d89ef78d8127297d899005456ff0 +rgba 1fc6e920a42ec812aaa3b2aa02f37987 +uyvy422 ffbd36720c77398d9a0d03ce2625928f +yuv410p 7bfb39d7afb49d6a6173e6b23ae321eb +yuv411p 4a90048cc3a65fac150e53289700efe1 +yuv420p 2e6d6062e8cad37fb3ab2c433b55f382 +yuv420p10be fb0772f5e2b9da20ff826e64c3893137 +yuv420p10le e95879e14c4a6805f39643964baf41f7 +yuv420p16be 539076782902664a8acf381bf4f713e8 +yuv420p16le 0f609e588e5a258644ef85170d70e030 yuv420p9be be40ec975fb2873891643cbbbddbc3b0 yuv420p9le 7e606310d3f5ff12badf911e8f333471 -yuv422p 3c6cd98020a8822430015a1d4f643f6c -yuv422p10be 588fe319b96513c32e21d3e32b45447f -yuv422p10le 11b57f2bd9661024153f3973b9090cdb -yuv422p16be 161f9b97be9dd6801878a0ee2f8149de -yuv422p16le 98165fb4c7a8ba83fb592021347d7212 +yuv422p d7f5cb44d9b0210d66d6a8762640ab34 +yuv422p10be 0be8378c3773e1c0b394315ef4994351 +yuv422p10le 6518094fe8de6bee95af21af1e5dc1e1 +yuv422p16be 9bd8f8c961822b586fa4cf992be54acc +yuv422p16le 9c4a1239605c7952b736ac3130163f14 yuv422p9be 7c6f1e140b3999ee7d923854e507752a yuv422p9le 51f10d79c07989060dd06e767e6d7d60 -yuv440p 0b9b909c1fbc520cc91f1b2bc319f84c -yuv444p bc483d89637ed7d27cde1d1085154564 -yuv444p10be 944a4997c4edb3a8dd0f0493cfd5a1fd -yuv444p10le 2d0947ae89ecc6a501eee6832cb27e06 -yuv444p16be 3dde1ec591100800d4ee6ec931ac1c4d -yuv444p16le 506ad8e766ee0b601e18a4290d2b9c1f +yuv440p 876385e96165acf51271b20e5d85a416 +yuv444p 9c3c667d1613b72d15bc6d851c5eb8f7 +yuv444p10be ee069cc6db48975eb029d72f889a7fe6 +yuv444p10le 645b3335248113cafe3c29edb1d7f3be +yuv444p16be de2dedfc6f12073ffead113f86e07ecf +yuv444p16le 8e83323cf102d6c823a03ae8a7b7e033 yuv444p9be 6ac92b7dc9ab2fc59bee99204886899a yuv444p9le 85aef13a654953d3455d89770b0d74bd -yuva420p 34af9677e70b0d54a42d44107f6e5cff +yuva420p c705d1cf061d8c6580ac690b55f92276 yuva422p 6aed0ea657ed51cc047a4fbdd981aec8 yuva444p da5d64f2b2bd2013c186456f595fad65 -yuvj420p 20f0ff8b4e202bd0a118acca9c774beb -yuvj422p 948e6239dfc78a85a575d92e7968bb6f -yuvj440p 60cfe7a12efa3c75a60579d56cd8f5c6 -yuvj444p ff09cf2a6250f08c130cd91402d67c80 -yuyv422 fa64091239484eb461f44f54f324bb80 +yuvj420p 41fd02b204da0ab62452cd14b595e2e4 +yuvj422p 7f6ca9bc1812cde02036d7d29a7cce43 +yuvj440p 25711c3c0fd15ec19c59a10784fcfb96 +yuvj444p e45dee2ac02276dfab92e8ebfbe52e00 +yuyv422 e944ff7316cd03c42c091717ce74f602 diff --git a/tests/ref/lavfi/scale200 b/tests/ref/lavfi/scale200 index dbb3be7327..17103a256d 100644 --- a/tests/ref/lavfi/scale200 +++ b/tests/ref/lavfi/scale200 @@ -1 +1 @@ -scale200 c11aba7c133cba17d8e522c1904a98d5 +scale200 aebdc1c3e08da2a925ba7212b1fadee0 diff --git a/tests/ref/lavfi/scale500 b/tests/ref/lavfi/scale500 index b1a9b9d9b7..93ba4f2485 100644 --- a/tests/ref/lavfi/scale500 +++ b/tests/ref/lavfi/scale500 @@ -1 +1 @@ -scale500 4815689a16d30fcb858ca6cfc20dbceb +scale500 ef865c51156e55ce1ce38c8f90a709e6 diff --git a/tests/ref/lavfi/vflip b/tests/ref/lavfi/vflip index 51456eafbf..66b873270a 100644 --- a/tests/ref/lavfi/vflip +++ b/tests/ref/lavfi/vflip @@ -1 +1 @@ -vflip 2a723a3b78a86381fd9331e85385f612 +vflip 2e6d6062e8cad37fb3ab2c433b55f382 diff --git a/tests/ref/lavfi/vflip_crop b/tests/ref/lavfi/vflip_crop index 0a83fb0ede..6bb832f4cc 100644 --- a/tests/ref/lavfi/vflip_crop +++ b/tests/ref/lavfi/vflip_crop @@ -1 +1 @@ -vflip_crop 23998d61923d72982c618ed806d6cf9d +vflip_crop 72ee0d0dfc8af0cd94a466760313654d diff --git a/tests/ref/lavfi/vflip_vflip b/tests/ref/lavfi/vflip_vflip index 0d067e9be7..b719745dc6 100644 --- a/tests/ref/lavfi/vflip_vflip +++ b/tests/ref/lavfi/vflip_vflip @@ -1 +1 @@ -vflip_vflip 46235acb958138b6a77976601b7045ec +vflip_vflip eba2f135a08829387e2f698ff72a2939 From 1fbaabefc4bbd1d4eed3c84b78e84ac38a339cab Mon Sep 17 00:00:00 2001 From: Mans Rullgard Date: Sat, 13 Oct 2012 22:57:23 +0100 Subject: [PATCH 3/7] network: #include stdint.h in network.h This header uses various types provided by stdint.h without explicitly including it. Signed-off-by: Mans Rullgard --- libavformat/network.h | 1 + 1 file changed, 1 insertion(+) diff --git a/libavformat/network.h b/libavformat/network.h index 19c5a92256..da9d9263ab 100644 --- a/libavformat/network.h +++ b/libavformat/network.h @@ -22,6 +22,7 @@ #define AVFORMAT_NETWORK_H #include +#include #include "config.h" #include "libavutil/error.h" From c0a6cac2920e47da9257845d6ded10138083fe6c Mon Sep 17 00:00:00 2001 From: Diego Biurrun Date: Fri, 5 Oct 2012 19:02:42 +0200 Subject: [PATCH 4/7] fate: Add rangecoder test --- tests/fate/libavcodec.mak | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/tests/fate/libavcodec.mak b/tests/fate/libavcodec.mak index 2aa9596cdd..765a1b8489 100644 --- a/tests/fate/libavcodec.mak +++ b/tests/fate/libavcodec.mak @@ -7,4 +7,10 @@ FATE_LIBAVCODEC += fate-iirfilter fate-iirfilter: libavcodec/iirfilter-test$(EXESUF) fate-iirfilter: CMD = run libavcodec/iirfilter-test +FATE_LIBAVCODEC += fate-rangecoder +fate-rangecoder: libavcodec/rangecoder-test$(EXESUF) +fate-rangecoder: CMD = run libavcodec/rangecoder-test +fate-rangecoder: CMP = null +fate-rangecoder: REF = /dev/null + fate-libavcodec: $(FATE_LIBAVCODEC) From 9a978b334b9b905c3bd4f858b9479c415ce61f51 Mon Sep 17 00:00:00 2001 From: Luca Barbato Date: Thu, 11 Oct 2012 18:55:53 +0200 Subject: [PATCH 5/7] ffv1: K&R formatting cosmetics Signed-off-by: Diego Biurrun --- libavcodec/ffv1.c | 1993 ++++++++++++++++++++++++--------------------- 1 file changed, 1055 insertions(+), 938 deletions(-) diff --git a/libavcodec/ffv1.c b/libavcodec/ffv1.c index e6ee96d722..f290b940e8 100644 --- a/libavcodec/ffv1.c +++ b/libavcodec/ffv1.c @@ -25,6 +25,7 @@ * FF Video Codec 1 (a lossless codec) */ +#include "libavutil/avassert.h" #include "avcodec.h" #include "get_bits.h" #include "put_bits.h" @@ -32,7 +33,6 @@ #include "rangecoder.h" #include "golomb.h" #include "mathops.h" -#include "libavutil/avassert.h" #define MAX_PLANES 4 #define CONTEXT_SIZE 32 @@ -42,109 +42,109 @@ extern const uint8_t ff_log2_run[41]; -static const int8_t quant5_10bit[256]={ - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-1, --1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, --1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, --1,-1,-1,-1,-1,-1,-0,-0,-0,-0,-0,-0,-0,-0,-0,-0, +static const int8_t quant5_10bit[256] = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -0, -0, -0, -0, -0, -0, -0, -0, -0, -0, }; -static const int8_t quant5[256]={ - 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-1,-1,-1, +static const int8_t quant5[256] = { + 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, -1, -1, -1, }; -static const int8_t quant9_10bit[256]={ - 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-3,-3,-3,-3,-3,-3,-3, --3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3,-3, --3,-3,-3,-3,-3,-3,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, --2,-2,-2,-2,-1,-1,-1,-1,-1,-1,-1,-1,-0,-0,-0,-0, +static const int8_t quant9_10bit[256] = { + 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, + 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -3, -3, -3, -3, -3, -3, -3, + -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, + -3, -3, -3, -3, -3, -3, -2, -2, -2, -2, -2, -2, -2, -2, -2, -2, + -2, -2, -2, -2, -1, -1, -1, -1, -1, -1, -1, -1, -0, -0, -0, -0, }; -static const int8_t quant11[256]={ - 0, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, - 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, - 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, - 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5, --5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-5,-4,-4, --4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4, --4,-4,-4,-4,-4,-3,-3,-3,-3,-3,-3,-3,-2,-2,-2,-1, +static const int8_t quant11[256] = { + 0, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, + 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, + 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, + -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -5, -4, -4, + -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, + -4, -4, -4, -4, -4, -3, -3, -3, -3, -3, -3, -3, -2, -2, -2, -1, }; -static const uint8_t ver2_state[256]= { - 0, 10, 10, 10, 10, 16, 16, 16, 28, 16, 16, 29, 42, 49, 20, 49, - 59, 25, 26, 26, 27, 31, 33, 33, 33, 34, 34, 37, 67, 38, 39, 39, - 40, 40, 41, 79, 43, 44, 45, 45, 48, 48, 64, 50, 51, 52, 88, 52, - 53, 74, 55, 57, 58, 58, 74, 60, 101, 61, 62, 84, 66, 66, 68, 69, - 87, 82, 71, 97, 73, 73, 82, 75, 111, 77, 94, 78, 87, 81, 83, 97, - 85, 83, 94, 86, 99, 89, 90, 99, 111, 92, 93, 134, 95, 98, 105, 98, - 105, 110, 102, 108, 102, 118, 103, 106, 106, 113, 109, 112, 114, 112, 116, 125, - 115, 116, 117, 117, 126, 119, 125, 121, 121, 123, 145, 124, 126, 131, 127, 129, - 165, 130, 132, 138, 133, 135, 145, 136, 137, 139, 146, 141, 143, 142, 144, 148, - 147, 155, 151, 149, 151, 150, 152, 157, 153, 154, 156, 168, 158, 162, 161, 160, - 172, 163, 169, 164, 166, 184, 167, 170, 177, 174, 171, 173, 182, 176, 180, 178, - 175, 189, 179, 181, 186, 183, 192, 185, 200, 187, 191, 188, 190, 197, 193, 196, - 197, 194, 195, 196, 198, 202, 199, 201, 210, 203, 207, 204, 205, 206, 208, 214, - 209, 211, 221, 212, 213, 215, 224, 216, 217, 218, 219, 220, 222, 228, 223, 225, - 226, 224, 227, 229, 240, 230, 231, 232, 233, 234, 235, 236, 238, 239, 237, 242, - 241, 243, 242, 244, 245, 246, 247, 248, 249, 250, 251, 252, 252, 253, 254, 255, +static const uint8_t ver2_state[256] = { + 0, 10, 10, 10, 10, 16, 16, 16, 28, 16, 16, 29, 42, 49, 20, 49, + 59, 25, 26, 26, 27, 31, 33, 33, 33, 34, 34, 37, 67, 38, 39, 39, + 40, 40, 41, 79, 43, 44, 45, 45, 48, 48, 64, 50, 51, 52, 88, 52, + 53, 74, 55, 57, 58, 58, 74, 60, 101, 61, 62, 84, 66, 66, 68, 69, + 87, 82, 71, 97, 73, 73, 82, 75, 111, 77, 94, 78, 87, 81, 83, 97, + 85, 83, 94, 86, 99, 89, 90, 99, 111, 92, 93, 134, 95, 98, 105, 98, + 105, 110, 102, 108, 102, 118, 103, 106, 106, 113, 109, 112, 114, 112, 116, 125, + 115, 116, 117, 117, 126, 119, 125, 121, 121, 123, 145, 124, 126, 131, 127, 129, + 165, 130, 132, 138, 133, 135, 145, 136, 137, 139, 146, 141, 143, 142, 144, 148, + 147, 155, 151, 149, 151, 150, 152, 157, 153, 154, 156, 168, 158, 162, 161, 160, + 172, 163, 169, 164, 166, 184, 167, 170, 177, 174, 171, 173, 182, 176, 180, 178, + 175, 189, 179, 181, 186, 183, 192, 185, 200, 187, 191, 188, 190, 197, 193, 196, + 197, 194, 195, 196, 198, 202, 199, 201, 210, 203, 207, 204, 205, 206, 208, 214, + 209, 211, 221, 212, 213, 215, 224, 216, 217, 218, 219, 220, 222, 228, 223, 225, + 226, 224, 227, 229, 240, 230, 231, 232, 233, 234, 235, 236, 238, 239, 237, 242, + 241, 243, 242, 244, 245, 246, 247, 248, 249, 250, 251, 252, 252, 253, 254, 255, }; -typedef struct VlcState{ +typedef struct VlcState { int16_t drift; uint16_t error_sum; int8_t bias; uint8_t count; } VlcState; -typedef struct PlaneContext{ +typedef struct PlaneContext { int16_t quant_table[MAX_CONTEXT_INPUTS][256]; int quant_table_index; int context_count; @@ -155,7 +155,7 @@ typedef struct PlaneContext{ #define MAX_SLICES 256 -typedef struct FFV1Context{ +typedef struct FFV1Context { AVCodecContext *avctx; RangeCoder c; GetBitContext gb; @@ -169,7 +169,7 @@ typedef struct FFV1Context{ int picture_number; AVFrame picture; int plane_count; - int ac; ///< 1=range coder <-> 0=golomb rice + int ac; // 1 = range coder <-> 0 = golomb rice PlaneContext plane[MAX_PLANES]; int16_t quant_table[MAX_CONTEXT_INPUTS][256]; int16_t quant_tables[MAX_QUANT_TABLES][MAX_CONTEXT_INPUTS][256]; @@ -193,15 +193,16 @@ typedef struct FFV1Context{ int slice_height; int slice_x; int slice_y; -}FFV1Context; - -static av_always_inline int fold(int diff, int bits){ - if(bits==8) - diff= (int8_t)diff; - else{ - diff+= 1<<(bits-1); - diff&=(1<quant_table[3][127]){ - const int TT= last2[0]; - const int LL= src[-2]; - return p->quant_table[0][(L-LT) & 0xFF] + p->quant_table[1][(LT-T) & 0xFF] + p->quant_table[2][(T-RT) & 0xFF] - +p->quant_table[3][(LL-L) & 0xFF] + p->quant_table[4][(TT-T) & 0xFF]; - }else - return p->quant_table[0][(L-LT) & 0xFF] + p->quant_table[1][(LT-T) & 0xFF] + p->quant_table[2][(T-RT) & 0xFF]; + const int LT = last[-1]; + const int T = last[0]; + const int RT = last[1]; + const int L = src[-1]; + + if (p->quant_table[3][127]) { + const int TT = last2[0]; + const int LL = src[-2]; + return p->quant_table[0][(L - LT) & 0xFF] + + p->quant_table[1][(LT - T) & 0xFF] + + p->quant_table[2][(T - RT) & 0xFF] + + p->quant_table[3][(LL - L) & 0xFF] + + p->quant_table[4][(TT - T) & 0xFF]; + } else + return p->quant_table[0][(L - LT) & 0xFF] + + p->quant_table[1][(LT - T) & 0xFF] + + p->quant_table[2][(T - RT) & 0xFF]; } -static void find_best_state(uint8_t best_state[256][256], const uint8_t one_state[256]){ - int i,j,k,m; +static void find_best_state(uint8_t best_state[256][256], + const uint8_t one_state[256]) +{ + int i, j, k, m; double l2tab[256]; - for(i=1; i<256; i++) - l2tab[i]= log2(i/256.0); + for (i = 1; i < 256; i++) + l2tab[i] = log2(i / 256.0); - for(i=0; i<256; i++){ + for (i = 0; i < 256; i++) { double best_len[256]; - double p= i/256.0; - - for(j=0; j<256; j++) - best_len[j]= 1<<30; - - for(j=FFMAX(i-10,1); j=0; i--){ - put_rac(c, state+22+i, (a>>i)&1); //22..31 - } - - if(is_signed) - put_rac(c, state+11 + e, v < 0); //11..21 - }else{ - for(i=0; i=0; i--){ - put_rac(c, state+22+FFMIN(i,9), (a>>i)&1); //22..31 - } - - if(is_signed) - put_rac(c, state+11 + 10, v < 0); //11..21 +#define put_rac(C, S, B) \ + do { \ + if (rc_stat) { \ + rc_stat[*(S)][B]++; \ + rc_stat2[(S) - state][B]++; \ + } \ + put_rac(C, S, B); \ + } while (0) + + if (v) { + const int a = FFABS(v); + const int e = av_log2(a); + put_rac(c, state + 0, 0); + if (e <= 9) { + for (i = 0; i < e; i++) + put_rac(c, state + 1 + i, 1); // 1..10 + put_rac(c, state + 1 + i, 0); + + for (i = e - 1; i >= 0; i--) + put_rac(c, state + 22 + i, (a >> i) & 1); // 22..31 + + if (is_signed) + put_rac(c, state + 11 + e, v < 0); // 11..21 + } else { + for (i = 0; i < e; i++) + put_rac(c, state + 1 + FFMIN(i, 9), 1); // 1..10 + put_rac(c, state + 1 + 9, 0); + + for (i = e - 1; i >= 0; i--) + put_rac(c, state + 22 + FFMIN(i, 9), (a >> i) & 1); // 22..31 + + if (is_signed) + put_rac(c, state + 11 + 10, v < 0); // 11..21 } - }else{ - put_rac(c, state+0, 1); + } else { + put_rac(c, state + 0, 1); } #undef put_rac } -static av_noinline void put_symbol(RangeCoder *c, uint8_t *state, int v, int is_signed){ +static av_noinline void put_symbol(RangeCoder *c, uint8_t *state, + int v, int is_signed) +{ put_symbol_inline(c, state, v, is_signed, NULL, NULL); } -static inline av_flatten int get_symbol_inline(RangeCoder *c, uint8_t *state, int is_signed){ - if(get_rac(c, state+0)) +static inline av_flatten int get_symbol_inline(RangeCoder *c, uint8_t *state, + int is_signed) +{ + if (get_rac(c, state + 0)) return 0; - else{ + else { int i, e, a; - e= 0; - while(get_rac(c, state+1 + FFMIN(e,9))){ //1..10 + e = 0; + while (get_rac(c, state + 1 + FFMIN(e, 9))) // 1..10 e++; - } - a= 1; - for(i=e-1; i>=0; i--){ - a += a + get_rac(c, state+22 + FFMIN(i,9)); //22..31 - } + a = 1; + for (i = e - 1; i >= 0; i--) + a += a + get_rac(c, state + 22 + FFMIN(i, 9)); // 22..31 - e= -(is_signed && get_rac(c, state+11 + FFMIN(e, 10))); //11..21 - return (a^e)-e; + e = -(is_signed && get_rac(c, state + 11 + FFMIN(e, 10))); // 11..21 + return (a ^ e) - e; } } -static av_noinline int get_symbol(RangeCoder *c, uint8_t *state, int is_signed){ +static av_noinline int get_symbol(RangeCoder *c, uint8_t *state, int is_signed) +{ return get_symbol_inline(c, state, is_signed); } -static inline void update_vlc_state(VlcState * const state, const int v){ - int drift= state->drift; - int count= state->count; +static inline void update_vlc_state(VlcState *const state, const int v) +{ + int drift = state->drift; + int count = state->count; state->error_sum += FFABS(v); - drift += v; + drift += v; - if(count == 128){ //FIXME variable - count >>= 1; - drift >>= 1; + if (count == 128) { // FIXME: variable + count >>= 1; + drift >>= 1; state->error_sum >>= 1; } count++; - if(drift <= -count){ - if(state->bias > -128) state->bias--; + if (drift <= -count) { + if (state->bias > -128) + state->bias--; drift += count; - if(drift <= -count) - drift= -count + 1; - }else if(drift > 0){ - if(state->bias < 127) state->bias++; + if (drift <= -count) + drift = -count + 1; + } else if (drift > 0) { + if (state->bias < 127) + state->bias++; drift -= count; - if(drift > 0) - drift= 0; + if (drift > 0) + drift = 0; } - state->drift= drift; - state->count= count; + state->drift = drift; + state->count = count; } -static inline void put_vlc_symbol(PutBitContext *pb, VlcState * const state, int v, int bits){ +static inline void put_vlc_symbol(PutBitContext *pb, VlcState *const state, + int v, int bits) +{ int i, k, code; v = fold(v - state->bias, bits); - i= state->count; - k=0; - while(i < state->error_sum){ //FIXME optimize + i = state->count; + k = 0; + while (i < state->error_sum) { // FIXME: optimize k++; i += i; } - assert(k<=8); + assert(k <= 8); #if 0 // JPEG LS - if(k==0 && 2*state->drift <= - state->count) code= v ^ (-1); - else code= v; + if (k == 0 && 2 * state->drift <= -state->count) + code = v ^ (-1); + else + code = v; #else - code= v ^ ((2*state->drift + state->count)>>31); + code = v ^ ((2 * state->drift + state->count) >> 31); #endif - av_dlog(NULL, "v:%d/%d bias:%d error:%d drift:%d count:%d k:%d\n", v, code, - state->bias, state->error_sum, state->drift, state->count, k); + av_dlog(NULL, "v:%d/%d bias:%d error:%d drift:%d count:%d k:%d\n", v, code, + state->bias, state->error_sum, state->drift, state->count, k); set_sr_golomb(pb, code, k, 12, bits); update_vlc_state(state, v); } -static inline int get_vlc_symbol(GetBitContext *gb, VlcState * const state, int bits){ +static inline int get_vlc_symbol(GetBitContext *gb, VlcState *const state, + int bits) +{ int k, i, v, ret; - i= state->count; - k=0; - while(i < state->error_sum){ //FIXME optimize + i = state->count; + k = 0; + while (i < state->error_sum) { // FIXME: optimize k++; i += i; } - assert(k<=8); + assert(k <= 8); - v= get_sr_golomb(gb, k, 12, bits); + v = get_sr_golomb(gb, k, 12, bits); av_dlog(NULL, "v:%d bias:%d error:%d drift:%d count:%d k:%d", v, state->bias, state->error_sum, state->drift, state->count, k); #if 0 // JPEG LS - if(k==0 && 2*state->drift <= - state->count) v ^= (-1); + if (k == 0 && 2 * state->drift <= -state->count) + v ^= (-1); #else - v ^= ((2*state->drift + state->count)>>31); + v ^= ((2 * state->drift + state->count) >> 31); #endif - ret= fold(v + state->bias, bits); + ret = fold(v + state->bias, bits); update_vlc_state(state, v); @@ -442,62 +462,65 @@ static av_always_inline int encode_line(FFV1Context *s, int w, int16_t *sample[3], int plane_index, int bits) { - PlaneContext * const p= &s->plane[plane_index]; - RangeCoder * const c= &s->c; + PlaneContext *const p = &s->plane[plane_index]; + RangeCoder *const c = &s->c; int x; - int run_index= s->run_index; - int run_count=0; - int run_mode=0; + int run_index = s->run_index; + int run_count = 0; + int run_mode = 0; - if(s->ac){ - if(c->bytestream_end - c->bytestream < w*20){ + if (s->ac) { + if (c->bytestream_end - c->bytestream < w * 20) { av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n"); return -1; } - }else{ - if(s->pb.buf_end - s->pb.buf - (put_bits_count(&s->pb)>>3) < w*4){ + } else { + if (s->pb.buf_end - s->pb.buf - (put_bits_count(&s->pb) >> 3) < w * 4) { av_log(s->avctx, AV_LOG_ERROR, "encoded frame too large\n"); return -1; } } - for(x=0; xac){ - if(s->flags & CODEC_FLAG_PASS1){ - put_symbol_inline(c, p->state[context], diff, 1, s->rc_stat, s->rc_stat2[p->quant_table_index][context]); - }else{ + if (s->ac) { + if (s->flags & CODEC_FLAG_PASS1) { + put_symbol_inline(c, p->state[context], diff, 1, s->rc_stat, + s->rc_stat2[p->quant_table_index][context]); + } else { put_symbol_inline(c, p->state[context], diff, 1, NULL, NULL); } - }else{ - if(context == 0) run_mode=1; - - if(run_mode){ - - if(diff){ - while(run_count >= 1<= 1 << ff_log2_run[run_index]) { + run_count -= 1 << ff_log2_run[run_index]; run_index++; put_bits(&s->pb, 1, 1); } put_bits(&s->pb, 1 + ff_log2_run[run_index], run_count); - if(run_index) run_index--; - run_count=0; - run_mode=0; - if(diff>0) diff--; - }else{ + if (run_index) + run_index--; + run_count = 0; + run_mode = 0; + if (diff > 0) + diff--; + } else { run_count++; } } @@ -506,200 +529,216 @@ static av_always_inline int encode_line(FFV1Context *s, int w, run_count, run_index, run_mode, x, (int)put_bits_count(&s->pb)); - if(run_mode == 0) + if (run_mode == 0) put_vlc_symbol(&s->pb, &p->vlc_state[context], diff, bits); } } - if(run_mode){ - while(run_count >= 1<= 1 << ff_log2_run[run_index]) { + run_count -= 1 << ff_log2_run[run_index]; run_index++; put_bits(&s->pb, 1, 1); } - if(run_count) + if (run_count) put_bits(&s->pb, 1, 1); } - s->run_index= run_index; + s->run_index = run_index; return 0; } -static void encode_plane(FFV1Context *s, uint8_t *src, int w, int h, int stride, int plane_index){ - int x,y,i; - const int ring_size= s->avctx->context_model ? 3 : 2; +static void encode_plane(FFV1Context *s, uint8_t *src, int w, int h, + int stride, int plane_index) +{ + int x, y, i; + const int ring_size = s->avctx->context_model ? 3 : 2; int16_t *sample[3]; - s->run_index=0; + s->run_index = 0; - memset(s->sample_buffer, 0, ring_size*(w+6)*sizeof(*s->sample_buffer)); + memset(s->sample_buffer, 0, ring_size * (w + 6) * sizeof(*s->sample_buffer)); - for(y=0; ysample_buffer + (w+6)*((h+i-y)%ring_size) + 3; + for (y = 0; y < h; y++) { + for (i = 0; i < ring_size; i++) + sample[i] = s->sample_buffer + (w + 6) * ((h + i - y) % ring_size) + 3; - sample[0][-1]= sample[1][0 ]; - sample[1][ w]= sample[1][w-1]; -//{START_TIMER - if(s->avctx->bits_per_raw_sample<=8){ - for(x=0; xavctx->bits_per_raw_sample <= 8) { + for (x = 0; x < w; x++) + sample[0][x] = src[x + stride * y]; encode_line(s, w, sample, plane_index, 8); - }else{ - for(x=0; x> (16 - s->avctx->bits_per_raw_sample); - } + } else { + for (x = 0; x < w; x++) + sample[0][x] = ((uint16_t *)(src + stride * y))[x] >> + (16 - s->avctx->bits_per_raw_sample); encode_line(s, w, sample, plane_index, s->avctx->bits_per_raw_sample); } -//STOP_TIMER("encode line")} +// STOP_TIMER("encode line") } } } -static void encode_rgb_frame(FFV1Context *s, uint32_t *src, int w, int h, int stride){ +static void encode_rgb_frame(FFV1Context *s, uint32_t *src, int w, int h, + int stride) +{ int x, y, p, i; - const int ring_size= s->avctx->context_model ? 3 : 2; + const int ring_size = s->avctx->context_model ? 3 : 2; int16_t *sample[3][3]; - s->run_index=0; + s->run_index = 0; - memset(s->sample_buffer, 0, ring_size*3*(w+6)*sizeof(*s->sample_buffer)); + memset(s->sample_buffer, 0, ring_size * 3 * (w + 6) * sizeof(*s->sample_buffer)); - for(y=0; ysample_buffer + p*ring_size*(w+6) + ((h+i-y)%ring_size)*(w+6) + 3; + for (y = 0; y < h; y++) { + for (i = 0; i < ring_size; i++) + for (p = 0; p < 3; p++) + sample[p][i] = s->sample_buffer + p * ring_size * (w + 6) + + ((h + i - y) % ring_size) * (w + 6) + 3; - for(x=0; x>8)&0xFF; - int r= (v>>16)&0xFF; + for (x = 0; x < w; x++) { + int v = src[x + stride * y]; + int b = v & 0xFF; + int g = (v >> 8) & 0xFF; + int r = (v >> 16) & 0xFF; b -= g; r -= g; - g += (b + r)>>2; + g += (b + r) >> 2; b += 0x100; r += 0x100; -// assert(g>=0 && b>=0 && r>=0); -// assert(g<256 && b<512 && r<512); - sample[0][0][x]= g; - sample[1][0][x]= b; - sample[2][0][x]= r; + sample[0][0][x] = g; + sample[1][0][x] = b; + sample[2][0][x] = r; } - for(p=0; p<3; p++){ - sample[p][0][-1]= sample[p][1][0 ]; - sample[p][1][ w]= sample[p][1][w-1]; + for (p = 0; p < 3; p++) { + sample[p][0][-1] = sample[p][1][0]; + sample[p][1][w] = sample[p][1][w - 1]; encode_line(s, w, sample[p], FFMIN(p, 1), 9); } } } -static void write_quant_table(RangeCoder *c, int16_t *quant_table){ - int last=0; +static void write_quant_table(RangeCoder *c, int16_t *quant_table) +{ + int last = 0; int i; uint8_t state[CONTEXT_SIZE]; memset(state, 128, sizeof(state)); - for(i=1; i<128 ; i++){ - if(quant_table[i] != quant_table[i-1]){ - put_symbol(c, state, i-last-1, 0); - last= i; + for (i = 1; i < 128; i++) + if (quant_table[i] != quant_table[i - 1]) { + put_symbol(c, state, i - last - 1, 0); + last = i; } - } - put_symbol(c, state, i-last-1, 0); + put_symbol(c, state, i - last - 1, 0); } -static void write_quant_tables(RangeCoder *c, int16_t quant_table[MAX_CONTEXT_INPUTS][256]){ +static void write_quant_tables(RangeCoder *c, + int16_t quant_table[MAX_CONTEXT_INPUTS][256]) +{ int i; - for(i=0; i<5; i++) + for (i = 0; i < 5; i++) write_quant_table(c, quant_table[i]); } -static void write_header(FFV1Context *f){ +static void write_header(FFV1Context *f) +{ uint8_t state[CONTEXT_SIZE]; int i, j; - RangeCoder * const c= &f->slice_context[0]->c; + RangeCoder *const c = &f->slice_context[0]->c; memset(state, 128, sizeof(state)); - if(f->version < 2){ + if (f->version < 2) { put_symbol(c, state, f->version, 0); put_symbol(c, state, f->ac, 0); - if(f->ac>1){ - for(i=1; i<256; i++){ - put_symbol(c, state, f->state_transition[i] - c->one_state[i], 1); - } + if (f->ac > 1) { + for (i = 1; i < 256; i++) + put_symbol(c, state, + f->state_transition[i] - c->one_state[i], 1); } - put_symbol(c, state, f->colorspace, 0); //YUV cs type - if(f->version>0) + put_symbol(c, state, f->colorspace, 0); // YUV cs type + if (f->version > 0) put_symbol(c, state, f->avctx->bits_per_raw_sample, 0); - put_rac(c, state, 1); //chroma planes - put_symbol(c, state, f->chroma_h_shift, 0); - put_symbol(c, state, f->chroma_v_shift, 0); - put_rac(c, state, 0); //no transparency plane + put_rac(c, state, 1); // chroma planes + put_symbol(c, state, f->chroma_h_shift, 0); + put_symbol(c, state, f->chroma_v_shift, 0); + put_rac(c, state, 0); // no transparency plane write_quant_tables(c, f->quant_table); - }else{ + } else { put_symbol(c, state, f->slice_count, 0); - for(i=0; islice_count; i++){ - FFV1Context *fs= f->slice_context[i]; - put_symbol(c, state, (fs->slice_x +1)*f->num_h_slices / f->width , 0); - put_symbol(c, state, (fs->slice_y +1)*f->num_v_slices / f->height , 0); - put_symbol(c, state, (fs->slice_width +1)*f->num_h_slices / f->width -1, 0); - put_symbol(c, state, (fs->slice_height+1)*f->num_v_slices / f->height-1, 0); - for(j=0; jplane_count; j++){ + for (i = 0; i < f->slice_count; i++) { + FFV1Context *fs = f->slice_context[i]; + put_symbol(c, state, + (fs->slice_x + 1) * f->num_h_slices / f->width, 0); + put_symbol(c, state, + (fs->slice_y + 1) * f->num_v_slices / f->height, 0); + put_symbol(c, state, + (fs->slice_width + 1) * f->num_h_slices / f->width - 1, + 0); + put_symbol(c, state, + (fs->slice_height + 1) * f->num_v_slices / f->height - 1, + 0); + for (j = 0; j < f->plane_count; j++) { put_symbol(c, state, f->plane[j].quant_table_index, 0); av_assert0(f->plane[j].quant_table_index == f->avctx->context_model); } } } } + #endif /* CONFIG_FFV1_ENCODER */ -static av_cold int common_init(AVCodecContext *avctx){ +static av_cold int common_init(AVCodecContext *avctx) +{ FFV1Context *s = avctx->priv_data; - s->avctx= avctx; - s->flags= avctx->flags; + s->avctx = avctx; + s->flags = avctx->flags; ff_dsputil_init(&s->dsp, avctx); - s->width = avctx->width; - s->height= avctx->height; + s->width = avctx->width; + s->height = avctx->height; assert(s->width && s->height); - //defaults - s->num_h_slices=1; - s->num_v_slices=1; - + // defaults + s->num_h_slices = 1; + s->num_v_slices = 1; return 0; } -static int init_slice_state(FFV1Context *f){ +static int init_slice_state(FFV1Context *f) +{ int i, j; - for(i=0; islice_count; i++){ - FFV1Context *fs= f->slice_context[i]; - for(j=0; jplane_count; j++){ - PlaneContext * const p= &fs->plane[j]; + for (i = 0; i < f->slice_count; i++) { + FFV1Context *fs = f->slice_context[i]; + for (j = 0; j < f->plane_count; j++) { + PlaneContext *const p = &fs->plane[j]; - if(fs->ac){ - if(!p-> state) p-> state= av_malloc(CONTEXT_SIZE*p->context_count*sizeof(uint8_t)); - if(!p-> state) + if (fs->ac) { + if (!p->state) + p->state = av_malloc(CONTEXT_SIZE * p->context_count * + sizeof(uint8_t)); + if (!p->state) return AVERROR(ENOMEM); - }else{ - if(!p->vlc_state) p->vlc_state= av_malloc(p->context_count*sizeof(VlcState)); - if(!p->vlc_state) + } else { + if (!p->vlc_state) + p->vlc_state = av_malloc(p->context_count * sizeof(VlcState)); + if (!p->vlc_state) return AVERROR(ENOMEM); } } - if (fs->ac>1){ - //FIXME only redo if state_transition changed - for(j=1; j<256; j++){ - fs->c.one_state [ j]= fs->state_transition[j]; - fs->c.zero_state[256-j]= 256-fs->c.one_state [j]; + if (fs->ac > 1) { + // FIXME: only redo if state_transition changed + for (j = 1; j < 256; j++) { + fs->c.one_state[j] = fs->state_transition[j]; + fs->c.zero_state[256 - j] = 256 - fs->c.one_state[j]; } } } @@ -707,50 +746,56 @@ static int init_slice_state(FFV1Context *f){ return 0; } -static av_cold int init_slice_contexts(FFV1Context *f){ +static av_cold int init_slice_contexts(FFV1Context *f) +{ int i; - f->slice_count= f->num_h_slices * f->num_v_slices; - - for(i=0; islice_count; i++){ - FFV1Context *fs= av_mallocz(sizeof(*fs)); - int sx= i % f->num_h_slices; - int sy= i / f->num_h_slices; - int sxs= f->avctx->width * sx / f->num_h_slices; - int sxe= f->avctx->width *(sx+1) / f->num_h_slices; - int sys= f->avctx->height* sy / f->num_v_slices; - int sye= f->avctx->height*(sy+1) / f->num_v_slices; - f->slice_context[i]= fs; + f->slice_count = f->num_h_slices * f->num_v_slices; + + for (i = 0; i < f->slice_count; i++) { + FFV1Context *fs = av_mallocz(sizeof(*fs)); + int sx = i % f->num_h_slices; + int sy = i / f->num_h_slices; + int sxs = f->avctx->width * sx / f->num_h_slices; + int sxe = f->avctx->width * (sx + 1) / f->num_h_slices; + int sys = f->avctx->height * sy / f->num_v_slices; + int sye = f->avctx->height * (sy + 1) / f->num_v_slices; + f->slice_context[i] = fs; memcpy(fs, f, sizeof(*fs)); memset(fs->rc_stat2, 0, sizeof(fs->rc_stat2)); - fs->slice_width = sxe - sxs; - fs->slice_height= sye - sys; - fs->slice_x = sxs; - fs->slice_y = sys; + fs->slice_width = sxe - sxs; + fs->slice_height = sye - sys; + fs->slice_x = sxs; + fs->slice_y = sys; - fs->sample_buffer = av_malloc(9 * (fs->width+6) * sizeof(*fs->sample_buffer)); + fs->sample_buffer = av_malloc(9 * (fs->width + 6) * + sizeof(*fs->sample_buffer)); if (!fs->sample_buffer) return AVERROR(ENOMEM); } return 0; } -static int allocate_initial_states(FFV1Context *f){ +static int allocate_initial_states(FFV1Context *f) +{ int i; - for(i=0; iquant_table_count; i++){ - f->initial_states[i]= av_malloc(f->context_count[i]*sizeof(*f->initial_states[i])); - if(!f->initial_states[i]) + for (i = 0; i < f->quant_table_count; i++) { + f->initial_states[i] = av_malloc(f->context_count[i] * + sizeof(*f->initial_states[i])); + if (!f->initial_states[i]) return AVERROR(ENOMEM); - memset(f->initial_states[i], 128, f->context_count[i]*sizeof(*f->initial_states[i])); + memset(f->initial_states[i], 128, + f->context_count[i] * sizeof(*f->initial_states[i])); } return 0; } #if CONFIG_FFV1_ENCODER -static int write_extra_header(FFV1Context *f){ - RangeCoder * const c= &f->c; +static int write_extra_header(FFV1Context *f) +{ + RangeCoder *const c = &f->c; uint8_t state[CONTEXT_SIZE]; int i, j, k; uint8_t state2[32][CONTEXT_SIZE]; @@ -758,92 +803,96 @@ static int write_extra_header(FFV1Context *f){ memset(state2, 128, sizeof(state2)); memset(state, 128, sizeof(state)); - f->avctx->extradata= av_malloc(f->avctx->extradata_size= 10000 + (11*11*5*5*5+11*11*11)*32); + f->avctx->extradata = av_malloc(f->avctx->extradata_size = 10000 + + (11 * 11 * 5 * 5 * 5 + 11 * 11 * 11) * 32); ff_init_range_encoder(c, f->avctx->extradata, f->avctx->extradata_size); - ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); + ff_build_rac_states(c, 0.05 * (1LL << 32), 256 - 8); put_symbol(c, state, f->version, 0); put_symbol(c, state, f->ac, 0); - if(f->ac>1){ - for(i=1; i<256; i++){ + if (f->ac > 1) + for (i = 1; i < 256; i++) put_symbol(c, state, f->state_transition[i] - c->one_state[i], 1); - } - } - put_symbol(c, state, f->colorspace, 0); //YUV cs type + put_symbol(c, state, f->colorspace, 0); // YUV cs type put_symbol(c, state, f->avctx->bits_per_raw_sample, 0); - put_rac(c, state, 1); //chroma planes - put_symbol(c, state, f->chroma_h_shift, 0); - put_symbol(c, state, f->chroma_v_shift, 0); - put_rac(c, state, 0); //no transparency plane - put_symbol(c, state, f->num_h_slices-1, 0); - put_symbol(c, state, f->num_v_slices-1, 0); + put_rac(c, state, 1); // chroma planes + put_symbol(c, state, f->chroma_h_shift, 0); + put_symbol(c, state, f->chroma_v_shift, 0); + put_rac(c, state, 0); // no transparency plane + put_symbol(c, state, f->num_h_slices - 1, 0); + put_symbol(c, state, f->num_v_slices - 1, 0); put_symbol(c, state, f->quant_table_count, 0); - for(i=0; iquant_table_count; i++) + for (i = 0; i < f->quant_table_count; i++) write_quant_tables(c, f->quant_tables[i]); - for(i=0; iquant_table_count; i++){ - for(j=0; jcontext_count[i]*CONTEXT_SIZE; j++) - if(f->initial_states[i] && f->initial_states[i][0][j] != 128) + for (i = 0; i < f->quant_table_count; i++) { + for (j = 0; j < f->context_count[i] * CONTEXT_SIZE; j++) + if (f->initial_states[i] && f->initial_states[i][0][j] != 128) break; - if(jcontext_count[i]*CONTEXT_SIZE){ + if (j < f->context_count[i] * CONTEXT_SIZE) { put_rac(c, state, 1); - for(j=0; jcontext_count[i]; j++){ - for(k=0; kinitial_states[i][j-1][k] : 128; - put_symbol(c, state2[k], (int8_t)(f->initial_states[i][j][k]-pred), 1); + for (j = 0; j < f->context_count[i]; j++) + for (k = 0; k < CONTEXT_SIZE; k++) { + int pred = j ? f->initial_states[i][j - 1][k] : 128; + put_symbol(c, state2[k], + (int8_t)(f->initial_states[i][j][k] - pred), 1); } - } - }else{ + } else { put_rac(c, state, 0); } } - f->avctx->extradata_size= ff_rac_terminate(c); + f->avctx->extradata_size = ff_rac_terminate(c); return 0; } -static int sort_stt(FFV1Context *s, uint8_t stt[256]){ - int i,i2,changed,print=0; +static int sort_stt(FFV1Context *s, uint8_t stt[256]) +{ + int i, i2, changed, print = 0; + + do { + changed = 0; + for (i = 12; i < 244; i++) { + for (i2 = i + 1; i2 < 245 && i2 < i + 4; i2++) { - do{ - changed=0; - for(i=12; i<244; i++){ - for(i2=i+1; i2<245 && i2rc_stat[old][0]*-log2((256-(new))/256.0)\ - +s->rc_stat[old][1]*-log2( (new) /256.0) +#define COST(old, new) \ + s->rc_stat[old][0] * -log2((256 - (new)) / 256.0) + \ + s->rc_stat[old][1] * -log2((new) / 256.0) -#define COST2(old, new) \ - COST(old, new)\ - +COST(256-(old), 256-(new)) +#define COST2(old, new) \ + COST(old, new) + COST(256 - (old), 256 - (new)) - double size0= COST2(i, i ) + COST2(i2, i2); - double sizeX= COST2(i, i2) + COST2(i2, i ); - if(sizeX < size0 && i!=128 && i2!=128){ + double size0 = COST2(i, i) + COST2(i2, i2); + double sizeX = COST2(i, i2) + COST2(i2, i); + if (sizeX < size0 && i != 128 && i2 != 128) { int j; - FFSWAP(int, stt[ i], stt[ i2]); - FFSWAP(int, s->rc_stat[i ][0],s->rc_stat[ i2][0]); - FFSWAP(int, s->rc_stat[i ][1],s->rc_stat[ i2][1]); - if(i != 256-i2){ - FFSWAP(int, stt[256-i], stt[256-i2]); - FFSWAP(int, s->rc_stat[256-i][0],s->rc_stat[256-i2][0]); - FFSWAP(int, s->rc_stat[256-i][1],s->rc_stat[256-i2][1]); + FFSWAP(int, stt[i], stt[i2]); + FFSWAP(int, s->rc_stat[i][0], s->rc_stat[i2][0]); + FFSWAP(int, s->rc_stat[i][1], s->rc_stat[i2][1]); + if (i != 256 - i2) { + FFSWAP(int, stt[256 - i], stt[256 - i2]); + FFSWAP(int, s->rc_stat[256 - i][0], s->rc_stat[256 - i2][0]); + FFSWAP(int, s->rc_stat[256 - i][1], s->rc_stat[256 - i2][1]); } - for(j=1; j<256; j++){ - if (stt[j] == i ) stt[j] = i2; - else if(stt[j] == i2) stt[j] = i ; - if(i != 256-i2){ - if (stt[256-j] == 256-i ) stt[256-j] = 256-i2; - else if(stt[256-j] == 256-i2) stt[256-j] = 256-i ; + for (j = 1; j < 256; j++) { + if (stt[j] == i) + stt[j] = i2; + else if (stt[j] == i2) + stt[j] = i; + if (i != 256 - i2) { + if (stt[256 - j] == 256 - i) + stt[256 - j] = 256 - i2; + else if (stt[256 - j] == 256 - i2) + stt[256 - j] = 256 - i; } } - print=changed=1; + print = changed = 1; } } } - }while(changed); + } while (changed); return print; } @@ -854,229 +903,246 @@ static av_cold int encode_init(AVCodecContext *avctx) common_init(avctx); - s->version=0; - s->ac= avctx->coder_type ? 2:0; - - if(s->ac>1) - for(i=1; i<256; i++) - s->state_transition[i]=ver2_state[i]; - - s->plane_count=2; - for(i=0; i<256; i++){ - s->quant_table_count=2; - if(avctx->bits_per_raw_sample <=8){ - s->quant_tables[0][0][i]= quant11[i]; - s->quant_tables[0][1][i]= 11*quant11[i]; - s->quant_tables[0][2][i]= 11*11*quant11[i]; - s->quant_tables[1][0][i]= quant11[i]; - s->quant_tables[1][1][i]= 11*quant11[i]; - s->quant_tables[1][2][i]= 11*11*quant5 [i]; - s->quant_tables[1][3][i]= 5*11*11*quant5 [i]; - s->quant_tables[1][4][i]= 5*5*11*11*quant5 [i]; - }else{ - s->quant_tables[0][0][i]= quant9_10bit[i]; - s->quant_tables[0][1][i]= 11*quant9_10bit[i]; - s->quant_tables[0][2][i]= 11*11*quant9_10bit[i]; - s->quant_tables[1][0][i]= quant9_10bit[i]; - s->quant_tables[1][1][i]= 11*quant9_10bit[i]; - s->quant_tables[1][2][i]= 11*11*quant5_10bit[i]; - s->quant_tables[1][3][i]= 5*11*11*quant5_10bit[i]; - s->quant_tables[1][4][i]= 5*5*11*11*quant5_10bit[i]; + s->version = 0; + s->ac = avctx->coder_type ? 2 : 0; + + if (s->ac > 1) + for (i = 1; i < 256; i++) + s->state_transition[i] = ver2_state[i]; + + s->plane_count = 2; + for (i = 0; i < 256; i++) { + s->quant_table_count = 2; + if (avctx->bits_per_raw_sample <= 8) { + s->quant_tables[0][0][i] = quant11[i]; + s->quant_tables[0][1][i] = quant11[i] * 11; + s->quant_tables[0][2][i] = quant11[i] * 11 * 11; + s->quant_tables[1][0][i] = quant11[i]; + s->quant_tables[1][1][i] = quant11[i] * 11; + s->quant_tables[1][2][i] = quant5[i] * 11 * 11; + s->quant_tables[1][3][i] = quant5[i] * 5 * 11 * 11; + s->quant_tables[1][4][i] = quant5[i] * 5 * 5 * 11 * 11; + } else { + s->quant_tables[0][0][i] = quant9_10bit[i]; + s->quant_tables[0][1][i] = quant9_10bit[i] * 11; + s->quant_tables[0][2][i] = quant9_10bit[i] * 11 * 11; + s->quant_tables[1][0][i] = quant9_10bit[i]; + s->quant_tables[1][1][i] = quant9_10bit[i] * 11; + s->quant_tables[1][2][i] = quant5_10bit[i] * 11 * 11; + s->quant_tables[1][3][i] = quant5_10bit[i] * 5 * 11 * 11; + s->quant_tables[1][4][i] = quant5_10bit[i] * 5 * 5 * 11 * 11; } } - s->context_count[0]= (11*11*11+1)/2; - s->context_count[1]= (11*11*5*5*5+1)/2; - memcpy(s->quant_table, s->quant_tables[avctx->context_model], sizeof(s->quant_table)); + s->context_count[0] = (11 * 11 * 11 + 1) / 2; + s->context_count[1] = (11 * 11 * 5 * 5 * 5 + 1) / 2; + memcpy(s->quant_table, s->quant_tables[avctx->context_model], + sizeof(s->quant_table)); - for(i=0; iplane_count; i++){ - PlaneContext * const p= &s->plane[i]; + for (i = 0; i < s->plane_count; i++) { + PlaneContext *const p = &s->plane[i]; memcpy(p->quant_table, s->quant_table, sizeof(p->quant_table)); - p->quant_table_index= avctx->context_model; - p->context_count= s->context_count[p->quant_table_index]; + p->quant_table_index = avctx->context_model; + p->context_count = s->context_count[p->quant_table_index]; } - if(allocate_initial_states(s) < 0) + if (allocate_initial_states(s) < 0) return AVERROR(ENOMEM); - avctx->coded_frame= &s->picture; - switch(avctx->pix_fmt){ + avctx->coded_frame = &s->picture; + switch (avctx->pix_fmt) { case AV_PIX_FMT_YUV444P16: case AV_PIX_FMT_YUV422P16: case AV_PIX_FMT_YUV420P16: - if(avctx->bits_per_raw_sample <=8){ + if (avctx->bits_per_raw_sample <= 8) { av_log(avctx, AV_LOG_ERROR, "bits_per_raw_sample invalid\n"); return -1; } - if(!s->ac){ - av_log(avctx, AV_LOG_ERROR, "bits_per_raw_sample of more than 8 needs -coder 1 currently\n"); + if (!s->ac) { + av_log(avctx, AV_LOG_ERROR, + "bits_per_raw_sample of more than 8 needs -coder 1 currently\n"); return -1; } - s->version= FFMAX(s->version, 1); + s->version = FFMAX(s->version, 1); case AV_PIX_FMT_YUV444P: case AV_PIX_FMT_YUV422P: case AV_PIX_FMT_YUV420P: case AV_PIX_FMT_YUV411P: case AV_PIX_FMT_YUV410P: - s->colorspace= 0; + s->colorspace = 0; break; case AV_PIX_FMT_RGB32: - s->colorspace= 1; + s->colorspace = 1; break; default: av_log(avctx, AV_LOG_ERROR, "format not supported\n"); return -1; } - avcodec_get_chroma_sub_sample(avctx->pix_fmt, &s->chroma_h_shift, &s->chroma_v_shift); + avcodec_get_chroma_sub_sample(avctx->pix_fmt, &s->chroma_h_shift, + &s->chroma_v_shift); - s->picture_number=0; + s->picture_number = 0; - if(avctx->flags & (CODEC_FLAG_PASS1|CODEC_FLAG_PASS2)){ - for(i=0; iquant_table_count; i++){ - s->rc_stat2[i]= av_mallocz(s->context_count[i]*sizeof(*s->rc_stat2[i])); - if(!s->rc_stat2[i]) + if (avctx->flags & (CODEC_FLAG_PASS1 | CODEC_FLAG_PASS2)) { + for (i = 0; i < s->quant_table_count; i++) { + s->rc_stat2[i] = av_mallocz(s->context_count[i] * + sizeof(*s->rc_stat2[i])); + if (!s->rc_stat2[i]) return AVERROR(ENOMEM); } } - if(avctx->stats_in){ - char *p= avctx->stats_in; + if (avctx->stats_in) { + char *p = avctx->stats_in; uint8_t best_state[256][256]; - int gob_count=0; + int gob_count = 0; char *next; - av_assert0(s->version>=2); + av_assert0(s->version >= 2); - for(;;){ - for(j=0; j<256; j++){ - for(i=0; i<2; i++){ - s->rc_stat[j][i]= strtol(p, &next, 0); - if(next==p){ - av_log(avctx, AV_LOG_ERROR, "2Pass file invalid at %d %d [%s]\n", j,i,p); + for (;; ) { + for (j = 0; j < 256; j++) + for (i = 0; i < 2; i++) { + s->rc_stat[j][i] = strtol(p, &next, 0); + if (next == p) { + av_log(avctx, AV_LOG_ERROR, + "2Pass file invalid at %d %d [%s]\n", j, i, p); return -1; } - p=next; + p = next; } - } - for(i=0; iquant_table_count; i++){ - for(j=0; jcontext_count[i]; j++){ - for(k=0; k<32; k++){ - for(m=0; m<2; m++){ - s->rc_stat2[i][j][k][m]= strtol(p, &next, 0); - if(next==p){ - av_log(avctx, AV_LOG_ERROR, "2Pass file invalid at %d %d %d %d [%s]\n", i,j,k,m,p); + for (i = 0; i < s->quant_table_count; i++) + for (j = 0; j < s->context_count[i]; j++) { + for (k = 0; k < 32; k++) + for (m = 0; m < 2; m++) { + s->rc_stat2[i][j][k][m] = strtol(p, &next, 0); + if (next == p) { + av_log(avctx, AV_LOG_ERROR, + "2Pass file invalid at %d %d %d %d [%s]\n", + i, j, k, m, p); return -1; } - p=next; + p = next; } - } } - } - gob_count= strtol(p, &next, 0); - if(next==p || gob_count <0){ + gob_count = strtol(p, &next, 0); + if (next == p || gob_count < 0) { av_log(avctx, AV_LOG_ERROR, "2Pass file invalid\n"); return -1; } - p=next; - while(*p=='\n' || *p==' ') p++; - if(p[0]==0) break; + p = next; + while (*p == '\n' || *p == ' ') + p++; + if (p[0] == 0) + break; } sort_stt(s, s->state_transition); find_best_state(best_state, s->state_transition); - for(i=0; iquant_table_count; i++){ - for(j=0; jcontext_count[i]; j++){ - for(k=0; k<32; k++){ - double p= 128; - if(s->rc_stat2[i][j][k][0]+s->rc_stat2[i][j][k][1]){ - p=256.0*s->rc_stat2[i][j][k][1] / (s->rc_stat2[i][j][k][0]+s->rc_stat2[i][j][k][1]); + for (i = 0; i < s->quant_table_count; i++) { + for (j = 0; j < s->context_count[i]; j++) + for (k = 0; k < 32; k++) { + double p = 128; + if (s->rc_stat2[i][j][k][0] + s->rc_stat2[i][j][k][1]) { + p = 256.0 * s->rc_stat2[i][j][k][1] / + (s->rc_stat2[i][j][k][0] + s->rc_stat2[i][j][k][1]); } - s->initial_states[i][j][k]= best_state[av_clip(round(p), 1, 255)][av_clip((s->rc_stat2[i][j][k][0]+s->rc_stat2[i][j][k][1])/gob_count, 0, 255)]; + s->initial_states[i][j][k] = + best_state[av_clip(round(p), 1, 255)][av_clip((s->rc_stat2[i][j][k][0] + + s->rc_stat2[i][j][k][1]) / + gob_count, 0, 255)]; } - } } } - if(s->version>1){ - s->num_h_slices=2; - s->num_v_slices=2; + if (s->version > 1) { + s->num_h_slices = 2; + s->num_v_slices = 2; write_extra_header(s); } - if(init_slice_contexts(s) < 0) + if (init_slice_contexts(s) < 0) return -1; - if(init_slice_state(s) < 0) + if (init_slice_state(s) < 0) return -1; -#define STATS_OUT_SIZE 1024*1024*6 - if(avctx->flags & CODEC_FLAG_PASS1){ - avctx->stats_out= av_mallocz(STATS_OUT_SIZE); - for(i=0; iquant_table_count; i++){ - for(j=0; jslice_count; j++){ - FFV1Context *sf= s->slice_context[j]; +#define STATS_OUT_SIZE 1024 * 1024 * 6 + if (avctx->flags & CODEC_FLAG_PASS1) { + avctx->stats_out = av_mallocz(STATS_OUT_SIZE); + for (i = 0; i < s->quant_table_count; i++) + for (j = 0; j < s->slice_count; j++) { + FFV1Context *sf = s->slice_context[j]; av_assert0(!sf->rc_stat2[i]); - sf->rc_stat2[i]= av_mallocz(s->context_count[i]*sizeof(*sf->rc_stat2[i])); - if(!sf->rc_stat2[i]) + sf->rc_stat2[i] = av_mallocz(s->context_count[i] * + sizeof(*sf->rc_stat2[i])); + if (!sf->rc_stat2[i]) return AVERROR(ENOMEM); } - } } return 0; } -#endif /* CONFIG_FFV1_ENCODER */ +#endif /* CONFIG_FFV1_ENCODER */ -static void clear_state(FFV1Context *f){ +static void clear_state(FFV1Context *f) +{ int i, si, j; - for(si=0; sislice_count; si++){ - FFV1Context *fs= f->slice_context[si]; - for(i=0; iplane_count; i++){ - PlaneContext *p= &fs->plane[i]; - - p->interlace_bit_state[0]= 128; - p->interlace_bit_state[1]= 128; - - if(fs->ac){ - if(f->initial_states[p->quant_table_index]){ - memcpy(p->state, f->initial_states[p->quant_table_index], CONTEXT_SIZE*p->context_count); - }else - memset(p->state, 128, CONTEXT_SIZE*p->context_count); - }else{ - for(j=0; jcontext_count; j++){ - p->vlc_state[j].drift= 0; - p->vlc_state[j].error_sum= 4; //FFMAX((RANGE + 32)/64, 2); - p->vlc_state[j].bias= 0; - p->vlc_state[j].count= 1; - } + for (si = 0; si < f->slice_count; si++) { + FFV1Context *fs = f->slice_context[si]; + for (i = 0; i < f->plane_count; i++) { + PlaneContext *p = &fs->plane[i]; + + p->interlace_bit_state[0] = 128; + p->interlace_bit_state[1] = 128; + + if (fs->ac) { + if (f->initial_states[p->quant_table_index]) { + memcpy(p->state, f->initial_states[p->quant_table_index], + CONTEXT_SIZE * p->context_count); + } else + memset(p->state, 128, CONTEXT_SIZE * p->context_count); + } else { + for (j = 0; j < p->context_count; j++) { + p->vlc_state[j].drift = 0; + p->vlc_state[j].error_sum = 4; // FFMAX((RANGE + 32)/64, 2); + p->vlc_state[j].bias = 0; + p->vlc_state[j].count = 1; + } } } } } #if CONFIG_FFV1_ENCODER -static int encode_slice(AVCodecContext *c, void *arg){ - FFV1Context *fs= *(void**)arg; - FFV1Context *f= fs->avctx->priv_data; - int width = fs->slice_width; - int height= fs->slice_height; - int x= fs->slice_x; - int y= fs->slice_y; - AVFrame * const p= &f->picture; - - if(f->colorspace==0){ - const int chroma_width = -((-width )>>f->chroma_h_shift); - const int chroma_height= -((-height)>>f->chroma_v_shift); - const int cx= x>>f->chroma_h_shift; - const int cy= y>>f->chroma_v_shift; - - encode_plane(fs, p->data[0] + x + y*p->linesize[0], width, height, p->linesize[0], 0); - - encode_plane(fs, p->data[1] + cx+cy*p->linesize[1], chroma_width, chroma_height, p->linesize[1], 1); - encode_plane(fs, p->data[2] + cx+cy*p->linesize[2], chroma_width, chroma_height, p->linesize[2], 1); - }else{ - encode_rgb_frame(fs, (uint32_t*)(p->data[0]) + x + y*(p->linesize[0]/4), width, height, p->linesize[0]/4); +static int encode_slice(AVCodecContext *c, void *arg) +{ + FFV1Context *fs = *(void **)arg; + FFV1Context *f = fs->avctx->priv_data; + int width = fs->slice_width; + int height = fs->slice_height; + int x = fs->slice_x; + int y = fs->slice_y; + AVFrame *const p = &f->picture; + + if (f->colorspace == 0) { + const int chroma_width = -((-width) >> f->chroma_h_shift); + const int chroma_height = -((-height) >> f->chroma_v_shift); + const int cx = x >> f->chroma_h_shift; + const int cy = y >> f->chroma_v_shift; + + encode_plane(fs, p->data[0] + x + y * p->linesize[0], + width, height, p->linesize[0], 0); + + encode_plane(fs, p->data[1] + cx + cy * p->linesize[1], + chroma_width, chroma_height, p->linesize[1], 1); + encode_plane(fs, p->data[2] + cx + cy * p->linesize[2], + chroma_width, chroma_height, p->linesize[2], 1); + } else { + encode_rgb_frame(fs, (uint32_t *)(p->data[0]) + + x + y * (p->linesize[0] / 4), + width, height, p->linesize[0] / 4); } emms_c(); @@ -1086,149 +1152,152 @@ static int encode_slice(AVCodecContext *c, void *arg){ static int encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pict, int *got_packet) { - FFV1Context *f = avctx->priv_data; - RangeCoder * const c= &f->slice_context[0]->c; - AVFrame * const p= &f->picture; - int used_count= 0; - uint8_t keystate=128; + FFV1Context *f = avctx->priv_data; + RangeCoder *const c = &f->slice_context[0]->c; + AVFrame *const p = &f->picture; + int used_count = 0; + uint8_t keystate = 128; uint8_t *buf_p; int i, ret; if (!pkt->data && - (ret = av_new_packet(pkt, avctx->width*avctx->height*((8*2+1+1)*4)/8 - + FF_MIN_BUFFER_SIZE)) < 0) { + (ret = av_new_packet(pkt, avctx->width * avctx->height * + ((8 * 2 + 1 + 1) * 4) / 8 + FF_MIN_BUFFER_SIZE)) < 0) { av_log(avctx, AV_LOG_ERROR, "Error getting output packet.\n"); return ret; } ff_init_range_encoder(c, pkt->data, pkt->size); - ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); + ff_build_rac_states(c, 0.05 * (1LL << 32), 256 - 8); - *p = *pict; - p->pict_type= AV_PICTURE_TYPE_I; + *p = *pict; + p->pict_type = AV_PICTURE_TYPE_I; - if(avctx->gop_size==0 || f->picture_number % avctx->gop_size == 0){ + if (avctx->gop_size == 0 || f->picture_number % avctx->gop_size == 0) { put_rac(c, &keystate, 1); - p->key_frame= 1; + p->key_frame = 1; f->gob_count++; write_header(f); clear_state(f); - }else{ + } else { put_rac(c, &keystate, 0); - p->key_frame= 0; + p->key_frame = 0; } - if(!f->ac){ + if (!f->ac) { used_count += ff_rac_terminate(c); - init_put_bits(&f->slice_context[0]->pb, pkt->data + used_count, pkt->size - used_count); - }else if (f->ac>1){ + init_put_bits(&f->slice_context[0]->pb, pkt->data + used_count, + pkt->size - used_count); + } else if (f->ac > 1) { int i; - for(i=1; i<256; i++){ - c->one_state[i]= f->state_transition[i]; - c->zero_state[256-i]= 256-c->one_state[i]; + for (i = 1; i < 256; i++) { + c->one_state[i] = f->state_transition[i]; + c->zero_state[256 - i] = 256 - c->one_state[i]; } } - for(i=1; islice_count; i++){ - FFV1Context *fs= f->slice_context[i]; - uint8_t *start = pkt->data + (pkt->size-used_count)*i/f->slice_count; - int len = pkt->size/f->slice_count; + for (i = 1; i < f->slice_count; i++) { + FFV1Context *fs = f->slice_context[i]; + uint8_t *start = pkt->data + (pkt->size - used_count) * i / f->slice_count; + int len = pkt->size / f->slice_count; - if(fs->ac){ + if (fs->ac) ff_init_range_encoder(&fs->c, start, len); - }else{ + else init_put_bits(&fs->pb, start, len); - } } - avctx->execute(avctx, encode_slice, &f->slice_context[0], NULL, f->slice_count, sizeof(void*)); + avctx->execute(avctx, encode_slice, &f->slice_context[0], NULL, + f->slice_count, sizeof(void *)); buf_p = pkt->data; - for(i=0; islice_count; i++){ - FFV1Context *fs= f->slice_context[i]; + for (i = 0; i < f->slice_count; i++) { + FFV1Context *fs = f->slice_context[i]; int bytes; - if(fs->ac){ - uint8_t state=128; + if (fs->ac) { + uint8_t state = 128; put_rac(&fs->c, &state, 0); - bytes= ff_rac_terminate(&fs->c); - }else{ - flush_put_bits(&fs->pb); //nicer padding FIXME - bytes= used_count + (put_bits_count(&fs->pb)+7)/8; - used_count= 0; + bytes = ff_rac_terminate(&fs->c); + } else { + flush_put_bits(&fs->pb); // FIXME: nicer padding + bytes = used_count + (put_bits_count(&fs->pb) + 7) / 8; + used_count = 0; } - if(i>0){ - av_assert0(bytes < pkt->size/f->slice_count); + if (i > 0) { + av_assert0(bytes < pkt->size / f->slice_count); memmove(buf_p, fs->ac ? fs->c.bytestream_start : fs->pb.buf, bytes); - av_assert0(bytes < (1<<24)); - AV_WB24(buf_p+bytes, bytes); - bytes+=3; + av_assert0(bytes < (1 << 24)); + AV_WB24(buf_p + bytes, bytes); + bytes += 3; } buf_p += bytes; } - if((avctx->flags&CODEC_FLAG_PASS1) && (f->picture_number&31)==0){ + if ((avctx->flags & CODEC_FLAG_PASS1) && (f->picture_number & 31) == 0) { int j, k, m; - char *p= avctx->stats_out; - char *end= p + STATS_OUT_SIZE; + char *p = avctx->stats_out; + char *end = p + STATS_OUT_SIZE; memset(f->rc_stat, 0, sizeof(f->rc_stat)); - for(i=0; iquant_table_count; i++) - memset(f->rc_stat2[i], 0, f->context_count[i]*sizeof(*f->rc_stat2[i])); + for (i = 0; i < f->quant_table_count; i++) + memset(f->rc_stat2[i], 0, f->context_count[i] * sizeof(*f->rc_stat2[i])); - for(j=0; jslice_count; j++){ - FFV1Context *fs= f->slice_context[j]; - for(i=0; i<256; i++){ + for (j = 0; j < f->slice_count; j++) { + FFV1Context *fs = f->slice_context[j]; + for (i = 0; i < 256; i++) { f->rc_stat[i][0] += fs->rc_stat[i][0]; f->rc_stat[i][1] += fs->rc_stat[i][1]; } - for(i=0; iquant_table_count; i++){ - for(k=0; kcontext_count[i]; k++){ - for(m=0; m<32; m++){ + for (i = 0; i < f->quant_table_count; i++) { + for (k = 0; k < f->context_count[i]; k++) + for (m = 0; m < 32; m++) { f->rc_stat2[i][k][m][0] += fs->rc_stat2[i][k][m][0]; f->rc_stat2[i][k][m][1] += fs->rc_stat2[i][k][m][1]; } - } } } - for(j=0; j<256; j++){ - snprintf(p, end-p, "%"PRIu64" %"PRIu64" ", f->rc_stat[j][0], f->rc_stat[j][1]); - p+= strlen(p); + for (j = 0; j < 256; j++) { + snprintf(p, end - p, "%" PRIu64 " %" PRIu64 " ", + f->rc_stat[j][0], f->rc_stat[j][1]); + p += strlen(p); } - snprintf(p, end-p, "\n"); - - for(i=0; iquant_table_count; i++){ - for(j=0; jcontext_count[i]; j++){ - for(m=0; m<32; m++){ - snprintf(p, end-p, "%"PRIu64" %"PRIu64" ", f->rc_stat2[i][j][m][0], f->rc_stat2[i][j][m][1]); - p+= strlen(p); + snprintf(p, end - p, "\n"); + + for (i = 0; i < f->quant_table_count; i++) { + for (j = 0; j < f->context_count[i]; j++) + for (m = 0; m < 32; m++) { + snprintf(p, end - p, "%" PRIu64 " %" PRIu64 " ", + f->rc_stat2[i][j][m][0], f->rc_stat2[i][j][m][1]); + p += strlen(p); } - } } - snprintf(p, end-p, "%d\n", f->gob_count); - } else if(avctx->flags&CODEC_FLAG_PASS1) + snprintf(p, end - p, "%d\n", f->gob_count); + } else if (avctx->flags & CODEC_FLAG_PASS1) avctx->stats_out[0] = '\0'; f->picture_number++; pkt->size = buf_p - pkt->data; - pkt->flags |= AV_PKT_FLAG_KEY*p->key_frame; + pkt->flags |= AV_PKT_FLAG_KEY * p->key_frame; *got_packet = 1; return 0; } + #endif /* CONFIG_FFV1_ENCODER */ -static av_cold int common_end(AVCodecContext *avctx){ +static av_cold int common_end(AVCodecContext *avctx) +{ FFV1Context *s = avctx->priv_data; int i, j; if (avctx->codec->decode && s->picture.data[0]) avctx->release_buffer(avctx, &s->picture); - for(j=0; jslice_count; j++){ - FFV1Context *fs= s->slice_context[j]; - for(i=0; iplane_count; i++){ - PlaneContext *p= &fs->plane[i]; + for (j = 0; j < s->slice_count; j++) { + FFV1Context *fs = s->slice_context[j]; + for (i = 0; i < s->plane_count; i++) { + PlaneContext *p = &fs->plane[i]; av_freep(&p->state); av_freep(&p->vlc_state); @@ -1237,18 +1306,17 @@ static av_cold int common_end(AVCodecContext *avctx){ } av_freep(&avctx->stats_out); - for(j=0; jquant_table_count; j++){ + for (j = 0; j < s->quant_table_count; j++) { av_freep(&s->initial_states[j]); - for(i=0; islice_count; i++){ - FFV1Context *sf= s->slice_context[i]; + for (i = 0; i < s->slice_count; i++) { + FFV1Context *sf = s->slice_context[i]; av_freep(&sf->rc_stat2[j]); } av_freep(&s->rc_stat2[j]); } - for(i=0; islice_count; i++){ + for (i = 0; i < s->slice_count; i++) av_freep(&s->slice_context[i]); - } return 0; } @@ -1257,162 +1325,182 @@ static av_always_inline void decode_line(FFV1Context *s, int w, int16_t *sample[2], int plane_index, int bits) { - PlaneContext * const p= &s->plane[plane_index]; - RangeCoder * const c= &s->c; + PlaneContext *const p = &s->plane[plane_index]; + RangeCoder *const c = &s->c; int x; - int run_count=0; - int run_mode=0; - int run_index= s->run_index; + int run_count = 0; + int run_mode = 0; + int run_index = s->run_index; - for(x=0; xcontext_count); - if(s->ac){ - diff= get_symbol_inline(c, p->state[context], 1); - }else{ - if(context == 0 && run_mode==0) run_mode=1; - - if(run_mode){ - if(run_count==0 && run_mode==1){ - if(get_bits1(&s->gb)){ - run_count = 1<gb, ff_log2_run[run_index]); - else run_count=0; - if(run_index) run_index--; - run_mode=2; + if (s->ac) { + diff = get_symbol_inline(c, p->state[context], 1); + } else { + if (context == 0 && run_mode == 0) + run_mode = 1; + + if (run_mode) { + if (run_count == 0 && run_mode == 1) { + if (get_bits1(&s->gb)) { + run_count = 1 << ff_log2_run[run_index]; + if (x + run_count <= w) + run_index++; + } else { + if (ff_log2_run[run_index]) + run_count = get_bits(&s->gb, ff_log2_run[run_index]); + else + run_count = 0; + if (run_index) + run_index--; + run_mode = 2; } } run_count--; - if(run_count < 0){ - run_mode=0; - run_count=0; - diff= get_vlc_symbol(&s->gb, &p->vlc_state[context], bits); - if(diff>=0) diff++; - }else - diff=0; - }else - diff= get_vlc_symbol(&s->gb, &p->vlc_state[context], bits); + if (run_count < 0) { + run_mode = 0; + run_count = 0; + diff = get_vlc_symbol(&s->gb, &p->vlc_state[context], + bits); + if (diff >= 0) + diff++; + } else + diff = 0; + } else + diff = get_vlc_symbol(&s->gb, &p->vlc_state[context], bits); av_dlog(s->avctx, "count:%d index:%d, mode:%d, x:%d pos:%d\n", run_count, run_index, run_mode, x, get_bits_count(&s->gb)); } - if(sign) diff= -diff; + if (sign) + diff = -diff; - sample[1][x]= (predict(sample[1] + x, sample[0] + x) + diff) & ((1<run_index= run_index; + s->run_index = run_index; } -static void decode_plane(FFV1Context *s, uint8_t *src, int w, int h, int stride, int plane_index){ +static void decode_plane(FFV1Context *s, uint8_t *src, + int w, int h, int stride, int plane_index) +{ int x, y; int16_t *sample[2]; - sample[0]=s->sample_buffer +3; - sample[1]=s->sample_buffer+w+6+3; + sample[0] = s->sample_buffer + 3; + sample[1] = s->sample_buffer + w + 6 + 3; - s->run_index=0; + s->run_index = 0; - memset(s->sample_buffer, 0, 2*(w+6)*sizeof(*s->sample_buffer)); + memset(s->sample_buffer, 0, 2 * (w + 6) * sizeof(*s->sample_buffer)); - for(y=0; yavctx->bits_per_raw_sample <= 8){ +// { START_TIMER + if (s->avctx->bits_per_raw_sample <= 8) { decode_line(s, w, sample, plane_index, 8); - for(x=0; xavctx->bits_per_raw_sample); - for(x=0; xavctx->bits_per_raw_sample); - } + for (x = 0; x < w; x++) + src[x + stride * y] = sample[1][x]; + } else { + decode_line(s, w, sample, plane_index, + s->avctx->bits_per_raw_sample); + for (x = 0; x < w; x++) + ((uint16_t *)(src + stride * y))[x] = + sample[1][x] << (16 - s->avctx->bits_per_raw_sample); } -//STOP_TIMER("decode-line")} +// STOP_TIMER("decode-line") } } } -static void decode_rgb_frame(FFV1Context *s, uint32_t *src, int w, int h, int stride){ +static void decode_rgb_frame(FFV1Context *s, uint32_t *src, + int w, int h, int stride) +{ int x, y, p; int16_t *sample[3][2]; - for(x=0; x<3; x++){ - sample[x][0] = s->sample_buffer + x*2 *(w+6) + 3; - sample[x][1] = s->sample_buffer + (x*2+1)*(w+6) + 3; + for (x = 0; x < 3; x++) { + sample[x][0] = s->sample_buffer + x * 2 * (w + 6) + 3; + sample[x][1] = s->sample_buffer + (x * 2 + 1) * (w + 6) + 3; } - s->run_index=0; + s->run_index = 0; - memset(s->sample_buffer, 0, 6*(w+6)*sizeof(*s->sample_buffer)); + memset(s->sample_buffer, 0, 6 * (w + 6) * sizeof(*s->sample_buffer)); - for(y=0; y=0 && b>=0 && r>=0); -// assert(g<256 && b<512 && r<512); +// assert(g >= 0 && b >= 0 && r >= 0); +// assert(g < 256 && b < 512 && r < 512); b -= 0x100; r -= 0x100; - g -= (b + r)>>2; + g -= (b + r) >> 2; b += g; r += g; - src[x + stride*y]= b + (g<<8) + (r<<16) + (0xFF<<24); + src[x + stride * y] = b + (g << 8) + (r << 16) + (0xFF << 24); } } } -static int decode_slice(AVCodecContext *c, void *arg){ - FFV1Context *fs= *(void**)arg; - FFV1Context *f= fs->avctx->priv_data; - int width = fs->slice_width; - int height= fs->slice_height; - int x= fs->slice_x; - int y= fs->slice_y; - AVFrame * const p= &f->picture; +static int decode_slice(AVCodecContext *c, void *arg) +{ + FFV1Context *fs = *(void **)arg; + FFV1Context *f = fs->avctx->priv_data; + int width = fs->slice_width; + int height = fs->slice_height; + int x = fs->slice_x; + int y = fs->slice_y; + AVFrame *const p = &f->picture; av_assert1(width && height); - if(f->colorspace==0){ - const int chroma_width = -((-width )>>f->chroma_h_shift); - const int chroma_height= -((-height)>>f->chroma_v_shift); - const int cx= x>>f->chroma_h_shift; - const int cy= y>>f->chroma_v_shift; - decode_plane(fs, p->data[0] + x + y*p->linesize[0], width, height, p->linesize[0], 0); - - decode_plane(fs, p->data[1] + cx+cy*p->linesize[1], chroma_width, chroma_height, p->linesize[1], 1); - decode_plane(fs, p->data[2] + cx+cy*p->linesize[1], chroma_width, chroma_height, p->linesize[2], 1); - }else{ - decode_rgb_frame(fs, (uint32_t*)p->data[0] + x + y*(p->linesize[0]/4), width, height, p->linesize[0]/4); + if (f->colorspace == 0) { + const int chroma_width = -((-width) >> f->chroma_h_shift); + const int chroma_height = -((-height) >> f->chroma_v_shift); + const int cx = x >> f->chroma_h_shift; + const int cy = y >> f->chroma_v_shift; + + decode_plane(fs, p->data[0] + x + y * p->linesize[0], + width, height, p->linesize[0], 0); + + decode_plane(fs, p->data[1] + cx + cy * p->linesize[1], + chroma_width, chroma_height, p->linesize[1], 1); + decode_plane(fs, p->data[2] + cx + cy * p->linesize[1], + chroma_width, chroma_height, p->linesize[2], 1); + } else { + decode_rgb_frame(fs, + (uint32_t *)p->data[0] + x + y * (p->linesize[0] / 4), + width, height, p->linesize[0] / 4); } emms_c(); @@ -1420,47 +1508,51 @@ static int decode_slice(AVCodecContext *c, void *arg){ return 0; } -static int read_quant_table(RangeCoder *c, int16_t *quant_table, int scale){ +static int read_quant_table(RangeCoder *c, int16_t *quant_table, int scale) +{ int v; - int i=0; + int i = 0; uint8_t state[CONTEXT_SIZE]; memset(state, 128, sizeof(state)); - for(v=0; i<128 ; v++){ - int len= get_symbol(c, state, 0) + 1; + for (v = 0; i < 128; v++) { + int len = get_symbol(c, state, 0) + 1; - if(len + i > 128) return -1; + if (len + i > 128) + return -1; - while(len--){ - quant_table[i] = scale*v; + while (len--) { + quant_table[i] = scale * v; i++; } } - for(i=1; i<128; i++){ - quant_table[256-i]= -quant_table[i]; - } - quant_table[128]= -quant_table[127]; + for (i = 1; i < 128; i++) + quant_table[256 - i] = -quant_table[i]; + quant_table[128] = -quant_table[127]; - return 2*v - 1; + return 2 * v - 1; } -static int read_quant_tables(RangeCoder *c, int16_t quant_table[MAX_CONTEXT_INPUTS][256]){ +static int read_quant_tables(RangeCoder *c, + int16_t quant_table[MAX_CONTEXT_INPUTS][256]) +{ int i; - int context_count=1; + int context_count = 1; - for(i=0; i<5; i++){ - context_count*= read_quant_table(c, quant_table[i], context_count); - if(context_count > 32768U){ + for (i = 0; i < 5; i++) { + context_count *= read_quant_table(c, quant_table[i], context_count); + if (context_count > 32768U) { return -1; } } - return (context_count+1)/2; + return (context_count + 1) / 2; } -static int read_extra_header(FFV1Context *f){ - RangeCoder * const c= &f->c; +static int read_extra_header(FFV1Context *f) +{ + RangeCoder *const c = &f->c; uint8_t state[CONTEXT_SIZE]; int i, j, k; uint8_t state2[32][CONTEXT_SIZE]; @@ -1469,170 +1561,190 @@ static int read_extra_header(FFV1Context *f){ memset(state, 128, sizeof(state)); ff_init_range_decoder(c, f->avctx->extradata, f->avctx->extradata_size); - ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); - - f->version= get_symbol(c, state, 0); - f->ac= f->avctx->coder_type= get_symbol(c, state, 0); - if(f->ac>1){ - for(i=1; i<256; i++){ - f->state_transition[i]= get_symbol(c, state, 1) + c->one_state[i]; - } - } - f->colorspace= get_symbol(c, state, 0); //YUV cs type - f->avctx->bits_per_raw_sample= get_symbol(c, state, 0); - get_rac(c, state); //no chroma = false - f->chroma_h_shift= get_symbol(c, state, 0); - f->chroma_v_shift= get_symbol(c, state, 0); - get_rac(c, state); //transparency plane - f->plane_count= 2; - f->num_h_slices= 1 + get_symbol(c, state, 0); - f->num_v_slices= 1 + get_symbol(c, state, 0); - if(f->num_h_slices > (unsigned)f->width || f->num_v_slices > (unsigned)f->height){ + ff_build_rac_states(c, 0.05 * (1LL << 32), 256 - 8); + + f->version = get_symbol(c, state, 0); + f->ac = f->avctx->coder_type = get_symbol(c, state, 0); + if (f->ac > 1) + for (i = 1; i < 256; i++) + f->state_transition[i] = get_symbol(c, state, 1) + c->one_state[i]; + f->colorspace = get_symbol(c, state, 0); // YUV cs type + f->avctx->bits_per_raw_sample = get_symbol(c, state, 0); + get_rac(c, state); // no chroma = false + f->chroma_h_shift = get_symbol(c, state, 0); + f->chroma_v_shift = get_symbol(c, state, 0); + get_rac(c, state); // transparency plane + f->plane_count = 2; + f->num_h_slices = 1 + get_symbol(c, state, 0); + f->num_v_slices = 1 + get_symbol(c, state, 0); + + if (f->num_h_slices > (unsigned)f->width || + f->num_v_slices > (unsigned)f->height) { av_log(f->avctx, AV_LOG_ERROR, "too many slices\n"); return -1; } - f->quant_table_count= get_symbol(c, state, 0); - if(f->quant_table_count > (unsigned)MAX_QUANT_TABLES) + f->quant_table_count = get_symbol(c, state, 0); + + if (f->quant_table_count > (unsigned)MAX_QUANT_TABLES) return -1; - for(i=0; iquant_table_count; i++){ - if((f->context_count[i]= read_quant_tables(c, f->quant_tables[i])) < 0){ + + for (i = 0; i < f->quant_table_count; i++) { + f->context_count[i] = read_quant_tables(c, f->quant_tables[i]); + if (f->context_count[i] < 0) { av_log(f->avctx, AV_LOG_ERROR, "read_quant_table error\n"); return -1; } } - if(allocate_initial_states(f) < 0) + if (allocate_initial_states(f) < 0) return AVERROR(ENOMEM); - for(i=0; iquant_table_count; i++){ - if(get_rac(c, state)){ - for(j=0; jcontext_count[i]; j++){ - for(k=0; kinitial_states[i][j-1][k] : 128; - f->initial_states[i][j][k]= (pred+get_symbol(c, state2[k], 1))&0xFF; + for (i = 0; i < f->quant_table_count; i++) + if (get_rac(c, state)) + for (j = 0; j < f->context_count[i]; j++) + for (k = 0; k < CONTEXT_SIZE; k++) { + int pred = j ? f->initial_states[i][j - 1][k] : 128; + f->initial_states[i][j][k] = + (pred + get_symbol(c, state2[k], 1)) & 0xFF; } - } - } - } - return 0; } -static int read_header(FFV1Context *f){ +static int read_header(FFV1Context *f) +{ uint8_t state[CONTEXT_SIZE]; int i, j, context_count; - RangeCoder * const c= &f->slice_context[0]->c; + RangeCoder *const c = &f->slice_context[0]->c; memset(state, 128, sizeof(state)); - if(f->version < 2){ - f->version= get_symbol(c, state, 0); - f->ac= f->avctx->coder_type= get_symbol(c, state, 0); - if(f->ac>1){ - for(i=1; i<256; i++){ - f->state_transition[i]= get_symbol(c, state, 1) + c->one_state[i]; - } - } - f->colorspace= get_symbol(c, state, 0); //YUV cs type - if(f->version>0) - f->avctx->bits_per_raw_sample= get_symbol(c, state, 0); - get_rac(c, state); //no chroma = false - f->chroma_h_shift= get_symbol(c, state, 0); - f->chroma_v_shift= get_symbol(c, state, 0); - get_rac(c, state); //transparency plane - f->plane_count= 2; + if (f->version < 2) { + f->version = get_symbol(c, state, 0); + f->ac = f->avctx->coder_type = get_symbol(c, state, 0); + if (f->ac > 1) + for (i = 1; i < 256; i++) + f->state_transition[i] = get_symbol(c, state, 1) + c->one_state[i]; + f->colorspace = get_symbol(c, state, 0); // YUV cs type + if (f->version > 0) + f->avctx->bits_per_raw_sample = get_symbol(c, state, 0); + get_rac(c, state); // no chroma = false + f->chroma_h_shift = get_symbol(c, state, 0); + f->chroma_v_shift = get_symbol(c, state, 0); + get_rac(c, state); // transparency plane + f->plane_count = 2; } - if(f->colorspace==0){ - if(f->avctx->bits_per_raw_sample<=8){ - switch(16*f->chroma_h_shift + f->chroma_v_shift){ - case 0x00: f->avctx->pix_fmt= AV_PIX_FMT_YUV444P; break; - case 0x10: f->avctx->pix_fmt= AV_PIX_FMT_YUV422P; break; - case 0x11: f->avctx->pix_fmt= AV_PIX_FMT_YUV420P; break; - case 0x20: f->avctx->pix_fmt= AV_PIX_FMT_YUV411P; break; - case 0x22: f->avctx->pix_fmt= AV_PIX_FMT_YUV410P; break; + if (f->colorspace == 0) { + if (f->avctx->bits_per_raw_sample <= 8) { + switch (16 * f->chroma_h_shift + f->chroma_v_shift) { + case 0x00: + f->avctx->pix_fmt = AV_PIX_FMT_YUV444P; + break; + case 0x10: + f->avctx->pix_fmt = AV_PIX_FMT_YUV422P; + break; + case 0x11: + f->avctx->pix_fmt = AV_PIX_FMT_YUV420P; + break; + case 0x20: + f->avctx->pix_fmt = AV_PIX_FMT_YUV411P; + break; + case 0x22: + f->avctx->pix_fmt = AV_PIX_FMT_YUV410P; + break; default: av_log(f->avctx, AV_LOG_ERROR, "format not supported\n"); return -1; } - }else{ - switch(16*f->chroma_h_shift + f->chroma_v_shift){ - case 0x00: f->avctx->pix_fmt= AV_PIX_FMT_YUV444P16; break; - case 0x10: f->avctx->pix_fmt= AV_PIX_FMT_YUV422P16; break; - case 0x11: f->avctx->pix_fmt= AV_PIX_FMT_YUV420P16; break; + } else { + switch (16 * f->chroma_h_shift + f->chroma_v_shift) { + case 0x00: + f->avctx->pix_fmt = AV_PIX_FMT_YUV444P16; + break; + case 0x10: + f->avctx->pix_fmt = AV_PIX_FMT_YUV422P16; + break; + case 0x11: + f->avctx->pix_fmt = AV_PIX_FMT_YUV420P16; + break; default: av_log(f->avctx, AV_LOG_ERROR, "format not supported\n"); return -1; } } - }else if(f->colorspace==1){ - if(f->chroma_h_shift || f->chroma_v_shift){ - av_log(f->avctx, AV_LOG_ERROR, "chroma subsampling not supported in this colorspace\n"); + } else if (f->colorspace == 1) { + if (f->chroma_h_shift || f->chroma_v_shift) { + av_log(f->avctx, AV_LOG_ERROR, + "chroma subsampling not supported in this colorspace\n"); return -1; } - f->avctx->pix_fmt= AV_PIX_FMT_RGB32; - }else{ + f->avctx->pix_fmt = AV_PIX_FMT_RGB32; + } else { av_log(f->avctx, AV_LOG_ERROR, "colorspace not supported\n"); return -1; } av_dlog(f->avctx, "%d %d %d\n", f->chroma_h_shift, f->chroma_v_shift, f->avctx->pix_fmt); - if(f->version < 2){ - context_count= read_quant_tables(c, f->quant_table); - if(context_count < 0){ - av_log(f->avctx, AV_LOG_ERROR, "read_quant_table error\n"); - return -1; + + if (f->version < 2) { + context_count = read_quant_tables(c, f->quant_table); + if (context_count < 0) { + av_log(f->avctx, AV_LOG_ERROR, "read_quant_table error\n"); + return -1; } - }else{ - f->slice_count= get_symbol(c, state, 0); - if(f->slice_count > (unsigned)MAX_SLICES) + } else { + f->slice_count = get_symbol(c, state, 0); + if (f->slice_count > (unsigned)MAX_SLICES) return -1; } - for(j=0; jslice_count; j++){ - FFV1Context *fs= f->slice_context[j]; - fs->ac= f->ac; - - if(f->version >= 2){ - fs->slice_x = get_symbol(c, state, 0) *f->width ; - fs->slice_y = get_symbol(c, state, 0) *f->height; - fs->slice_width =(get_symbol(c, state, 0)+1)*f->width + fs->slice_x; - fs->slice_height=(get_symbol(c, state, 0)+1)*f->height + fs->slice_y; - - fs->slice_x /= f->num_h_slices; - fs->slice_y /= f->num_v_slices; - fs->slice_width = fs->slice_width /f->num_h_slices - fs->slice_x; - fs->slice_height = fs->slice_height/f->num_v_slices - fs->slice_y; - if((unsigned)fs->slice_width > f->width || (unsigned)fs->slice_height > f->height) + for (j = 0; j < f->slice_count; j++) { + FFV1Context *fs = f->slice_context[j]; + fs->ac = f->ac; + + if (f->version >= 2) { + fs->slice_x = get_symbol(c, state, 0) * f->width; + fs->slice_y = get_symbol(c, state, 0) * f->height; + fs->slice_width = (get_symbol(c, state, 0) + 1) * f->width + fs->slice_x; + fs->slice_height = (get_symbol(c, state, 0) + 1) * f->height + fs->slice_y; + + fs->slice_x /= f->num_h_slices; + fs->slice_y /= f->num_v_slices; + fs->slice_width = fs->slice_width / f->num_h_slices - fs->slice_x; + fs->slice_height = fs->slice_height / f->num_v_slices - fs->slice_y; + if ((unsigned)fs->slice_width > f->width || + (unsigned)fs->slice_height > f->height) return -1; - if( (unsigned)fs->slice_x + (uint64_t)fs->slice_width > f->width - || (unsigned)fs->slice_y + (uint64_t)fs->slice_height > f->height) + if ((unsigned)fs->slice_x + (uint64_t)fs->slice_width > f->width || + (unsigned)fs->slice_y + (uint64_t)fs->slice_height > f->height) return -1; } - for(i=0; iplane_count; i++){ - PlaneContext * const p= &fs->plane[i]; + for (i = 0; i < f->plane_count; i++) { + PlaneContext *const p = &fs->plane[i]; - if(f->version >= 2){ - int idx=get_symbol(c, state, 0); - if(idx > (unsigned)f->quant_table_count){ - av_log(f->avctx, AV_LOG_ERROR, "quant_table_index out of range\n"); + if (f->version >= 2) { + int idx = get_symbol(c, state, 0); + if (idx > (unsigned)f->quant_table_count) { + av_log(f->avctx, AV_LOG_ERROR, + "quant_table_index out of range\n"); return -1; } - p->quant_table_index= idx; - memcpy(p->quant_table, f->quant_tables[idx], sizeof(p->quant_table)); - context_count= f->context_count[idx]; - }else{ + p->quant_table_index = idx; + memcpy(p->quant_table, f->quant_tables[idx], + sizeof(p->quant_table)); + context_count = f->context_count[idx]; + } else { memcpy(p->quant_table, f->quant_table, sizeof(p->quant_table)); } - if(p->context_count < context_count){ + if (p->context_count < context_count) { av_freep(&p->state); av_freep(&p->vlc_state); } - p->context_count= context_count; + p->context_count = context_count; } } @@ -1645,23 +1757,25 @@ static av_cold int decode_init(AVCodecContext *avctx) common_init(avctx); - if(avctx->extradata && read_extra_header(f) < 0) + if (avctx->extradata && read_extra_header(f) < 0) return -1; - if(init_slice_contexts(f) < 0) + if (init_slice_contexts(f) < 0) return -1; return 0; } -static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPacket *avpkt){ - const uint8_t *buf = avpkt->data; - int buf_size = avpkt->size; - FFV1Context *f = avctx->priv_data; - RangeCoder * const c= &f->slice_context[0]->c; - AVFrame * const p= &f->picture; +static int decode_frame(AVCodecContext *avctx, void *data, + int *data_size, AVPacket *avpkt) +{ + const uint8_t *buf = avpkt->data; + int buf_size = avpkt->size; + FFV1Context *f = avctx->priv_data; + RangeCoder *const c = &f->slice_context[0]->c; + AVFrame *const p = &f->picture; int bytes_read, i; - uint8_t keystate= 128; + uint8_t keystate = 128; const uint8_t *buf_p; AVFrame *picture = data; @@ -1671,66 +1785,67 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPac avctx->release_buffer(avctx, p); ff_init_range_decoder(c, buf, buf_size); - ff_build_rac_states(c, 0.05*(1LL<<32), 256-8); + ff_build_rac_states(c, 0.05 * (1LL << 32), 256 - 8); - - p->pict_type= AV_PICTURE_TYPE_I; //FIXME I vs. P - if(get_rac(c, &keystate)){ - p->key_frame= 1; - if(read_header(f) < 0) + p->pict_type = AV_PICTURE_TYPE_I; // FIXME: I vs. P + if (get_rac(c, &keystate)) { + p->key_frame = 1; + if (read_header(f) < 0) return -1; - if(init_slice_state(f) < 0) + if (init_slice_state(f) < 0) return -1; clear_state(f); - }else{ - p->key_frame= 0; + } else { + p->key_frame = 0; } - if(f->ac>1){ + if (f->ac > 1) { int i; - for(i=1; i<256; i++){ - c->one_state[i]= f->state_transition[i]; - c->zero_state[256-i]= 256-c->one_state[i]; + for (i = 1; i < 256; i++) { + c->one_state[i] = f->state_transition[i]; + c->zero_state[256 - i] = 256 - c->one_state[i]; } } - p->reference= 0; - if(avctx->get_buffer(avctx, p) < 0){ + p->reference = 0; + if (avctx->get_buffer(avctx, p) < 0) { av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); return -1; } - if(avctx->debug&FF_DEBUG_PICT_INFO) + if (avctx->debug & FF_DEBUG_PICT_INFO) av_log(avctx, AV_LOG_ERROR, "keyframe:%d coder:%d\n", p->key_frame, f->ac); - if(!f->ac){ + if (!f->ac) { bytes_read = c->bytestream - c->bytestream_start - 1; - if(bytes_read ==0) av_log(avctx, AV_LOG_ERROR, "error at end of AC stream\n"); //FIXME - init_get_bits(&f->slice_context[0]->gb, buf + bytes_read, (buf_size - bytes_read) * 8); + if (bytes_read == 0) + av_log(avctx, AV_LOG_ERROR, "error at end of AC stream\n"); // FIXME + init_get_bits(&f->slice_context[0]->gb, buf + bytes_read, + (buf_size - bytes_read) * 8); } else { bytes_read = 0; /* avoid warning */ } - buf_p= buf + buf_size; - for(i=f->slice_count-1; i>0; i--){ - FFV1Context *fs= f->slice_context[i]; - int v= AV_RB24(buf_p-3)+3; - if(buf_p - buf <= v){ + buf_p = buf + buf_size; + for (i = f->slice_count - 1; i > 0; i--) { + FFV1Context *fs = f->slice_context[i]; + int v = AV_RB24(buf_p - 3) + 3; + if (buf_p - buf <= v) { av_log(avctx, AV_LOG_ERROR, "Slice pointer chain broken\n"); return -1; } buf_p -= v; - if(fs->ac){ + if (fs->ac) ff_init_range_decoder(&fs->c, buf_p, v); - }else{ + else init_get_bits(&fs->gb, buf_p, v * 8); - } } - avctx->execute(avctx, decode_slice, &f->slice_context[0], NULL, f->slice_count, sizeof(void*)); + avctx->execute(avctx, decode_slice, &f->slice_context[0], + NULL, f->slice_count, sizeof(void *)); f->picture_number++; - *picture= *p; + *picture = *p; *data_size = sizeof(AVFrame); return buf_size; @@ -1759,10 +1874,12 @@ AVCodec ff_ffv1_encoder = { .encode2 = encode_frame, .close = common_end, .capabilities = CODEC_CAP_SLICE_THREADS, - .pix_fmts = (const enum AVPixelFormat[]){ - AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUV444P, AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUV411P, - AV_PIX_FMT_YUV410P, AV_PIX_FMT_RGB32, AV_PIX_FMT_YUV420P16, AV_PIX_FMT_YUV422P16, - AV_PIX_FMT_YUV444P16, AV_PIX_FMT_NONE + .pix_fmts = (const enum AVPixelFormat[]) { + AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUV444P, + AV_PIX_FMT_YUV411P, AV_PIX_FMT_YUV410P, + AV_PIX_FMT_YUV420P16, AV_PIX_FMT_YUV422P16, AV_PIX_FMT_YUV444P16, + AV_PIX_FMT_RGB32, + AV_PIX_FMT_NONE }, .long_name = NULL_IF_CONFIG_SMALL("FFmpeg video codec #1"), }; From 4a7429203a390f5629c819b98f314246b62b2145 Mon Sep 17 00:00:00 2001 From: Christian Schmidt Date: Tue, 16 Oct 2012 15:40:58 +0200 Subject: [PATCH 6/7] pcm-mpeg: correct bitrate calculation Bitrate calculation is off since the bluray spec always specifies an even number of coded channels. This was honored in the decoder, but not for bitrate calculation. Signed-off-by: Luca Barbato --- libavcodec/pcm-mpeg.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/libavcodec/pcm-mpeg.c b/libavcodec/pcm-mpeg.c index 4a386483d1..b5af6493b7 100644 --- a/libavcodec/pcm-mpeg.c +++ b/libavcodec/pcm-mpeg.c @@ -109,12 +109,12 @@ static int pcm_bluray_parse_header(AVCodecContext *avctx, return -1; } - avctx->bit_rate = avctx->channels * avctx->sample_rate * + avctx->bit_rate = FFALIGN(avctx->channels, 2) * avctx->sample_rate * avctx->bits_per_coded_sample; if (avctx->debug & FF_DEBUG_PICT_INFO) av_dlog(avctx, - "pcm_bluray_parse_header: %d channels, %d bits per sample, %d kHz, %d kbit\n", + "pcm_bluray_parse_header: %d channels, %d bits per sample, %d Hz, %d bit/s\n", avctx->channels, avctx->bits_per_coded_sample, avctx->sample_rate, avctx->bit_rate); return 0; From a25d912dca9cd553440167e0476c47581359c0fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C3=ABl=20Carr=C3=A9?= Date: Mon, 15 Oct 2012 18:41:55 +0200 Subject: [PATCH 7/7] avcodec_encode_audio(): fix invalid free Since 2bc0de385, AVFrame needs to be initialized before calling avcodec_get_frame_defaults(). Signed-off-by: Anton Khirnov --- libavcodec/utils.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libavcodec/utils.c b/libavcodec/utils.c index bb99a5a32d..836d95388d 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -1073,7 +1073,7 @@ int attribute_align_arg avcodec_encode_audio(AVCodecContext *avctx, const short *samples) { AVPacket pkt; - AVFrame frame0; + AVFrame frame0 = { 0 }; AVFrame *frame; int ret, samples_size, got_packet;