Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp918406pxb; Wed, 29 Sep 2021 12:29:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzkE3khORaG+dRt0Thsr9l2LU27Xy8P5XZrOX7R/4WpdZBerFjXBWiP4RnF9DZb+SBRbPuE X-Received: by 2002:a17:906:a0e:: with SMTP id w14mr1873591ejf.106.1632943763706; Wed, 29 Sep 2021 12:29:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632943763; cv=none; d=google.com; s=arc-20160816; b=EqqHrs6SEZJN/ZOkdbeUX1eRrp7JotGfnG7I5arJXM6yBD7Jx9SruTkO8ZzLJpQxe0 tJhQ/GGGbe9IeHZ41Z5ecIyH24CTx++Ycxw3tsfqctcDDZGX9X54+a074/FxWqfGkHU1 JTj6ebAByb6SXBcaNy3gXK7AixHgj8WBx79t+Jj1kgvCjZRhHa3Mgn/5sAdxkYG5q1iZ SSWg8Q9wgOSuq5a9AH15DQb2OlZsmiHt+O7hyFFLF1OeCrXpb5RW71Rmz/BJqeGBG9yC SQ3exaIboovEgHKrr1JRdOulW+BVQvqFOF54GFQ1nDEqVzXXfzYuomP8J+teYHq2ZH8J Pi5Q== 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=n8HsfV7RFQWoa5/TFlxFufaedtFCNha3XC2H4rDNQEw=; b=Q6FFhh2j3znNy1YFY2ReJ5/AzNf/AZUxJv859LIp8N3w1EkpEmyNB8Q/LtvS6PDBv3 3PDkP6cNBU9Ac23Ko0KwqRTT1KDnEeLalzWaU8t2jIUjRcKVe9aedGDqsDQO8C8xCp3L NV+j5F+iDKCpDXFqr8gavRI77g4PkAoWW/tiJMoTrQbfHRau+BaOGqkkAENjoNwS4/fT +80fTcmPqNzYtSZXyERKoVKsEnKyMVlU9/njyZsrgxoWpoe7lyDCtuLjbv6Jp12xmQaK 4wZ0m1G3Oks2on4MxU/C69fYhlZpxQ0CkMyh4ydvHmtCVEUBgLhsOpy9SLSGzlfUia4D 2RuA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=dTMB3JlF; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m7si949474ejn.649.2021.09.29.12.28.58; Wed, 29 Sep 2021 12:29:23 -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=@gmail.com header.s=20210112 header.b=dTMB3JlF; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344700AbhI2Rgw (ORCPT + 99 others); Wed, 29 Sep 2021 13:36:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58888 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244721AbhI2Rgv (ORCPT ); Wed, 29 Sep 2021 13:36:51 -0400 Received: from mail-wm1-x329.google.com (mail-wm1-x329.google.com [IPv6:2a00:1450:4864:20::329]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 69B20C06161C; Wed, 29 Sep 2021 10:35:10 -0700 (PDT) Received: by mail-wm1-x329.google.com with SMTP id j27so2487068wms.0; Wed, 29 Sep 2021 10:35:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=n8HsfV7RFQWoa5/TFlxFufaedtFCNha3XC2H4rDNQEw=; b=dTMB3JlFoZDI53nuVwIENnq/dXA5ultZwJbnG/iLS1y3AHpEsc82O4yU1r4gKIQ3tg Lur+dstLEbIcEeBTv7Hvj78kVY1OO7KnWrhDqwZCNbpVg265sGX8K6cgEAe6lP+QEjnB ftY1I6YclRwDcbRuiL1vD4BZa3QWUgYapW8EsawKzdndVOavplv78DVU6rnTG63tqrVt fRPMd7cqJO6fuVp5UpwLGfvJtmuib68fBTHA6r0iWEj4crfz6eEOvuqH31B8xbwamUiu l6sDMMr0lDCqp6cRYxacKYaaWyBxt67plFSGZEHW73rzT0EHPrtO+YSVo/syngnV56uj yqwQ== 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=n8HsfV7RFQWoa5/TFlxFufaedtFCNha3XC2H4rDNQEw=; b=Gy5xwbyGRkURPSbiok6us1at+sblxA+hxR3JcYSWDfqi4lyZFJbcVTGHRWjfxsvRBb 9FQ0EY0/aaXTgXdsRdTJL8tq2JwmziYMwBD+iHvtmdBSPQVLjE5ruWPISb1JI03tmp3N 2MuG9rZ4mvrqk1hJIWcznDLvN9fBACq3kgM/4K1jJ9CqcPshNZTw07ScVOhF5ReW4BB/ 43qbe3dxFGHjpuABp1wOo8DK5lqRHCSMjP1dcgrFYbPgBRzPuKAiGs43i1cMyv+iJ9Pf +hCUzVxSQVaS4188o0Wmm4uiAim8YrRMbigROMyVDnBwrb7FqV0sjM2yPmvPN5YEEjz8 Ehnw== X-Gm-Message-State: AOAM531hw2W2RDXzNRTLvnPPOzy+q8nHebrReVq6wSLSoQmqboixx8v6 IuPe7SsYt2vRJVqjks1GYNtz0CMEMa4= X-Received: by 2002:a1c:a94a:: with SMTP id s71mr11527424wme.32.1632936908571; Wed, 29 Sep 2021 10:35:08 -0700 (PDT) Received: from [192.168.178.40] (ipbcc061e7.dynamic.kabel-deutschland.de. [188.192.97.231]) by smtp.gmail.com with ESMTPSA id u2sm512802wrr.35.2021.09.29.10.35.08 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 29 Sep 2021 10:35:08 -0700 (PDT) Subject: Re: [PATCH][next] scsi: target: tcmu: Use struct_size() helper in kmalloc() To: "Gustavo A. R. Silva" , "Martin K. Petersen" Cc: linux-scsi@vger.kernel.org, target-devel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-hardening@vger.kernel.org References: <20210927224344.GA190701@embeddedor> From: Bodo Stroesser Message-ID: <289a7052-7062-ce88-7cbd-dd29f23b4c60@gmail.com> Date: Wed, 29 Sep 2021 19:35:07 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <20210927224344.GA190701@embeddedor> 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 28.09.21 00:43, Gustavo A. R. Silva wrote: > Make use of the struct_size() helper instead of an open-coded version, > in order to avoid any potential type mistakes or integer overflows > that, in the worst scenario, could lead to heap overflows. > > Link: https://github.com/KSPP/linux/issues/160 > Signed-off-by: Gustavo A. R. Silva > --- > drivers/target/target_core_user.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/drivers/target/target_core_user.c b/drivers/target/target_core_user.c > index 9f552f48084c..dc220fad06fa 100644 > --- a/drivers/target/target_core_user.c > +++ b/drivers/target/target_core_user.c > @@ -1255,7 +1255,6 @@ tcmu_tmr_notify(struct se_device *se_dev, enum tcm_tmreq_table tmf, > { > int i = 0, cmd_cnt = 0; > bool unqueued = false; > - uint16_t *cmd_ids = NULL; > struct tcmu_cmd *cmd; > struct se_cmd *se_cmd; > struct tcmu_tmr *tmr; > @@ -1292,7 +1291,7 @@ tcmu_tmr_notify(struct se_device *se_dev, enum tcm_tmreq_table tmf, > pr_debug("TMR event %d on dev %s, aborted cmds %d, afflicted cmd_ids %d\n", > tcmu_tmr_type(tmf), udev->name, i, cmd_cnt); > > - tmr = kmalloc(sizeof(*tmr) + cmd_cnt * sizeof(*cmd_ids), GFP_NOIO); > + tmr = kmalloc(struct_size(tmr, tmr_cmd_ids, cmd_cnt), GFP_NOIO); > if (!tmr) > goto unlock; > > Looks good. Thank you. Reviewed-by: Bodo Stroesser