From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-17.3 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER,INCLUDES_PATCH,MAILING_LIST_MULTI,NICE_REPLY_A, SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 08ACEC433B4 for ; Tue, 20 Apr 2021 14:48:40 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 5510C611C9 for ; Tue, 20 Apr 2021 14:48:39 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 5510C611C9 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id BB2B16B006C; Tue, 20 Apr 2021 10:48:38 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id B620E6B006E; Tue, 20 Apr 2021 10:48:38 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 9B59F6B0070; Tue, 20 Apr 2021 10:48:38 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0086.hostedemail.com [216.40.44.86]) by kanga.kvack.org (Postfix) with ESMTP id 7C1656B006C for ; Tue, 20 Apr 2021 10:48:38 -0400 (EDT) Received: from smtpin28.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay03.hostedemail.com (Postfix) with ESMTP id 288538249980 for ; Tue, 20 Apr 2021 14:48:38 +0000 (UTC) X-FDA: 78053026716.28.2350793 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by imf21.hostedemail.com (Postfix) with ESMTP id 20EA1E000104 for ; Tue, 20 Apr 2021 14:48:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1618930117; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Z3pGrxDQTrsahWqPF4BATAsWy195XHZCR8bZtF3h1SQ=; b=QSL6rWkWfriMuBTMnAyWNK3oL+X+WG6ss1g5BnUp6xhJ3dnXgSP5A1VYXO+sdCjMkIdMpg 5sU++n23k5HAQAil/e0J+PVITxU5UTgKI2VIP/2PRTUYGlbY8m5AeV3wce01vG4duvfU7h WJ/qKvq+QguRmNfXc3Xdj34VKfBOQFk= Received: from mail-wm1-f71.google.com (mail-wm1-f71.google.com [209.85.128.71]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-120-7RYbEUUNMU20Ho8UdVYhlw-1; Tue, 20 Apr 2021 10:48:34 -0400 X-MC-Unique: 7RYbEUUNMU20Ho8UdVYhlw-1 Received: by mail-wm1-f71.google.com with SMTP id j123-20020a1c23810000b02901384b7122bcso911186wmj.6 for ; Tue, 20 Apr 2021 07:48:34 -0700 (PDT) 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:organization :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=Z3pGrxDQTrsahWqPF4BATAsWy195XHZCR8bZtF3h1SQ=; b=I4DHbulK/EbYQQpL6HX7mYNrGsyFD9XhiBagVH3W0nIQ6A2JL2sDKQDRxxWw+XQcBy iiKxsRmKie5IRSd/HBKGXBKRyGFP/3H65wXzTt17NolAo+7h33WGoAif/MPJB68sDUUO 3kyrkOUJQoJkult65m8PoEc4bzm83lNNNDEJNccRjZNJ1lwpOyXrKDegwdgzgpjNZW1X zZcwI7B9oYU4QeuReznfHVi8E8j4ovZNvQdOT2T8mtECTOcZrfSh+82l25bzjfLK2Z5D TuFhqOTsSt3tsDHiHRlEvSPYezopNacYmc5xqmnrgF4sUnX4xAL3vtzeQ0wpgZGKmPAE +7EQ== X-Gm-Message-State: AOAM532QVFaVU7X6zM6fjzFU+BIuvtrlQmEx4N94O56zRWjD3i3n9cuF otATTHV1KPyU/OHfUjJOt2qbIjG5IhgERWm7ANpALpFzom7j8moR4b8qdY5ZAB+Ys9BO1/I6qlT 5KP7xEpUZsgg= X-Received: by 2002:a1c:4045:: with SMTP id n66mr4768354wma.94.1618930113340; Tue, 20 Apr 2021 07:48:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwDFDQA67mvm5ZD4QmmSNpkuMV2HU0SQ4C2NsHoCUD5jbAOYnb9XnMmP/yrEe6VIwTuBA8ZZw== X-Received: by 2002:a1c:4045:: with SMTP id n66mr4768331wma.94.1618930113148; Tue, 20 Apr 2021 07:48:33 -0700 (PDT) Received: from [192.168.3.132] (p4ff2390a.dip0.t-ipconnect.de. [79.242.57.10]) by smtp.gmail.com with ESMTPSA id l14sm16944556wrv.94.2021.04.20.07.48.31 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 20 Apr 2021 07:48:32 -0700 (PDT) Subject: Re: [PATCH v5 3/3] kernel/resource: Fix locking in request_free_mem_region To: Alistair Popple , akpm@linux-foundation.org Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, daniel.vetter@ffwll.ch, dan.j.williams@intel.com, gregkh@linuxfoundation.org, jhubbard@nvidia.com, jglisse@redhat.com, bsingharora@gmail.com, smuchun@gmail.com References: <20210419070109.4780-1-apopple@nvidia.com> <20210419070109.4780-3-apopple@nvidia.com> From: David Hildenbrand Organization: Red Hat Message-ID: <9edc40ae-daf9-90ef-fac6-824b5ae00e30@redhat.com> Date: Tue, 20 Apr 2021 16:48:31 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: <20210419070109.4780-3-apopple@nvidia.com> Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=david@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Rspamd-Server: rspam01 X-Rspamd-Queue-Id: 20EA1E000104 X-Stat-Signature: zunytbu55r8gsh7q6156n9ih6goyqa1m Received-SPF: none (redhat.com>: No applicable sender policy available) receiver=imf21; identity=mailfrom; envelope-from=""; helo=us-smtp-delivery-124.mimecast.com; client-ip=170.10.133.124 X-HE-DKIM-Result: pass/pass X-HE-Tag: 1618930114-9889 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On 19.04.21 09:01, Alistair Popple wrote: > request_free_mem_region() is used to find an empty range of physical > addresses for hotplugging ZONE_DEVICE memory. It does this by iterating > over the range of possible addresses using region_intersects() to see if > the range is free before calling request_mem_region() to allocate the > region. > > However the resource_lock is dropped between these two calls meaning by the > time request_mem_region() is called in request_free_mem_region() another > thread may have already reserved the requested region. This results in > unexpected failures and a message in the kernel log from hitting this > condition: > > /* > * mm/hmm.c reserves physical addresses which then > * become unavailable to other users. Conflicts are > * not expected. Warn to aid debugging if encountered. > */ > if (conflict->desc == IORES_DESC_DEVICE_PRIVATE_MEMORY) { > pr_warn("Unaddressable device %s %pR conflicts with %pR", > conflict->name, conflict, res); > > These unexpected failures can be corrected by holding resource_lock across > the two calls. This also requires memory allocation to be performed prior > to taking the lock. > > Signed-off-by: Alistair Popple > --- > kernel/resource.c | 45 ++++++++++++++++++++++++++++++++++++++------- > 1 file changed, 38 insertions(+), 7 deletions(-) > > diff --git a/kernel/resource.c b/kernel/resource.c > index 75f8da722497..e8468e867495 100644 > --- a/kernel/resource.c > +++ b/kernel/resource.c > @@ -1801,25 +1801,56 @@ static struct resource *__request_free_mem_region(struct device *dev, > { > resource_size_t end, addr; > struct resource *res; > + struct region_devres *dr = NULL; > > size = ALIGN(size, 1UL << PA_SECTION_SHIFT); > end = min_t(unsigned long, base->end, (1UL << MAX_PHYSMEM_BITS) - 1); > addr = end - size + 1UL; > > + res = alloc_resource(GFP_KERNEL); > + if (!res) > + return ERR_PTR(-ENOMEM); > + > + if (dev) { > + dr = devres_alloc(devm_region_release, > + sizeof(struct region_devres), GFP_KERNEL); > + if (!dr) { > + free_resource(res); > + return ERR_PTR(-ENOMEM); > + } > + } > + > + write_lock(&resource_lock); > for (; addr > size && addr >= base->start; addr -= size) { > - if (region_intersects(addr, size, 0, IORES_DESC_NONE) != > + if (__region_intersects(addr, size, 0, IORES_DESC_NONE) != > REGION_DISJOINT) > continue; > > - if (dev) > - res = devm_request_mem_region(dev, addr, size, name); > - else > - res = request_mem_region(addr, size, name); > - if (!res) > - return ERR_PTR(-ENOMEM); > + if (!__request_region_locked(res, &iomem_resource, addr, size, > + name, 0)) > + break; > + > + if (dev) { > + dr->parent = &iomem_resource; > + dr->start = addr; > + dr->n = size; > + devres_add(dev, dr); > + } > + > res->desc = IORES_DESC_DEVICE_PRIVATE_MEMORY; > + write_unlock(&resource_lock); > + > + /* > + * A driver is claiming this region so revoke any mappings. > + */ > + revoke_iomem(res); > return res; > } > + write_unlock(&resource_lock); > + > + free_resource(res); > + if (dr) > + devres_free(dr); > > return ERR_PTR(-ERANGE); > } > LGTM Reviewed-by: David Hildenbrand -- Thanks, David / dhildenb