From patchwork Sat Feb 3 22:51:13 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Muhammad Faiz X-Patchwork-Id: 7502 Delivered-To: ffmpegpatchwork@gmail.com Received: by 10.2.150.1 with SMTP id c1csp1101020jai; Sat, 3 Feb 2018 14:51:37 -0800 (PST) X-Google-Smtp-Source: AH8x227RwsWZBCNbq07olI3ulYquoIzbQr9pdUxzNs4ZxIrT4m3yfigAZebV6PWYidOxVp4PFsPx X-Received: by 10.28.213.129 with SMTP id m123mr30319726wmg.91.1517698297441; Sat, 03 Feb 2018 14:51:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517698297; cv=none; d=google.com; s=arc-20160816; b=vkmjO8azoypOLcKIFU+rPri/yoWMUIgXPGhnrMxLYYgAtgos+F9vO/6oiT12Zw2/Wn jLBW92ixGfwpAf1oGMVgR0S61D5CBXogkPTcJvwlncGl6tGNbyZbUSVEoEKMehqQxncC BgX/qXYaOs5veW3anHoNmqS332000PLoyly8SM0X7NMN90ykpCc1SXSvndeXUJh3crMR H9PJ+LSX359xt8dGxVga/d7j8bLYNycCqQ/tcaM4BLlyEA2YuBzxE+absuUhbOAnvAIy p6UGhejvxRbp41nj2UuKntrLbwd9TSSTqXaHN1rzX3nsIE5ICpIDkXJ9OiiFmBqxGg9X Vq9g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:reply-to:list-subscribe :list-help:list-post:list-archive:list-unsubscribe:list-id :precedence:subject:mime-version:message-id:date:to:from :dkim-signature:delivered-to:arc-authentication-results; bh=KDe3DFg47GrrGaLCdQjKZk2iV4+fXmI0tVRFVI7Lr2s=; b=qVBc+Kr1Zym+RJQgwHQDwb1kfLePyj5APHf/OyaD3JXzFRRZaEXumlTCMOi3OgWNrc Y1Apq+yyL/R5CNKZI+z9qzjNkjnNySSdTlYFL+IG6w060YIZDXv/ORAq6dSqL3/qafOP ICEZWbfEVagYX0CZAe89xoZT5y6hZkOPkqQIdyDk1sN5MiEQwXBJlSw2athRD4MbFfaG Oxw3z/A9bESjvqAxUM/0JAfGPgldV693wlVVFGMpiPMYvlI0O1jvZskXA3O4Z92NlKpM Xh4RDAvM/u0kRkzMyrX69G5Q92xzK8VC6Z7IiV6QhS112JeEhTYZNjPgytHRutVSw4xL 7nxw== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20161025 header.b=L4flJa1y; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org. [79.124.17.100]) by mx.google.com with ESMTP id b193si3245907wmb.156.2018.02.03.14.51.36; Sat, 03 Feb 2018 14:51:37 -0800 (PST) Received-SPF: pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) client-ip=79.124.17.100; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20161025 header.b=L4flJa1y; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 27DED680498; Sun, 4 Feb 2018 00:51:28 +0200 (EET) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail-pg0-f65.google.com (mail-pg0-f65.google.com [74.125.83.65]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id A686668035F for ; Sun, 4 Feb 2018 00:51:21 +0200 (EET) Received: by mail-pg0-f65.google.com with SMTP id o13so15809110pgs.2 for ; Sat, 03 Feb 2018 14:51:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=EiOShEWPUgUR/Zvl2CKJdvhSe0+arti3cgqLxfQpzGU=; b=L4flJa1yW4MdqWfrBcwbVUx8kOATAIOceawI9ehpnPIgUkj5Sf9w2UG9vLWaSXCBpa iLo0odVKBhA2wk5VZ5qXwl5jzFeMPQ+SXnrUqUU83pM7a7n6nEsCylqmiAvtli7m6Xv2 5A44D3gb+EdiMMW2K5K/2EgFjFUqRcmuzrgsxa7thT9bqGyIUo4XNHjvf339GOs3mc4c 28gcDlw9jzCIdE/Z4gjO908pB497Ib3HrOjbhiOeeYETtYUmVQuMiZPxNsSOBrNtYk87 wwCiGFhzSk3XjmcOvr929s5m/V1xhF1yLfZzBGOWI35majps5I1s9pcrNxu0Hy62poEx 3rrQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=EiOShEWPUgUR/Zvl2CKJdvhSe0+arti3cgqLxfQpzGU=; b=eEyQb/S4W3BfSrKm5bf33wbvQW0Of5pX7mKAhXNKp4dBOfjjY72slbqruk48JDTikL 1FzBGP3sUSd/pMjNvyNTmnsYgTSVxNjCKzar2n1kaF6yMzASAF+B/VOi4KH0e8TdVYHF Zi3i7O9vha8+aJw4LNvaPX7yDOuw5CrCCN6yy5FI/iH9/w+98Uclk+yw3lsymzeHKIZD YkpA1Vv+ZwwauvbJWA0I4Ro6j8HUUuP5mrC2lYmnEzBP/5ozTVuEcwdJWpRGfjHm86Ft aagNRMHDRwu9rGouY38VVkmQoSeS1r1h2GiRr0XA1Nk+m76na4KaNDaTnyh49xDbqZZH QC/Q== X-Gm-Message-State: AKwxytc05cUdO4/FqMffPe8GfFDWOn4yXLM4CZCmrXWWGmo+8oAba2RQ TczBgl+96bfp8P+MHBXhDWRM+Mw7 X-Received: by 10.101.92.74 with SMTP id v10mr5182623pgr.341.1517698286253; Sat, 03 Feb 2018 14:51:26 -0800 (PST) Received: from localhost.localdomain ([114.124.196.28]) by smtp.gmail.com with ESMTPSA id v11sm7835818pgf.83.2018.02.03.14.51.24 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sat, 03 Feb 2018 14:51:25 -0800 (PST) From: Muhammad Faiz To: ffmpeg-devel@ffmpeg.org Date: Sun, 4 Feb 2018 05:51:13 +0700 Message-Id: <20180203225114.21423-1-mfcc64@gmail.com> X-Mailer: git-send-email 2.13.2 MIME-Version: 1.0 Subject: [FFmpeg-devel] [PATCH] avcodec/me_cmp: remove ff_me_cmp_init_static() X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" Precalculate and constify ff_square_tab. Signed-off-by: Muhammad Faiz --- libavcodec/me_cmp.c | 51 +++++++++++++++++++++++++++++++++----------- libavcodec/me_cmp.h | 4 +--- libavcodec/mpegvideo_enc.c | 2 +- libavcodec/mpegvideoencdsp.c | 2 +- libavcodec/snowenc.c | 2 +- libavcodec/utils.c | 13 ----------- 6 files changed, 43 insertions(+), 31 deletions(-) diff --git a/libavcodec/me_cmp.c b/libavcodec/me_cmp.c index 5e34a11593..67a5bb5c71 100644 --- a/libavcodec/me_cmp.c +++ b/libavcodec/me_cmp.c @@ -22,6 +22,7 @@ #include "libavutil/attributes.h" #include "libavutil/internal.h" +#include "libavutil/thread.h" #include "avcodec.h" #include "copy_block.h" #include "simple_idct.h" @@ -29,13 +30,47 @@ #include "mpegvideo.h" #include "config.h" -uint32_t ff_square_tab[512] = { 0, }; +/* (i - 256) * (i - 256) */ +const uint32_t ff_square_tab[512] = { + 65536, 65025, 64516, 64009, 63504, 63001, 62500, 62001, 61504, 61009, 60516, 60025, 59536, 59049, 58564, 58081, + 57600, 57121, 56644, 56169, 55696, 55225, 54756, 54289, 53824, 53361, 52900, 52441, 51984, 51529, 51076, 50625, + 50176, 49729, 49284, 48841, 48400, 47961, 47524, 47089, 46656, 46225, 45796, 45369, 44944, 44521, 44100, 43681, + 43264, 42849, 42436, 42025, 41616, 41209, 40804, 40401, 40000, 39601, 39204, 38809, 38416, 38025, 37636, 37249, + 36864, 36481, 36100, 35721, 35344, 34969, 34596, 34225, 33856, 33489, 33124, 32761, 32400, 32041, 31684, 31329, + 30976, 30625, 30276, 29929, 29584, 29241, 28900, 28561, 28224, 27889, 27556, 27225, 26896, 26569, 26244, 25921, + 25600, 25281, 24964, 24649, 24336, 24025, 23716, 23409, 23104, 22801, 22500, 22201, 21904, 21609, 21316, 21025, + 20736, 20449, 20164, 19881, 19600, 19321, 19044, 18769, 18496, 18225, 17956, 17689, 17424, 17161, 16900, 16641, + 16384, 16129, 15876, 15625, 15376, 15129, 14884, 14641, 14400, 14161, 13924, 13689, 13456, 13225, 12996, 12769, + 12544, 12321, 12100, 11881, 11664, 11449, 11236, 11025, 10816, 10609, 10404, 10201, 10000, 9801, 9604, 9409, + 9216, 9025, 8836, 8649, 8464, 8281, 8100, 7921, 7744, 7569, 7396, 7225, 7056, 6889, 6724, 6561, + 6400, 6241, 6084, 5929, 5776, 5625, 5476, 5329, 5184, 5041, 4900, 4761, 4624, 4489, 4356, 4225, + 4096, 3969, 3844, 3721, 3600, 3481, 3364, 3249, 3136, 3025, 2916, 2809, 2704, 2601, 2500, 2401, + 2304, 2209, 2116, 2025, 1936, 1849, 1764, 1681, 1600, 1521, 1444, 1369, 1296, 1225, 1156, 1089, + 1024, 961, 900, 841, 784, 729, 676, 625, 576, 529, 484, 441, 400, 361, 324, 289, + 256, 225, 196, 169, 144, 121, 100, 81, 64, 49, 36, 25, 16, 9, 4, 1, + 0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100, 121, 144, 169, 196, 225, + 256, 289, 324, 361, 400, 441, 484, 529, 576, 625, 676, 729, 784, 841, 900, 961, + 1024, 1089, 1156, 1225, 1296, 1369, 1444, 1521, 1600, 1681, 1764, 1849, 1936, 2025, 2116, 2209, + 2304, 2401, 2500, 2601, 2704, 2809, 2916, 3025, 3136, 3249, 3364, 3481, 3600, 3721, 3844, 3969, + 4096, 4225, 4356, 4489, 4624, 4761, 4900, 5041, 5184, 5329, 5476, 5625, 5776, 5929, 6084, 6241, + 6400, 6561, 6724, 6889, 7056, 7225, 7396, 7569, 7744, 7921, 8100, 8281, 8464, 8649, 8836, 9025, + 9216, 9409, 9604, 9801, 10000, 10201, 10404, 10609, 10816, 11025, 11236, 11449, 11664, 11881, 12100, 12321, + 12544, 12769, 12996, 13225, 13456, 13689, 13924, 14161, 14400, 14641, 14884, 15129, 15376, 15625, 15876, 16129, + 16384, 16641, 16900, 17161, 17424, 17689, 17956, 18225, 18496, 18769, 19044, 19321, 19600, 19881, 20164, 20449, + 20736, 21025, 21316, 21609, 21904, 22201, 22500, 22801, 23104, 23409, 23716, 24025, 24336, 24649, 24964, 25281, + 25600, 25921, 26244, 26569, 26896, 27225, 27556, 27889, 28224, 28561, 28900, 29241, 29584, 29929, 30276, 30625, + 30976, 31329, 31684, 32041, 32400, 32761, 33124, 33489, 33856, 34225, 34596, 34969, 35344, 35721, 36100, 36481, + 36864, 37249, 37636, 38025, 38416, 38809, 39204, 39601, 40000, 40401, 40804, 41209, 41616, 42025, 42436, 42849, + 43264, 43681, 44100, 44521, 44944, 45369, 45796, 46225, 46656, 47089, 47524, 47961, 48400, 48841, 49284, 49729, + 50176, 50625, 51076, 51529, 51984, 52441, 52900, 53361, 53824, 54289, 54756, 55225, 55696, 56169, 56644, 57121, + 57600, 58081, 58564, 59049, 59536, 60025, 60516, 61009, 61504, 62001, 62500, 63001, 63504, 64009, 64516, 65025, +}; static int sse4_c(MpegEncContext *v, uint8_t *pix1, uint8_t *pix2, ptrdiff_t stride, int h) { int s = 0, i; - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; for (i = 0; i < h; i++) { s += sq[pix1[0] - pix2[0]]; @@ -52,7 +87,7 @@ static int sse8_c(MpegEncContext *v, uint8_t *pix1, uint8_t *pix2, ptrdiff_t stride, int h) { int s = 0, i; - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; for (i = 0; i < h; i++) { s += sq[pix1[0] - pix2[0]]; @@ -73,7 +108,7 @@ static int sse16_c(MpegEncContext *v, uint8_t *pix1, uint8_t *pix2, ptrdiff_t stride, int h) { int s = 0, i; - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; for (i = 0; i < h; i++) { s += sq[pix1[0] - pix2[0]]; @@ -977,14 +1012,6 @@ WRAPPER8_16_SQ(quant_psnr8x8_c, quant_psnr16_c) WRAPPER8_16_SQ(rd8x8_c, rd16_c) WRAPPER8_16_SQ(bit8x8_c, bit16_c) -av_cold void ff_me_cmp_init_static(void) -{ - int i; - - for (i = 0; i < 512; i++) - ff_square_tab[i] = (i - 256) * (i - 256); -} - int ff_check_alignment(void) { static int did_fail = 0; diff --git a/libavcodec/me_cmp.h b/libavcodec/me_cmp.h index 0dbbcbb1d9..0a589e3c3d 100644 --- a/libavcodec/me_cmp.h +++ b/libavcodec/me_cmp.h @@ -23,7 +23,7 @@ #include "avcodec.h" -extern uint32_t ff_square_tab[512]; +extern const uint32_t ff_square_tab[512]; /* minimum alignment rules ;) @@ -79,8 +79,6 @@ typedef struct MECmpContext { me_cmp_func median_sad[6]; } MECmpContext; -void ff_me_cmp_init_static(void); - int ff_check_alignment(void); void ff_me_cmp_init(MECmpContext *c, AVCodecContext *avctx); diff --git a/libavcodec/mpegvideo_enc.c b/libavcodec/mpegvideo_enc.c index f1f4989231..979e138b88 100644 --- a/libavcodec/mpegvideo_enc.c +++ b/libavcodec/mpegvideo_enc.c @@ -2713,7 +2713,7 @@ static inline void encode_mb_hq(MpegEncContext *s, MpegEncContext *backup, MpegE } static int sse(MpegEncContext *s, uint8_t *src1, uint8_t *src2, int w, int h, int stride){ - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; int acc=0; int x,y; diff --git a/libavcodec/mpegvideoencdsp.c b/libavcodec/mpegvideoencdsp.c index 0af3d8bef8..a34ab3553e 100644 --- a/libavcodec/mpegvideoencdsp.c +++ b/libavcodec/mpegvideoencdsp.c @@ -81,7 +81,7 @@ static int pix_sum_c(uint8_t *pix, int line_size) static int pix_norm1_c(uint8_t *pix, int line_size) { int s = 0, i, j; - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; for (i = 0; i < 16; i++) { for (j = 0; j < 16; j += 8) { diff --git a/libavcodec/snowenc.c b/libavcodec/snowenc.c index 4fec377591..61a658fa44 100644 --- a/libavcodec/snowenc.c +++ b/libavcodec/snowenc.c @@ -179,7 +179,7 @@ static int pix_sum(uint8_t * pix, int line_size, int w, int h) static int pix_norm1(uint8_t * pix, int line_size, int w) { int s, i, j; - uint32_t *sq = ff_square_tab + 256; + const uint32_t *sq = ff_square_tab + 256; s = 0; for (i = 0; i < w; i++) { diff --git a/libavcodec/utils.c b/libavcodec/utils.c index 4c718432ad..aefe631590 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -104,18 +104,6 @@ AVCodec *av_codec_next(const AVCodec *c) return first_avcodec; } -static av_cold void avcodec_init(void) -{ - static int initialized = 0; - - if (initialized != 0) - return; - initialized = 1; - - if (CONFIG_ME_CMP) - ff_me_cmp_init_static(); -} - int av_codec_is_encoder(const AVCodec *codec) { return codec && (codec->encode_sub || codec->encode2 ||codec->send_frame); @@ -131,7 +119,6 @@ static AVMutex codec_register_mutex = AV_MUTEX_INITIALIZER; av_cold void avcodec_register(AVCodec *codec) { AVCodec **p; - avcodec_init(); ff_mutex_lock(&codec_register_mutex); p = last_avcodec;