Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp720073pxb; Wed, 6 Oct 2021 14:00:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxCvO7EnwIJzRH086y3kMD/i+TjcUvAfO/PH2+VsIvJh/WwoaYtTtPyTnOR2NdVTxHw/WFb X-Received: by 2002:a17:906:a20a:: with SMTP id r10mr11896ejy.412.1633554032362; Wed, 06 Oct 2021 14:00:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633554032; cv=none; d=google.com; s=arc-20160816; b=OplgYIX4hdINQSLndeOT9Q0Im9U4HE0Xse8o/5f+S1qp/Lmw6eBYEsCdaR25cg6Rmu gsqFuXRb5oAg6ool0pgYtioRoMleumJrF3vxbeLekbHGqwxku3T8xtAi0mZX5L6Rq5+I /NzwAG8I0Tt+LL5ZEy4v0I6aTQWqKMAlXv3JBqg6AiTI7nF9DaVPCnTr3RIDH2INHtSU I/OSYWVxLA3239dr6bjB8d/AJyc1q5RCVzwLvqOetFAb4zpgqmSDkY1F6t3GNfhHtq1y aBxqrXCCu6nZpWcKJykIWKVWCVV/eo0ZGpSFeLUsL7Ghy9BJ/ga0BGt2qKDTODgs66K1 G60w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=JvTa2lKBoI8pDHEiWBkxH9Br7TgFSzn7gNvMea8puyE=; b=B8wXj0nzQMLLC+u7aajKsLMifjZkC8Z0m7JPnI8nP5ofbsfDIy3ffg5w993ltBfVMD 0Yh2toFVx5wU25ZRCuu73+WbGFYIjHEX4k3nVjRiFtYMhFOJmiRp7A/8ZCTHDnCaoEHY n+5c2Cb2vfSAObD/uSO80xj1o6vXhFRfVDF32E1vGWrbgd/YEFV4ZfcArdsnkOjdVFnG IK8tGGj8udM31H0yTrwd2X7I51GoKo9LvhdK212ktvYlTEVs+DZMVOotl0DGcTKHd4uV ThX+7nmOMYFVrlvanFQyv7aLNGpnw9GMiL8ZO53ZUmdDZV+JGTpOPU6VqNvBFWchUVhu 4Ksw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=GHKG4f+J; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b1si17033913edw.225.2021.10.06.14.00.07; Wed, 06 Oct 2021 14:00:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=google header.b=GHKG4f+J; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239506AbhJFU5c (ORCPT + 99 others); Wed, 6 Oct 2021 16:57:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43530 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230043AbhJFU5b (ORCPT ); Wed, 6 Oct 2021 16:57:31 -0400 Received: from mail-oi1-x234.google.com (mail-oi1-x234.google.com [IPv6:2607:f8b0:4864:20::234]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CC786C061746 for ; Wed, 6 Oct 2021 13:55:38 -0700 (PDT) Received: by mail-oi1-x234.google.com with SMTP id n64so5932862oih.2 for ; Wed, 06 Oct 2021 13:55:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxfoundation.org; s=google; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=JvTa2lKBoI8pDHEiWBkxH9Br7TgFSzn7gNvMea8puyE=; b=GHKG4f+JDyBw783UV6ULROcl/lb/K5rec7Me193E2Cz3VdjF9s4lYC1jmlGbFMV1Nt Qq6Nn8d/3JKLDPjKiNUH/GLZLpRUhAXzPss6G1JN3VH7S7eweRd1sxuXWNxZD315d7EN PFyIb5ARTlTUSievJPL7tj4LJ4ydtt1xbLyzs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=JvTa2lKBoI8pDHEiWBkxH9Br7TgFSzn7gNvMea8puyE=; b=cz7nahp8Hx37qGfEW+0GzMQTInNmVWlmIIGR/c/EqtlPo31zNmfgagQs3BRSZN5Jya ef4ZTgP6G3AoGaAUji15+S+M6/wD9OMteWX1olBxhX0QLeNlltuN/ayeKsieQj9aei5A f5Bjtja7/ce+SbGR8WipJ55y0c4ukQXgW+MK8JtPtnyENZRdHOhNjmkB901HMusBcADQ kRN1STst4brx/9+GDLt6PnYn5hxL3mPry95D6mMGuAVzPV9OnRb+qjFXmInXX+cmkWvW 1wyMn6R15SuHVSutsHo+XVaWmrvfTt6rI5snqVN/VxSVKHigvZuEEz7kaYFPWt/d5GHm ZgaQ== X-Gm-Message-State: AOAM533ebvDN9Ns2NHUowzKhibpWqJsoHyjrn9ekzIKsYy2B6ivUHdjS U3Grpk4+nRVfkUdA+4JIvneBVA== X-Received: by 2002:aca:dbc2:: with SMTP id s185mr305618oig.141.1633553738147; Wed, 06 Oct 2021 13:55:38 -0700 (PDT) Received: from [192.168.1.112] (c-24-9-64-241.hsd1.co.comcast.net. [24.9.64.241]) by smtp.gmail.com with ESMTPSA id l1sm3351258oop.28.2021.10.06.13.55.37 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 06 Oct 2021 13:55:37 -0700 (PDT) Subject: Re: dm: change dm_get_target_type() to check for module load error To: Mike Snitzer Cc: agk@redhat.com, dm-devel@redhat.com, linux-kernel@vger.kernel.org, Shuah Khan References: <20211004200641.378496-1-skhan@linuxfoundation.org> From: Shuah Khan Message-ID: Date: Wed, 6 Oct 2021 14:55:36 -0600 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: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/6/21 2:35 PM, Mike Snitzer wrote: > On Mon, Oct 04 2021 at 4:06P -0400, > Shuah Khan wrote: > >> dm_get_target_type() doesn't check error return from request_module(). >> Change to check for error and return NULL instead of trying to get >> target type again which would fail. >> >> Signed-off-by: Shuah Khan >> --- >> drivers/md/dm-target.c | 11 ++++++++--- >> 1 file changed, 8 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/md/dm-target.c b/drivers/md/dm-target.c >> index 64dd0b34fcf4..0789e9f91d3a 100644 >> --- a/drivers/md/dm-target.c >> +++ b/drivers/md/dm-target.c >> @@ -41,17 +41,22 @@ static struct target_type *get_target_type(const char *name) >> return tt; >> } >> >> -static void load_module(const char *name) >> +static int load_module(const char *name) >> { >> - request_module("dm-%s", name); >> + return request_module("dm-%s", name); >> } >> >> struct target_type *dm_get_target_type(const char *name) >> { >> struct target_type *tt = get_target_type(name); >> + int ret; >> >> if (!tt) { >> - load_module(name); >> + ret = load_module(name); >> + if (ret < 0) { >> + pr_err("Module %s load failed %d\n", name, ret); >> + return NULL; >> + } >> tt = get_target_type(name); >> } >> >> -- >> 2.30.2 >> > > While I appreciate your intent, the reality is that multiple targets > may be made available in a given module. And so loading one dm module > may bring in access to N targets. There isn't a rigid 1:1 mapping of > target modules to names. And there may not even be a loadable module > that has the name dm-${name} -- but that doesn't mean the target_type > won;t have been loaded into DM for it to access. > Thanks for the explanation. -- Shuah