Received: by 2002:a05:6a10:7420:0:0:0:0 with SMTP id hk32csp1070374pxb; Wed, 16 Feb 2022 10:16:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJxr3WOqcaU70m5kF3m73nr3/JiVcrMj/h35rpWZtz3x7BOPfiygJzhscByWPaWW9VID3YTn X-Received: by 2002:a17:90a:1202:b0:1b9:b7e7:1652 with SMTP id f2-20020a17090a120200b001b9b7e71652mr3225204pja.1.1645035360612; Wed, 16 Feb 2022 10:16:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1645035360; cv=none; d=google.com; s=arc-20160816; b=UHR6F/3ClLjJw91y2fO+c3i1T6MYi2o0ZeyomGDbGR5tkDlw5qTj+L5w/kAX9Du6dO ARUS9cJpdCSpxqYXwixM3dIKxyVCRTVGEnc+omLP3lIH7Kfga6eQwPSNUFOtvaXpnEKy TKmrTrQrKbYNWDyg91xQktXV5aIyjVypsvYLYojqA/vJ6jscvzobDkv+/ImfGrj0Va+o dISQ9gl9yErVLM8tCvd7ECv48Mi0gkIGEruhxJr9mb523qLU44eI18i/SPp4pxlDQy4r dhrC41MDIoQcBYmKIVUunTjGytUjL3ibztlq0CyP46x7WtBn691NrzBuJ8xMPofwoA6h 69Mg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=NE7EY8xDj/IqqOA16SqMQVmbg8CT9KQUqq/vPjFlZhI=; b=bQltAE2Ay0Me0rvIZLQkQ0vnsxHgcGrxG2kuaZkd1992m4Lv8w7UgRw6kjnZsSw3SN Rf5cJwUJMMqCPD6ZuyW/orwprbrrRn1rCBWU6VR4tSmsx0LYgT2E9I/DD+xQ6dnDqHxZ Y6C5PpfeaarvZiEkEQC6kH/299jIdD53JnGSZQ3EyCQKJF+RiO9McH/ltv6TM30bJ50J WfO1+PpwTRQIcck/3MZAVl6Jv56r8dQGHCI4wUFJ+fR2IbahNGsGSRbtFxFrgKtwcj5B aGkaAbrvXp2aM4zemGoREWd/lBWIxpfdknl+swZyX05mVDkRnRkD4RNhlPN0KqZ2CmdL P1jQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@digitalocean.com header.s=google header.b="I/j6kvCD"; 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=REJECT sp=REJECT dis=NONE) header.from=digitalocean.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h186si6388769pgc.30.2022.02.16.10.15.41; Wed, 16 Feb 2022 10:16:00 -0800 (PST) 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=@digitalocean.com header.s=google header.b="I/j6kvCD"; 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=REJECT sp=REJECT dis=NONE) header.from=digitalocean.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235032AbiBPOcl (ORCPT + 99 others); Wed, 16 Feb 2022 09:32:41 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:57294 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235036AbiBPOch (ORCPT ); Wed, 16 Feb 2022 09:32:37 -0500 Received: from mail-io1-xd33.google.com (mail-io1-xd33.google.com [IPv6:2607:f8b0:4864:20::d33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4A7409E9F3 for ; Wed, 16 Feb 2022 06:32:24 -0800 (PST) Received: by mail-io1-xd33.google.com with SMTP id s1so2508411ioe.0 for ; Wed, 16 Feb 2022 06:32:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=digitalocean.com; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=NE7EY8xDj/IqqOA16SqMQVmbg8CT9KQUqq/vPjFlZhI=; b=I/j6kvCD8Y0jU5HzdduK6zPqGJBLpG2zrXvbLUcD3UZxNBcIQId25DctMd8SoQ42Vm o2otTRInzpGJc+V+B8dHDfk28fmn5DzuUTXtp6oy7v5DmIwhxYQ1HavOOu3fp6N6NP4e quS8iebcC0vkB1q4pAvovLeLidzDnLB3bldNY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=NE7EY8xDj/IqqOA16SqMQVmbg8CT9KQUqq/vPjFlZhI=; b=p8jIf3FdFLl4+T4YKGe3qdTPYE+9pV3CwMd1LMRTpTaRzIJvjLJh0AnrB4dCVBWDVm 9pL3skCNuh8cXpaJ/nSrY2IEZoA6IRbnRiFsSDnVLjfgM4zjPIx31dyDQ5JvkPbz7YaN eX/BJeY+7pZVfgoFMU0g/Bqy8fCxzhNX1iqSJuoFro4cWGXLXOMWIrTO2toDaiME8ajK b08dQe6lQnNUN6jb0gcEj/eTUY3xGvp8Pfn9sWL2Zy4McZh0Z1NXxYoVeMcG3blaCV1Q imJoPzfaj6rLo9uLkaATHMsluBnswWZd5IThvSHWy0Vcp0h0wNoTWmHcnQKl9W+sKOsB WEYQ== X-Gm-Message-State: AOAM533StzMMOqpJoyH3tzjXrPp92ktRsb4OFHYgTOsx/hieoM/EnfWT J2vGhZf1b32KK5N6AUK9UMsgzg== X-Received: by 2002:a02:7742:0:b0:311:626c:d554 with SMTP id g63-20020a027742000000b00311626cd554mr1853496jac.134.1645021943659; Wed, 16 Feb 2022 06:32:23 -0800 (PST) Received: from localhost ([2605:a601:ac0f:820:35a8:1556:a044:f8bb]) by smtp.gmail.com with ESMTPSA id q9sm8926475ilo.56.2022.02.16.06.32.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 16 Feb 2022 06:32:23 -0800 (PST) From: Seth Forshee To: Stefano Garzarella , "David S. Miller" , Jakub Kicinski Cc: virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] vsock: remove vsock from connected table when connect is interrupted by a signal Date: Wed, 16 Feb 2022 08:32:22 -0600 Message-Id: <20220216143222.1614690-1-sforshee@digitalocean.com> X-Mailer: git-send-email 2.32.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_NONE,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 vsock_connect() expects that the socket could already be in the TCP_ESTABLISHED state when the connecting task wakes up with a signal pending. If this happens the socket will be in the connected table, and it is not removed when the socket state is reset. In this situation it's common for the process to retry connect(), and if the connection is successful the socket will be added to the connected table a second time, corrupting the list. Prevent this by calling vsock_remove_connected() if a signal is received while waiting for a connection. This is harmless if the socket is not in the connected table, and if it is in the table then removing it will prevent list corruption from a double add. Signed-off-by: Seth Forshee --- net/vmw_vsock/af_vsock.c | 1 + 1 file changed, 1 insertion(+) diff --git a/net/vmw_vsock/af_vsock.c b/net/vmw_vsock/af_vsock.c index 3235261f138d..38baeb189d4e 100644 --- a/net/vmw_vsock/af_vsock.c +++ b/net/vmw_vsock/af_vsock.c @@ -1401,6 +1401,7 @@ static int vsock_connect(struct socket *sock, struct sockaddr *addr, sk->sk_state = sk->sk_state == TCP_ESTABLISHED ? TCP_CLOSING : TCP_CLOSE; sock->state = SS_UNCONNECTED; vsock_transport_cancel_pkt(vsk); + vsock_remove_connected(vsk); goto out_wait; } else if (timeout == 0) { err = -ETIMEDOUT; -- 2.32.0