Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp442465iog; Mon, 13 Jun 2022 06:05:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz+5Ath66TlDAx3udUQc9UbY/0yXqP3YRcvOm6F8y+BPZcZxBkSexTNUYjX6ThU7aAVOoVT X-Received: by 2002:a05:6a00:ad0:b0:4e1:2d96:2ab0 with SMTP id c16-20020a056a000ad000b004e12d962ab0mr59479114pfl.3.1655125556050; Mon, 13 Jun 2022 06:05:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655125556; cv=none; d=google.com; s=arc-20160816; b=wuu/LSikTbXgqRWx3hybFDxL7PIoiONU3Ku2raE0BUFf/YKtfNKR7P78U1OrwgsAS3 Ejl5zlDGwcLPzR721ozzUqck5H4cQ17YdWbSJtm+nLkPffAhjMb+5uiuOZDluvpzBX0s hLcW4EeMXoWslf4VXRT9EC/DXbweBkjf207RRDYy2kb8eWDtxXRQSlPh57gxWYgL/vwS dwu1MROgM+68A8yjNYGp4Dknj05ynOaBSuDNidQocxUMeN8Ci8vuAsSLy5KXl1ZT1+R8 aoTuyTfx3xNYkrsaIl3iTuV8oq94EQhW3WHkPlBV6noYouOTGUr8mscbEYtcfNbLNOhQ EJ2w== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=YB2i9CCFYHXEWiZtY0qwSQgjM7JavYrV6yvsx7u76SU=; b=jNXBPoEhRBYkmL8SdFAieP3j4+Cty3onIwD8vriHCsnNW6eXvym32UfJ28MvceSKHd cA0mQrTMdi4aywGV8s/rauTX0bUbVyqXK4qoaimWAU/HcqjI67E9VFVATIKyj9JWUwwi BHDZ5r6ZKNxTISnnJISnuy3N8Dxthwlsq1OHLTqOY1gzYFHEReoic1IO7a8tiL+iQG+T YbcV8po75zdYhipLdv+UfXyGKPkZCIFi+9GzL+nJygg/Ckcxno2ccguWauWVq3ice8RR RfsNOiZBkNUnIEwBN8I7LtwQbbO6f3XfL2JHT2Ob7UPparUM+rSeP1WXDiL2VEahHmP6 0OtQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="S/TP/gmu"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id lb1-20020a17090b4a4100b001d9752b43absi10603186pjb.137.2022.06.13.06.05.39; Mon, 13 Jun 2022 06:05:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="S/TP/gmu"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S243039AbiFMKVC (ORCPT + 99 others); Mon, 13 Jun 2022 06:21:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60978 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243157AbiFMKTE (ORCPT ); Mon, 13 Jun 2022 06:19:04 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D56FEDFC9; Mon, 13 Jun 2022 03:16:49 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 97CD3B80E5C; Mon, 13 Jun 2022 10:16:48 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 007E3C34114; Mon, 13 Jun 2022 10:16:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1655115407; bh=A0HpK7TglfPM4Gwam1uPnihBLJAcsFvWh4WnQBaKaic=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=S/TP/gmuUirREMfwo/4W2eZS8sc/xA3RpqWG05akdndKeuSlXaVew6L9701c1nZPC 0oJHVMPE5xk6xLaTTgDjLZfYovvPPaD0cmmX67Yhanv2x8Q6EknbBaZhYMatjMyJlZ JwDH8y3yRvmE5RG2B6qfge2OcO8jzbsCKTHVrQ14= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marc Dionne , David Howells , linux-afs@lists.infradead.org, "David S. Miller" , Sasha Levin Subject: [PATCH 4.9 061/167] rxrpc: Fix listen() setting the bar too high for the prealloc rings Date: Mon, 13 Jun 2022 12:08:55 +0200 Message-Id: <20220613094855.220699476@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220613094840.720778945@linuxfoundation.org> References: <20220613094840.720778945@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-8.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: David Howells [ Upstream commit 88e22159750b0d55793302eeed8ee603f5c1a95c ] AF_RXRPC's listen() handler lets you set the backlog up to 32 (if you bump up the sysctl), but whilst the preallocation circular buffers have 32 slots in them, one of them has to be a dead slot because we're using CIRC_CNT(). This means that listen(rxrpc_sock, 32) will cause an oops when the socket is closed because rxrpc_service_prealloc_one() allocated one too many calls and rxrpc_discard_prealloc() won't then be able to get rid of them because it'll think the ring is empty. rxrpc_release_calls_on_socket() then tries to abort them, but oopses because call->peer isn't yet set. Fix this by setting the maximum backlog to RXRPC_BACKLOG_MAX - 1 to match the ring capacity. BUG: kernel NULL pointer dereference, address: 0000000000000086 ... RIP: 0010:rxrpc_send_abort_packet+0x73/0x240 [rxrpc] Call Trace: ? __wake_up_common_lock+0x7a/0x90 ? rxrpc_notify_socket+0x8e/0x140 [rxrpc] ? rxrpc_abort_call+0x4c/0x60 [rxrpc] rxrpc_release_calls_on_socket+0x107/0x1a0 [rxrpc] rxrpc_release+0xc9/0x1c0 [rxrpc] __sock_release+0x37/0xa0 sock_close+0x11/0x20 __fput+0x89/0x240 task_work_run+0x59/0x90 do_exit+0x319/0xaa0 Fixes: 00e907127e6f ("rxrpc: Preallocate peers, conns and calls for incoming service requests") Reported-by: Marc Dionne Signed-off-by: David Howells cc: linux-afs@lists.infradead.org Link: https://lists.infradead.org/pipermail/linux-afs/2022-March/005079.html Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/rxrpc/sysctl.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net/rxrpc/sysctl.c b/net/rxrpc/sysctl.c index 34c706d2f79c..f9afc21b7e2c 100644 --- a/net/rxrpc/sysctl.c +++ b/net/rxrpc/sysctl.c @@ -18,7 +18,7 @@ static struct ctl_table_header *rxrpc_sysctl_reg_table; static const unsigned int zero = 0; static const unsigned int one = 1; static const unsigned int four = 4; -static const unsigned int thirtytwo = 32; +static const unsigned int max_backlog = RXRPC_BACKLOG_MAX - 1; static const unsigned int n_65535 = 65535; static const unsigned int n_max_acks = RXRPC_RXTX_BUFF_SIZE - 1; @@ -114,7 +114,7 @@ static struct ctl_table rxrpc_sysctl_table[] = { .mode = 0644, .proc_handler = proc_dointvec_minmax, .extra1 = (void *)&four, - .extra2 = (void *)&thirtytwo, + .extra2 = (void *)&max_backlog, }, { .procname = "rx_window_size", -- 2.35.1