From patchwork Sat May 21 14:07:39 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Aman Karmani X-Patchwork-Id: 35875 Delivered-To: ffmpegpatchwork2@gmail.com Received: by 2002:a05:6a21:9992:b0:82:461d:f3b with SMTP id ve18csp1081724pzb; Sat, 21 May 2022 07:08:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzqXat/j8mPXyu+v5/cl4Jkh3ATt8ZDkoPkmTpuOyR8PIQVis+PTYYrHK8AZ9DQbARMVvFP X-Received: by 2002:a17:906:264d:b0:6fe:a134:59ae with SMTP id i13-20020a170906264d00b006fea13459aemr9455969ejc.56.1653142088408; Sat, 21 May 2022 07:08:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653142088; cv=none; d=google.com; s=arc-20160816; b=w6qa0qX3D8gF4YOj8/KU/PJgafEoadddCru0z8X7YkoKkZC0IFDdUjEwsFyWNmYtgs 1ZaDBDTKNs9qdi2soLW8QxizAdDLb9DyxUopVUEApfNifQIpRTWF/gj3G4ns/fr933Bf qHh7gdAckwmUvvrkQ50Ej/t+jr1LNlL3iY8bG+ewp8Gpux6advvUBsEpkrM+0lTN9bVv krjij/dhFb/fPqDSLbr+Le0o9Fqn5rkYJ49SNaqZAKi1PgBw0CPeV2sN3SUN4QBYGO2V W0vAhG5e2JI7RA3/GtPgo++bqe8W0zgCAz4tE/pabg/mEQuWiiCk1SCJGuDIxVkJdwWs RR9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:cc:reply-to :list-subscribe:list-help:list-post:list-archive:list-unsubscribe :list-id:precedence:subject:to:mime-version:fcc:date:references :in-reply-to:message-id:from:dkim-signature:delivered-to; bh=wL1XOJRPMcK5O5M+w2JZyutSXUB8ihZN8Mz8KUIcvTM=; b=RFhjK2+r0cUTs0FVefIxmnI7iEJ33O16n0URN8Er3hID99r/Yfv+83tpfMuFNl5BM9 avUbTDCVtGm9J6FEc/5D760r17kr3MLoRCrvCux6XAJwLw9sJ9GQ6/frOcn28H7kDkEe VwMq8twiBnJMByBxkqifQresTD+ecmUOzTYt6zKhUgyrhC//8HZHkbnfV9HpEJO/uScn 15HMsUtL+EG9AispeJUvqBo1AUmP+aG/jVyzKfOzi9U1Xl1XI6chMvoYvuMmvhBR+6Wz 5YzhfrP1GEgfaPYp/BY+m7ERMXGXziwj3pcraEExuGJOFNdvYUKUJ4t5QvEbh4iV466o QFpA== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20210112 header.b=DSJjhDoC; 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=QUARANTINE 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 t12-20020a1709067c0c00b006fea05c0ccasi1482767ejo.680.2022.05.21.07.08.07; Sat, 21 May 2022 07:08:08 -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; dkim=neutral (body hash did not verify) header.i=@gmail.com header.s=20210112 header.b=DSJjhDoC; 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=QUARANTINE 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 803EB68B49D; Sat, 21 May 2022 17:07:54 +0300 (EEST) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail-pg1-f169.google.com (mail-pg1-f169.google.com [209.85.215.169]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id C74B968A2F6 for ; Sat, 21 May 2022 17:07:46 +0300 (EEST) Received: by mail-pg1-f169.google.com with SMTP id r71so10020299pgr.0 for ; Sat, 21 May 2022 07:07:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:message-id:in-reply-to:references:date:subject:fcc :content-transfer-encoding:mime-version:to:cc; bh=YG2Ueo0jW0GycGgy19XZ+62ItpaRuc1ZGAlGOPvDpaI=; b=DSJjhDoCgSCH9tNBPt5pusr5jJqhw5HmmZ4R2KjXDcfNVjyYfiHD0E+xMydA27w7Al R9HoiGX8kuaiufELXVcJwMQV0uCQVJkHzIOV6+BQWwEn+qS0kPNmxUuTXaK5DQrFZNJk bWhyX9xry2C5m1Ywhp4YKYdy+f9YMqxN15FX2mvZfIjm+90raU0B1qgW4pjwJFC7HMDU C+mbsXC0lNU9Rz29+23Od2mGXP0Ix4FJnPgjWCKqGVR2xZNbz368OZQa9N8ts4VESmZ8 syRKYyzyVfYeyuZMaVZgefTV8ZACFfSDHznryeRetLZfeBtypcLuBaxLxnS3kuNrjZg1 N4zg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:message-id:in-reply-to:references:date :subject:fcc:content-transfer-encoding:mime-version:to:cc; bh=YG2Ueo0jW0GycGgy19XZ+62ItpaRuc1ZGAlGOPvDpaI=; b=glbcjF9CFRqzSAEMNzPG14PCgznpCkOakrWMbitIaJa+Lb3fNGm/5gvdnyFMtJBElx h6xhV2zeuz0u8tNQSIA1fcBo6BvQDm83EWah1SsSYcuH0zggsnUr8vOpgYHBRBHOW4AM Snbujdk+qbXAKJnvvu4G0C/OXxDsBMp8reuBmyyaL/95VR8jlXvQcMi8hXc2EMjw3vOU 6Nb3IgG0yRoieqDtz2yTLUh0NRegN+ouzBT/orDdhhgBtsAL+2h5KEe07ueVNWA9g39p lpZXvExz55UYMFfrTM9/Ta92L7YPkTFU1BqjwAE+nD6ChmlVZW/EWN2sklv9jwTv6noj BJnQ== X-Gm-Message-State: AOAM5314rDnTEdmk5cF1Sh4dIegs98lpjrNa67/aCewpHR2T5ULK4lgb 9SPmCnH2rFRK8LW3rITKGzSenxcfYuwJTQ== X-Received: by 2002:a62:be14:0:b0:505:a43b:cf6e with SMTP id l20-20020a62be14000000b00505a43bcf6emr14945217pff.33.1653142065067; Sat, 21 May 2022 07:07:45 -0700 (PDT) Received: from [127.0.0.1] (master.gitmailbox.com. [34.83.118.50]) by smtp.gmail.com with ESMTPSA id 21-20020a170902c11500b0016173113c50sm1643120pli.92.2022.05.21.07.07.44 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Sat, 21 May 2022 07:07:44 -0700 (PDT) From: softworkz X-Google-Original-From: softworkz Message-Id: In-Reply-To: References: Date: Sat, 21 May 2022 14:07:39 +0000 Fcc: Sent MIME-Version: 1.0 To: ffmpeg-devel@ffmpeg.org Subject: [FFmpeg-devel] [PATCH v2 1/4] avutil/buffer: add av_ref_from_buffer() function 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 Cc: Mark Thompson , softworkz Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" X-TUID: 2LZsRedkStCb From: softworkz This allows to create AVBufferRef from AVBuffer directly. Signed-off-by: softworkz --- libavutil/buffer.c | 16 ++++++++++++++++ libavutil/buffer.h | 8 ++++++++ 2 files changed, 24 insertions(+) diff --git a/libavutil/buffer.c b/libavutil/buffer.c index 54590be566..f9df0ad6ea 100644 --- a/libavutil/buffer.c +++ b/libavutil/buffer.c @@ -100,6 +100,22 @@ AVBufferRef *av_buffer_allocz(size_t size) return ret; } +AVBufferRef *av_ref_from_buffer(AVBuffer *buf) +{ + AVBufferRef *ref = av_mallocz(sizeof(*ref)); + + if (!ref) + return NULL; + + ref->buffer = buf; + ref->data = buf->data; + ref->size = buf->size; + + atomic_fetch_add_explicit(&buf->refcount, 1, memory_order_relaxed); + + return ref; +} + AVBufferRef *av_buffer_ref(const AVBufferRef *buf) { AVBufferRef *ret = av_mallocz(sizeof(*ret)); diff --git a/libavutil/buffer.h b/libavutil/buffer.h index e1ef5b7f07..491734b9ca 100644 --- a/libavutil/buffer.h +++ b/libavutil/buffer.h @@ -139,6 +139,14 @@ AVBufferRef *av_buffer_create(uint8_t *data, size_t size, */ void av_buffer_default_free(void *opaque, uint8_t *data); +/** + * Create a new reference to an AVBuffer. + * + * @return a new AVBufferRef referring to the same AVBuffer as buf or NULL on + * failure. + */ +AVBufferRef *av_ref_from_buffer(AVBuffer *buf); + /** * Create a new reference to an AVBuffer. *