From patchwork Mon May 31 09:26:00 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Anton Khirnov X-Patchwork-Id: 28016 Delivered-To: ffmpegpatchwork2@gmail.com Received: by 2002:a6b:b214:0:0:0:0:0 with SMTP id b20csp2710093iof; Mon, 31 May 2021 02:26:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwoTmH8t5uqmtzK9HMRuJbBILTd06OrrMxByGhAZRCd/AGrXG+Yl4b5zPg4ADRRdKZGsO+F X-Received: by 2002:a05:6402:15:: with SMTP id d21mr24738644edu.66.1622453174242; Mon, 31 May 2021 02:26:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622453174; cv=none; d=google.com; s=arc-20160816; b=fNGwb5k3ja+VEpS1f1uSqFiShmOc77dlsgp59TBPL8IJoctoIftsXz0bd/mcS0AnFC ryzqmCLkoYqVdMK1zfA9t0fYmN66hND6yRBjBcLYFl871pGasjFRCMH6YdzAj7MvGkVh Pzpelrh7dNl1gBk83NUVRIMq8S/ArhZzL0DbZuFbjqGLwdsvL4d6k3b7g9mux0oCbPI6 NlzzSiWdpWnY487xLepa3DVx0w1pYzfj9e6Rn3wUNLMbIYD70XTKboBvqdBUD0r8XlNX nj2UM8xVntqcWoh4MPb1jvir+xYeBgnFrpKWj6ANOL53IyPJZ64e9bgV4lsSs+PohQ14 nR6Q== 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 :delivered-to; bh=KkSUgJ420DlfpQOemegrE2NHiFoOY6sQ0HK4L//Rklc=; b=hEpVatrAWBjzvKP/jt7B43N77RlMM1gOm/k2FpwQR0MIXzjDLeBDoqoB+3Il0Ap3Ch BiUTekxrr8mZUXBqh9et71s+KocGRcxotqNNW/V/8ftf+rAG8CoNiYvuk+P0B3BjXoZE +8E7IDrWTDAB4hhkHWuIW7kbAcWWNdFu08A40T8zH7EbVrw+4Q6ewtqQ7+wm7VT7RLol 5JupTfufErW64Pwx3Kk54JZ1xFE+viUEDKjKWByLDXNl69JJGOetSmTtNSnlx4MFltcX AsHC1qejzoiCA8TRax3nPyxYEgfGz6/kA7APMlHceDxPjbfzS15v7B3FXuQaGSUm3P+y LDOA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org. [79.124.17.100]) by mx.google.com with ESMTP id e1si12222686edk.506.2021.05.31.02.26.13; Mon, 31 May 2021 02:26:14 -0700 (PDT) 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; 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 Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 16725688156; Mon, 31 May 2021 12:26:10 +0300 (EEST) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail0.khirnov.net (red.khirnov.net [176.97.15.12]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id D58AC6801E7 for ; Mon, 31 May 2021 12:26:03 +0300 (EEST) Received: from localhost (localhost [IPv6:::1]) by mail0.khirnov.net (Postfix) with ESMTP id 4EE8D240476 for ; Mon, 31 May 2021 11:26:03 +0200 (CEST) Received: from mail0.khirnov.net ([IPv6:::1]) by localhost (mail0.khirnov.net [IPv6:::1]) (amavisd-new, port 10024) with ESMTP id 4M-TvXbx6d81 for ; Mon, 31 May 2021 11:26:02 +0200 (CEST) Received: from libav.khirnov.net (libav.khirnov.net [IPv6:2a00:c500:561:201::7]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256 client-signature RSA-PSS (2048 bits) client-digest SHA256) (Client CN "libav.khirnov.net", Issuer "smtp.khirnov.net SMTP CA" (verified OK)) by mail0.khirnov.net (Postfix) with ESMTPS id A882424042A for ; Mon, 31 May 2021 11:26:02 +0200 (CEST) Received: by libav.khirnov.net (Postfix, from userid 1000) id B01F13A125B; Mon, 31 May 2021 11:26:02 +0200 (CEST) From: Anton Khirnov To: ffmpeg-devel@ffmpeg.org Date: Mon, 31 May 2021 11:26:00 +0200 Message-Id: <20210531092600.20576-1-anton@khirnov.net> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Subject: [FFmpeg-devel] [PATCH] lavu/mem: un-inline av_size_mult() X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.29 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" X-TUID: f/J2asOYujq8 There seems to be no compelling reason for it to be inline. --- libavutil/mem.c | 18 ++++++++++++++++++ libavutil/mem.h | 19 +------------------ 2 files changed, 19 insertions(+), 18 deletions(-) diff --git a/libavutil/mem.c b/libavutil/mem.c index a52d33d4a6..063635fb22 100644 --- a/libavutil/mem.c +++ b/libavutil/mem.c @@ -547,3 +547,21 @@ void av_fast_mallocz(void *ptr, unsigned int *size, size_t min_size) { fast_malloc(ptr, size, min_size, 1); } + +int av_size_mult(size_t a, size_t b, size_t *r) +{ + size_t t; + +#if (!defined(__INTEL_COMPILER) && AV_GCC_VERSION_AT_LEAST(5,1)) || AV_HAS_BUILTIN(__builtin_mul_overflow) + if (__builtin_mul_overflow(a, b, &t)) + return AVERROR(EINVAL); +#else + t = a * b; + /* Hack inspired from glibc: don't try the division if nelem and elsize + * are both less than sqrt(SIZE_MAX). */ + if ((a | b) >= ((size_t)1 << (sizeof(size_t) * 4)) && a && t / a != b) + return AVERROR(EINVAL); +#endif + *r = t; + return 0; +} diff --git a/libavutil/mem.h b/libavutil/mem.h index c876111afb..e9d343eaf0 100644 --- a/libavutil/mem.h +++ b/libavutil/mem.h @@ -31,7 +31,6 @@ #include #include "attributes.h" -#include "error.h" #include "avutil.h" #include "version.h" @@ -672,23 +671,7 @@ void *av_dynarray2_add(void **tab_ptr, int *nb_ptr, size_t elem_size, * @param[out] r Pointer to the result of the operation * @return 0 on success, AVERROR(EINVAL) on overflow */ -static inline int av_size_mult(size_t a, size_t b, size_t *r) -{ - size_t t; - -#if (!defined(__INTEL_COMPILER) && AV_GCC_VERSION_AT_LEAST(5,1)) || AV_HAS_BUILTIN(__builtin_mul_overflow) - if (__builtin_mul_overflow(a, b, &t)) - return AVERROR(EINVAL); -#else - t = a * b; - /* Hack inspired from glibc: don't try the division if nelem and elsize - * are both less than sqrt(SIZE_MAX). */ - if ((a | b) >= ((size_t)1 << (sizeof(size_t) * 4)) && a && t / a != b) - return AVERROR(EINVAL); -#endif - *r = t; - return 0; -} +int av_size_mult(size_t a, size_t b, size_t *r); /** * Set the maximum size that may be allocated in one block.