Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp686986pxu; Fri, 11 Dec 2020 11:43:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJwvQzPNyG3f0sNXWJcwPmeCS8FTSYFxGeJ/zr30BBVyUfxMxQraJKFnhzuj8yC8XiIFaWgu X-Received: by 2002:a17:906:d8dc:: with SMTP id re28mr12486625ejb.168.1607715817282; Fri, 11 Dec 2020 11:43:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607715817; cv=none; d=google.com; s=arc-20160816; b=Z0Ah+V3sNBUKh675EAOrODXiEQ8RkbZwqptG9IDZfTQdDSlQOkafCl1jT/5FG/qSOH FVxnc3I8GwqXgQ8aHGrcdEndW5BN1XOgMJnOLyvfej7vbFUct3pYNMQe9rvG+Clc4/zc g10nv7mKJ/orwZeMD3lJ/5mFopRTnDu045jEP6tLZecPxQJve1Zhu9itHDYMzMBRDyl9 BFCUrfi7mEdEo22kDKQjnVPzqiMnIdSGYcUWY35gTa5LlDwhX96pQOG8VBIb/zJwkNNc vZj8izFOAJoMXUWh1n3XKIbwIoL1yVBF1iz6DvKliZLo/BMdx2iWguBi2xZ1oSI7OoOF zCXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:dkim-signature :date; bh=eSNikd5W3DA78KY0g+FZpaHaoGsINw3DopfDIW2Cts0=; b=M8I1UeXhgktItnqh5moh4mw25LPKjdi+2oMjZqdfd9cTmFImWHhApLBuxtkExcXJpU xBmgWG6E/k397GFuFWPZS1ZWqQgBmT4eG3cCSgLUaw9rPHe8b9FSVJuIdIiZdzLCuZ9w aIJhMZnxPxhv9FeUNC0YLBdS5kMqF7mrrxhGkTtRZXbv7/pZeqjS5bPF7IRtxwkrBhiu YFMMLEmAVXzSpB4uNo7WHFEYXyEEzxcvvI863RPobzHDfVd5YMrnnIextBq9hDbVJ7m1 M8Emp+HYG7ger0z+2kLzOMMIgsbylXosY5huHw1V2w5NBEF6kcqXNGOrpLMQh3w6f2W4 7xIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux-foundation.org header.s=korg header.b=tGaPNds9; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lr3si3833441ejb.388.2020.12.11.11.43.14; Fri, 11 Dec 2020 11:43:37 -0800 (PST) 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=@linux-foundation.org header.s=korg header.b=tGaPNds9; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2393715AbgLKTkB (ORCPT + 99 others); Fri, 11 Dec 2020 14:40:01 -0500 Received: from mail.kernel.org ([198.145.29.99]:40450 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393573AbgLKTjv (ORCPT ); Fri, 11 Dec 2020 14:39:51 -0500 Date: Fri, 11 Dec 2020 11:39:09 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linux-foundation.org; s=korg; t=1607715550; bh=U5rxTv/oE3jx6HklcCmBGmro94C4bmSbpwe8ZVtbESs=; h=From:To:Cc:Subject:In-Reply-To:References:From; b=tGaPNds9nNLIuZR3ejOz+yBohOgC7o2Q5h0m/NYNa9zd3uyUnGP/IP4+kW9R5Klpf ww7M2K+hdZO6jYV7elyNeRzaTtP4WsT6sCZElRWWE9lkbWbLyEygFlEho9rV2A3BLV 362MqgQHWa/jgbGJVMKxfO/qT9+2CbZ95+dC4qCQ= From: Andrew Morton To: Chris Down Cc: Kuan-Ying Lee , "qiang.zhang@windriver.com" , "sfr@canb.auug.org.au" , "aryabinin@virtuozzo.com" , "dvyukov@google.com" , "andreyknvl@google.com" , "qcai@redhat.com" , "linux-mm@kvack.org" , "linux-kernel@vger.kernel.org" , walter-zh.wu@mediatek.com Subject: Re: [PATCH] kasan: fix slab double free when cpu-hotplug Message-Id: <20201211113909.230e68fcb66193aa71661ddd@linux-foundation.org> In-Reply-To: References: <20201204102206.20237-1-qiang.zhang@windriver.com> <1607083295.22062.15.camel@mtksdccf07> <20201204172521.ed9f77164ff9f9fc91f35ee0@linux-foundation.org> <1607185035.22062.42.camel@mtksdccf07> <20201205170914.e380173074b2deded2ade3d3@linux-foundation.org> X-Mailer: Sylpheed 3.5.1 (GTK+ 2.24.31; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 11 Dec 2020 13:43:39 +0000 Chris Down wrote: > Hi folks, > > Andrew Morton writes: > >@@ -188,6 +190,10 @@ void quarantine_put(struct kasan_free_me > > local_irq_save(flags); > > > > q = this_cpu_ptr(&cpu_quarantine); > >+ if (q->offline) { > >+ local_irq_restore(flags); > >+ return; > >+ } > > qlist_put(q, &info->quarantine_link, cache->size); > > if (unlikely(q->bytes > QUARANTINE_PERCPU_SIZE)) { > > qlist_move_all(q, &temp); > > I'm afraid as well as the issues already identified, this also fails, because > `quarantine_put` now returns a bool after "kasan: sanitize objects when > metadata doesn't fit": > > mm/kasan/quarantine.c: In function ‘quarantine_put’: > mm/kasan/quarantine.c:198:3: error: ‘return’ with no value, in function returning non-void [-Werror=return-type] > 198 | return; > | ^~~~~~ > mm/kasan/quarantine.c:171:6: note: declared here > 171 | bool quarantine_put(struct kmem_cache *cache, void *object) Yup, thanks. I think I have this all fixed now, using the old apply-one-patch-compile-everything-repeat approach.