Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4376419imm; Wed, 30 May 2018 04:38:05 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJNC33/ohuehwgPtFBk9tldy1r9nk83SzIoKR8+14nMALZ5GJ3zO0ppFXUm99teL65xcWrx X-Received: by 2002:a17:902:683:: with SMTP id 3-v6mr2501268plh.291.1527680285525; Wed, 30 May 2018 04:38:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527680285; cv=none; d=google.com; s=arc-20160816; b=kq6nrDNsrxV1+kOxDMSRALg6aEH1TfXbC2sUmfpxd450zO8sl3rvIRVJNT5ZGrm6pg DkMwzTZPIWyepmBfzQpuYaoHivIm/KfF7D0vwwWYpcbPq2omkQBp+IlqvudCg+S34IsE /oQ92/TV6Z6pICvcpB0HbI+orfOZjB87OwOr/m6tuytIXI+aiWIV3YP+fX9oJ9AYslvB bX9+6/ZNgWhJ2jGQ2ZExNLDo3AUbdwddFhMVxSPXY2RTpM0L/wtCTIjrYATPMi9myESl PaJLXrB+eVblc5o/hVAYEz5jFknPPMQT9w/qi2UOhawsTprWSICeEkxnreDpMXaxuOdN I8pQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=Fb8HEu1/2+y2sXJupbL1vOHG3XNrYl1tBIuNpo/jXjY=; b=i0HuTtoO22ewGIdWiqKWJFqZTNNMkCcTEp8lYiE4muSVGoFPHgQ0sIBBkA4NmPr49S LICB2I/IcWlC4JtymZkxdIVBv/O/vD9xObQK/vL+3f9I8cIFqQPeeEQZfJcLvSPu6ZTv obOZl2U3yNpAgpZWBtQRzsVGvpce5Og4QFC8Hd4Sqlx7PKTF8kFGAAsDwrSuUDXI02xz hopbcBEBpOXs8RPHWTMkDvnbV1NRPHqbYsbYcqvBufhpwV23GBIDhZA965vg6TtRgn8M FLODaie805kg3T9NkZdYCGcTxGekVXUrWac/xJ60JtXX2IlvjXMAbQWfQsCUjUAAMBMx vfYQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=b3hJh8uv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w23-v6si18490831ply.563.2018.05.30.04.37.51; Wed, 30 May 2018 04:38:05 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=b3hJh8uv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752511AbeE3Lgz (ORCPT + 99 others); Wed, 30 May 2018 07:36:55 -0400 Received: from mail-lf0-f68.google.com ([209.85.215.68]:42217 "EHLO mail-lf0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751441AbeE3Lgq (ORCPT ); Wed, 30 May 2018 07:36:46 -0400 Received: by mail-lf0-f68.google.com with SMTP id v135-v6so3754001lfa.9; Wed, 30 May 2018 04:36:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=Fb8HEu1/2+y2sXJupbL1vOHG3XNrYl1tBIuNpo/jXjY=; b=b3hJh8uv02T9YIZifKdXnWCVAvdOYoP3Wkl0dhZqk4rlmD/nbQo7LfHsGK490p9/Xd 0n4T1JahX2TwdImAqD6zrXPjc/CCiLsHChaoDr7wooHS9cs8aDgloJpt7Tyqr22k5JPn cAv6jno2UHCK+bT9v6EvLH18Rs8Qt2eTuPDRfdjHtkAz81RElwdJlpqHcc+oQgFvtHBX IDr5VnTstIOrRFFXRBchhtJGSrS93rvDXNZJfc9YPgh+g4iY0G9QCtpOind26PsKTpQy hxerMuSuyMHhxToBzQjn29APOQ8+47RIFDJbsFzAm0n+qo4+jTQPWZ3Avj3UChw7BUnL T6/g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=Fb8HEu1/2+y2sXJupbL1vOHG3XNrYl1tBIuNpo/jXjY=; b=D1gid8tUKoLXpY7hNm6ZCq+tHZhm2rovdmj6LEmzaYaLtiyE1vaw8P5eN04ZID4fKN bXHTet2moG4RW0aGVVb87YB0eTDUgwGa60PdGczjDbaE/yC8pYGnfvJbzGGtmRGPwlV/ y6e64WTc5OnXNq7CAjI7+OxSAw/BKJ6gDTPXUAEAIY5mPcPvuG9DNJw1HIpkoYbFLJRT Sw+mWHihn5qPUyNqEGWl468AXiyoPi92IilFLbqvyD7NWEQqsrIl/N8z2qSx7GmqTzKH ueNMf2E9qDYsOiBHsPE98gbWn2zE6dFc0wJdtGOYuBBIdOnF+qAR2oQPmcPdKgchyS6Y OeRg== X-Gm-Message-State: ALKqPwdp0LGfmHRNU/4YEc4SH4aijpD59nDEzxeRXFkutBkYy+2NvIFc WRM9O+Vi4Vw7sZ+beo48rV7+Vp3AoUs= X-Received: by 2002:a19:4355:: with SMTP id m21-v6mr1556417lfj.121.1527680204984; Wed, 30 May 2018 04:36:44 -0700 (PDT) Received: from [10.17.182.9] (ll-59.209.223.85.sovam.net.ua. [85.223.209.59]) by smtp.gmail.com with ESMTPSA id s18-v6sm1341174lfc.22.2018.05.30.04.36.43 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 30 May 2018 04:36:44 -0700 (PDT) Subject: Re: [PATCH] dma-buf: make map_atomic and map function pointers optional To: Gerd Hoffmann , dri-devel@lists.freedesktop.org Cc: open list , "moderated list:DMA BUFFER SHARING FRAMEWORK" , "open list:DMA BUFFER SHARING FRAMEWORK" References: <20180529135918.19729-1-kraxel@redhat.com> From: Oleksandr Andrushchenko Message-ID: Date: Wed, 30 May 2018 14:36:43 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <20180529135918.19729-1-kraxel@redhat.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/29/2018 04:59 PM, Gerd Hoffmann wrote: > So drivers don't need dummy functions just returning NULL. > > Cc: Daniel Vetter > Signed-off-by: Gerd Hoffmann > --- > include/linux/dma-buf.h | 4 ++-- > drivers/dma-buf/dma-buf.c | 4 ++++ > 2 files changed, 6 insertions(+), 2 deletions(-) > > diff --git a/include/linux/dma-buf.h b/include/linux/dma-buf.h > index 085db2fee2..88917fa796 100644 > --- a/include/linux/dma-buf.h > +++ b/include/linux/dma-buf.h > @@ -39,12 +39,12 @@ struct dma_buf_attachment; > > /** > * struct dma_buf_ops - operations possible on struct dma_buf > - * @map_atomic: maps a page from the buffer into kernel address > + * @map_atomic: [optional] maps a page from the buffer into kernel address > * space, users may not block until the subsequent unmap call. > * This callback must not sleep. > * @unmap_atomic: [optional] unmaps a atomically mapped page from the buffer. > * This Callback must not sleep. > - * @map: maps a page from the buffer into kernel address space. > + * @map: [optional] maps a page from the buffer into kernel address space. > * @unmap: [optional] unmaps a page from the buffer. > * @vmap: [optional] creates a virtual mapping for the buffer into kernel > * address space. Same restrictions as for vmap and friends apply. > diff --git a/drivers/dma-buf/dma-buf.c b/drivers/dma-buf/dma-buf.c > index d78d5fc173..4c45e31258 100644 > --- a/drivers/dma-buf/dma-buf.c > +++ b/drivers/dma-buf/dma-buf.c > @@ -872,6 +872,8 @@ void *dma_buf_kmap_atomic(struct dma_buf *dmabuf, unsigned long page_num) > { > WARN_ON(!dmabuf); > > + if (!dmabuf->ops->map_atomic) > + return NULL; > return dmabuf->ops->map_atomic(dmabuf, page_num); > } > EXPORT_SYMBOL_GPL(dma_buf_kmap_atomic); > @@ -907,6 +909,8 @@ void *dma_buf_kmap(struct dma_buf *dmabuf, unsigned long page_num) > { > WARN_ON(!dmabuf); > > + if (!dmabuf->ops->map) > + return NULL; > return dmabuf->ops->map(dmabuf, page_num); > } > EXPORT_SYMBOL_GPL(dma_buf_kmap); Reviewed-by: Oleksandr Andrushchenko