Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp6081482ybf; Thu, 5 Mar 2020 12:44:11 -0800 (PST) X-Google-Smtp-Source: ADFU+vtYcT5hmWVvVTq13gNFm3nwPa1BcFfBujzJRoXENvlGLtydZOh3ORcttQdOQ+IkRBFSXXvJ X-Received: by 2002:a05:6830:616:: with SMTP id w22mr254914oti.215.1583441051568; Thu, 05 Mar 2020 12:44:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583441051; cv=none; d=google.com; s=arc-20160816; b=agM8PnyGnlYxrQu7Sod0dBJNu1Vb9xd/W1YhO5bw2eDWPXqDHZyuZLz4zNdvh+Wvv9 brWzn2zqsZHjOmiES32INHWUlkT2lFkRwqKSFOUKbjjGuAsoNc2jkV8ckEmyUZyhc8MR UkyCRluOmS70S9i8QoUXURv7ArkQw3zOgOxKEMejyKlpNgjwKPf9784l3Z+DCxKgFROF HkeLteI9MPubXc94IfAe83gs25kZOwEx7oSX9UjSXZnBHLzmg5bNd7qKptkC12B3O93g NnN85ICZwgKTCHCROWdqTCnQJTnpsXWxzELRmv7kppJQ3aCBuicQFuo4T02g1zn4ao9H RXlg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=K+E8Uy+fBw/gh0nu1wLPFsLlAAWTt9S6/ny9LuQwDCk=; b=qYYGe17n8pVjXIXXUqVaFaIxMf7/yi92yznPV5J1y+NKbVuraWzv5XJsjE7QAp09Gh 3T5wj0IVnoeT4XGyaMS5L31EupGhR09vueS0OihYJpfDfuSB7z6DaHwZ+sdr6jx9ZKaI 01EmTtk0xNwHNnAxoGL6jAUJq1Le1Rsekz+Febb1lWmmFUX+kSbIH0VRUeqQheqRoxcp JGehIhv4bWG47OnjehUZzjx7sV9eYRouiN8Au3Xug26RwzHDrty4Ncg7GGuWwVbZLlur 57VbqnCuzn6EUmQM5ES5/R8W4okbOot0/Pte4h5IPRCO+GXnZsLsTmU20jy1pZFHLNpN XJUw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=QO00FYAP; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c7si31957oto.105.2020.03.05.12.43.58; Thu, 05 Mar 2020 12:44:11 -0800 (PST) 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=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=QO00FYAP; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726128AbgCEUnI (ORCPT + 99 others); Thu, 5 Mar 2020 15:43:08 -0500 Received: from mail-io1-f68.google.com ([209.85.166.68]:41331 "EHLO mail-io1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726080AbgCEUnH (ORCPT ); Thu, 5 Mar 2020 15:43:07 -0500 Received: by mail-io1-f68.google.com with SMTP id m25so7950081ioo.8 for ; Thu, 05 Mar 2020 12:43:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=K+E8Uy+fBw/gh0nu1wLPFsLlAAWTt9S6/ny9LuQwDCk=; b=QO00FYAP80gFlnAl/2izdrLs57u2D9HT6jeMy2jT8IJZ00MvsCRpYMrR8GU7doHvUI 6eTb+gVBX2QOOZOZE6/JRJOsscpRzWVzHoz5rbfegXEmZFRBLrs535y23DRBwzYpzKRs yYISl+wAUCrtJHIv1OArKmUbI6XKyFB0hK4WqTeLu5SAdChBAk4eLwCN5E9Hq/1B96SE aX4nzpp1eL0MeuF3Xxlufcvnn2Cz+opeQ61syEiQ9bsHv0LcNsJjSniFOxUF+kiarlpH dp6RgdLzUypkBgWAfDoqyehybF1hN2UowVmdvdwQdP9/1lqSk2YqiAaOecvpB7MqHSYQ 5oig== 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-language :content-transfer-encoding; bh=K+E8Uy+fBw/gh0nu1wLPFsLlAAWTt9S6/ny9LuQwDCk=; b=me6MHlM/85dGTQlWOF4m9ZpJZduNYmrEXhNLrzXAIuIoqgCyU3VStPUAxiMypblMiw 2IusTgNNNckvGSdfAjJOO7yDSxlNhj4IBIzoo73MuYylDqR4gTc/pFJRF7lRWOC3T19D sZCbQRPkUTdDTStvrHHPeglfaQ8690VGokeB9jD1yjAKjXj4aS68+OGb2am/hF9gAa/4 5j0Rh+Gc83nzf+65bd7HepUzv0LbMCjY0OF1n3KFI9fD69pUFzqJJoKYHwqhUjBLOPfO xFvz23TsGCEwW4Uyaix5v84jJAq0lMewbu4S5KNvn3Ks5p1/zU3ELvTlizeVJcTed6dC JZ4Q== X-Gm-Message-State: ANhLgQ1QMV5bnp8erGvAq5sMHSDkerc+dAGVD0h5tPJS5+lw2EbsrW54 pIISwQGzI3zRoIz6ssxAw5KgaGhN3aQ= X-Received: by 2002:a6b:7f01:: with SMTP id l1mr208223ioq.146.1583440986476; Thu, 05 Mar 2020 12:43:06 -0800 (PST) Received: from [192.168.1.159] ([65.144.74.34]) by smtp.gmail.com with ESMTPSA id g3sm1074323ilb.53.2020.03.05.12.43.05 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 05 Mar 2020 12:43:05 -0800 (PST) Subject: Re: [PATCH v2] blktrace: fix dereference after null check To: Cengiz Can , Steven Rostedt , Ingo Molnar Cc: linux-block@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200304105818.11781-1-cengiz@kernel.wtf> From: Jens Axboe Message-ID: Date: Thu, 5 Mar 2020 13:43:04 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <20200304105818.11781-1-cengiz@kernel.wtf> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/4/20 3:58 AM, Cengiz Can wrote: > There was a recent change in blktrace.c that added a RCU protection to > `q->blk_trace` in order to fix a use-after-free issue during access. > > However the change missed an edge case that can lead to dereferencing of > `bt` pointer even when it's NULL: > > Coverity static analyzer marked this as a FORWARD_NULL issue with CID > 1460458. > > ``` > /kernel/trace/blktrace.c: 1904 in sysfs_blk_trace_attr_store() > 1898 ret = 0; > 1899 if (bt == NULL) > 1900 ret = blk_trace_setup_queue(q, bdev); > 1901 > 1902 if (ret == 0) { > 1903 if (attr == &dev_attr_act_mask) >>>> CID 1460458: Null pointer dereferences (FORWARD_NULL) >>>> Dereferencing null pointer "bt". > 1904 bt->act_mask = value; > 1905 else if (attr == &dev_attr_pid) > 1906 bt->pid = value; > 1907 else if (attr == &dev_attr_start_lba) > 1908 bt->start_lba = value; > 1909 else if (attr == &dev_attr_end_lba) > ``` > > Added a reassignment with RCU annotation to fix the issue. Applied, thanks. -- Jens Axboe