Received: by 2002:a25:b794:0:0:0:0:0 with SMTP id n20csp6207810ybh; Wed, 7 Aug 2019 19:31:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqw5xwV47grdf5sMrFOGOsInYiWwqmP/Oke3w5WwtgpzUfpIsNPWK8dmxLCOo3S3D8kUPTe1 X-Received: by 2002:a17:90a:bf92:: with SMTP id d18mr1564359pjs.128.1565231515180; Wed, 07 Aug 2019 19:31:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565231515; cv=none; d=google.com; s=arc-20160816; b=KBGVEsZRhjEpzq71NyGMLraLI9cNln+6bkwkoqyC/EP/ptghWqBMBsrd2csN/MHgbZ mw8PvMO4eSQSI9EwzDGbNzBYBxDs5TX37hRord6kRrZ5st5FIcA9ZXMotdCyTV2ohttB NWcZKjp/41yKjmut42ouEZAOmUuGG8kcUZY/I3fM/g3Mq9dVV3+3cZhrlQ8G7vPo1BWv aFZQV/FogpjZ4E1p6AGMYAvxRZOaHYzSVABL/jc1+hfvsfF5EDtY0mjxZiJxZ62wSGkT UGh0wPj3zjizkSCfSJWXf5XFsalcv18OSB0PwCzYsNqm0KA9wR5jyNfCEw/UaNe1BONk 0ayQ== 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:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=911lJLOrOi7YW+Y8y2OrYwA8FJ9lIeonGQ2EsA8/ctM=; b=U5mmxFYrUY0kw22QZ/jJwp/5oeafSKjK/1Ct1ssOhVJoj+hzyZRvOoAdVc93z/gTNK /RDPRxd025de/Kih0W8ioxHvQOb493aKXagMCvITs46SFW5YmqMg3oRJylz0J027ELyr +KW/zw4gzdwCFtnsUR87NxzFB13VOEdG9TGvU3Dx5kW7k/fo+GqcmpTUiTnBg98LRRjL f+k2To5mI+B6UMwybUXeC4EUDXpP8frVmM+F2tE1raQSTaQf8S7tc8QUV88F9gKHj/DY pwJQ3vlJx11HfGzQDOUNDj2xoCOxAGdDRo9jXSPnejN3pP2znvWkTL/j23cC3SVZ5mj0 WkUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@android.com header.s=20161025 header.b=KZrwUnP8; 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=REJECT sp=REJECT dis=NONE) header.from=android.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i8si13654372pfr.97.2019.08.07.19.31.39; Wed, 07 Aug 2019 19:31:55 -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=@android.com header.s=20161025 header.b=KZrwUnP8; 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=REJECT sp=REJECT dis=NONE) header.from=android.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728120AbfHHC3G (ORCPT + 99 others); Wed, 7 Aug 2019 22:29:06 -0400 Received: from mail-wr1-f65.google.com ([209.85.221.65]:45438 "EHLO mail-wr1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727984AbfHHC3F (ORCPT ); Wed, 7 Aug 2019 22:29:05 -0400 Received: by mail-wr1-f65.google.com with SMTP id q12so3009234wrj.12 for ; Wed, 07 Aug 2019 19:29:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=android.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=911lJLOrOi7YW+Y8y2OrYwA8FJ9lIeonGQ2EsA8/ctM=; b=KZrwUnP8ndpdYJoxGXHvYDyIRBxN0j7v3Tc5YDqCdqauYvPvw86OG7o/le+VPI3UAz vbo0c36MSNpisepoRR7UlD0Rzh/1khg/DARvkiMppaVMsvD4DKb39c1I7XtjYuNwo15c UHkfSJSKfw0XezcK5Rj0vm0l/Zu16XqB51l6szL8tl5lCXyozb0QJF9n7jZcvAqFNrzk J5NJQ/CGBJbH37jAxr10rYY7n9MCa1zY/t7MsTR179evalypUAIPBNH8c4xCxSXZf/i7 MhFojdt+h54C7/5f0ahEX7kyyP0jVop/EJ4lsMOwVawPXJZsbJY834dI2Mgke8nRrsDU ZCPQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=911lJLOrOi7YW+Y8y2OrYwA8FJ9lIeonGQ2EsA8/ctM=; b=AmiApxqYe364QJPfvDIYXuXWm7TwSTumgSTfvjLaQARm9aILcZ+nDaHipTnbJ9rH03 eCNRJzJFKdI2HyAxCsn3xQpKw82ry5Mo5J/w+KznzP6PNOd9ci0BaFTqJ0eWROMWMWyj k0hplhOVgaVwlvFEiaoDTtQuPhDB38TBcN2gt7mTpuPYDEfigcMFfmtxcr+i7LbiOM1i vHo0Ob2mg5PjLAiDcTESfue7OybHAu2H7ABgHX/IcHwRJkYWKpzbHn1ZXALGbAw1HXYM cmCYoknlCtcyFPid2rMXI0Nhpbch2lfz12o4hkhwx/PNgh4wxE7SLAVTFQyajQxsCWil /y3g== X-Gm-Message-State: APjAAAUpV0zYEHqoUMuJ3TiKRMvB/8A/XNYBb3jkxgbihJln0EWGtlBu pb6QhhN0y/oTShkGu4FUvauoXg== X-Received: by 2002:a05:6000:1148:: with SMTP id d8mr12498744wrx.354.1565231343427; Wed, 07 Aug 2019 19:29:03 -0700 (PDT) Received: from balsini.lon.corp.google.com ([2a00:79e0:d:210:e751:37a0:1e95:e65d]) by smtp.gmail.com with ESMTPSA id j189sm953362wmb.48.2019.08.07.19.29.02 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Wed, 07 Aug 2019 19:29:02 -0700 (PDT) From: Alessio Balsini To: gregkh@linuxfoundation.org Cc: stable@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-team@android.com, xiao jin , Ming Lei , Bart Van Assche , Jens Axboe , Alessio Balsini Subject: [PATCH 3.18.y 4.4.y 4.9.y] block: blk_init_allocated_queue() set q->fq as NULL in the fail case Date: Thu, 8 Aug 2019 03:28:19 +0100 Message-Id: <20190808022819.108337-1-balsini@android.com> X-Mailer: git-send-email 2.23.0.rc1.153.gdeed80330f-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: xiao jin commit 54648cf1ec2d7f4b6a71767799c45676a138ca24 upstream. We find the memory use-after-free issue in __blk_drain_queue() on the kernel 4.14. After read the latest kernel 4.18-rc6 we think it has the same problem. Memory is allocated for q->fq in the blk_init_allocated_queue(). If the elevator init function called with error return, it will run into the fail case to free the q->fq. Then the __blk_drain_queue() uses the same memory after the free of the q->fq, it will lead to the unpredictable event. The patch is to set q->fq as NULL in the fail case of blk_init_allocated_queue(). Fixes: commit 7c94e1c157a2 ("block: introduce blk_flush_queue to drive flush machinery") Cc: Reviewed-by: Ming Lei Reviewed-by: Bart Van Assche Signed-off-by: xiao jin Signed-off-by: Jens Axboe Signed-off-by: Alessio Balsini --- block/blk-core.c | 1 + 1 file changed, 1 insertion(+) diff --git a/block/blk-core.c b/block/blk-core.c index 50d77c90070d..7662f97dded6 100644 --- a/block/blk-core.c +++ b/block/blk-core.c @@ -870,6 +870,7 @@ blk_init_allocated_queue(struct request_queue *q, request_fn_proc *rfn, fail: blk_free_flush_queue(q->fq); + q->fq = NULL; return NULL; } EXPORT_SYMBOL(blk_init_allocated_queue); -- 2.22.0.770.g0f2c4a37fd-goog