Received: by 10.223.185.116 with SMTP id b49csp1098689wrg; Sat, 3 Mar 2018 15:30:32 -0800 (PST) X-Google-Smtp-Source: AG47ELu0+sc9g27gMWegmrRMLTSohd4DSY1zNR2SXFDo3qVzkXiYVQGRRnRP0k/UQlIXQQNuhcqB X-Received: by 2002:a17:902:8487:: with SMTP id c7-v6mr8888493plo.7.1520119832483; Sat, 03 Mar 2018 15:30:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520119832; cv=none; d=google.com; s=arc-20160816; b=L4jUqK9LiYYUpXywunXps5+bsPX+iUOJhAKjNOn6o1mOk1HcTS3Bn8Zt9SFLvzrxyb O9yyV4+pL89YJBSvZ2kznBv4FU3Atw49Oj7DWmlcPE+/Hctaj34OOAs20UP4eE/cgUJ4 3QmAQVlPfVhBDlUcpKY34zDHcMaueMDEWbBpuTD6jwoaF4d20ggPX0uIN2b/Hmg9Y3vp GggZ4WbN77TljXo9gidai3CZSQHO7pa1QIu2/qAax1buXRmgOesShtuAcgcs32NKHJST VfM4unP851EhNvIxKKeWsTLc3Xbx82gmrxqbWLa+8r4ZeI0S1/QxKckSnvV+XNnsSE0S k2ig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :spamdiagnosticmetadata:spamdiagnosticoutput:content-language :accept-language:in-reply-to:references:message-id:date:thread-index :thread-topic:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=ive2FaRo4zpr5UXzEkeEGkGvIYpf6xn7bMkiQ0Tua0g=; b=xruR8T/geZkOhRg6piJiEz/4O0csbplxa0daUcWwtf5e3HecApppr1CDe7OEPThcka dC/tYvPoO/5w+mJvCJ7PW2TOX7k4rGwQybDEFndq41j+wUSXt+/PaIvT8gSsFwuFQDl4 rMTfcQ5vK91QhgmlOJqtE+vBL0m24apiX6alR7ugR1DQZibe7YmDeSH4wLd//vAJXGpU Ur6MdQwVU2cmjlzo8wbaQupdpGHMKLdSnG7NviUF+onCbdP6Y45hj48zn/UUTSJwd1np Eqx6sLSRT+yQbX0AGasp2O9v7SYXq0ym4SeachoSYWvLVfpwDuOgwN3F5hYx2mzg+gJU amsg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@microsoft.com header.s=selector1 header.b=ouYLKdWc; 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=microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p2-v6si5189001pls.436.2018.03.03.15.30.18; Sat, 03 Mar 2018 15:30:32 -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=@microsoft.com header.s=selector1 header.b=ouYLKdWc; 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=microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934601AbeCCWgq (ORCPT + 99 others); Sat, 3 Mar 2018 17:36:46 -0500 Received: from mail-bn3nam01on0115.outbound.protection.outlook.com ([104.47.33.115]:41088 "EHLO NAM01-BN3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932649AbeCCWgn (ORCPT ); Sat, 3 Mar 2018 17:36:43 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=ive2FaRo4zpr5UXzEkeEGkGvIYpf6xn7bMkiQ0Tua0g=; b=ouYLKdWc0Uq8P8P+porPhrH9WdG/SawsXJPoNwq1O1ve7IJrPxvWOE2qpy+CTelDbh5UJEqxLX2q5L8+K5VDTgwEQHTUT85m8rAyoYv9kIp9TxZV8PvjaN524rrqKC2Kknzgo4B4EhwCw6m2rReGA/4u+16WnlI6rYbQan9dRMU= Received: from MW2PR2101MB1034.namprd21.prod.outlook.com (52.132.149.10) by MW2PR2101MB1020.namprd21.prod.outlook.com (52.132.148.150) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.588.1; Sat, 3 Mar 2018 22:36:40 +0000 Received: from MW2PR2101MB1034.namprd21.prod.outlook.com ([fe80::1d56:338f:e2b:cec0]) by MW2PR2101MB1034.namprd21.prod.outlook.com ([fe80::1d56:338f:e2b:cec0%3]) with mapi id 15.20.0567.006; Sat, 3 Mar 2018 22:36:40 +0000 From: Sasha Levin To: "linux-kernel@vger.kernel.org" , "stable@vger.kernel.org" CC: Lorenzo Colitti , Steffen Klassert , Sasha Levin Subject: [PATCH AUTOSEL for 4.9 182/219] net: xfrm: allow clearing socket xfrm policies. Thread-Topic: [PATCH AUTOSEL for 4.9 182/219] net: xfrm: allow clearing socket xfrm policies. Thread-Index: AQHTsz8gpdhn0v776EW2twC7IemJmQ== Date: Sat, 3 Mar 2018 22:29:43 +0000 Message-ID: <20180303222716.26640-182-alexander.levin@microsoft.com> References: <20180303222716.26640-1-alexander.levin@microsoft.com> In-Reply-To: <20180303222716.26640-1-alexander.levin@microsoft.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [52.168.54.252] x-ms-publictraffictype: Email x-microsoft-exchange-diagnostics: 1;MW2PR2101MB1020;7:DK5INQcXqb7VC8nRzK3DVnIKsVwqYtW2vTLW+bbfet/STNpEloPR/ADGkKodAzV3ZijcVwgaXlyH44uSVV1wxOpeoVOIT1i5BA7zL4AEGdlorJEMBwUnHe4mMALXfmhrlJu8gRpKGQK7ZwtK1TUeZvlJh/YfozLG9L1Dnjr8Uol+JblrlvbTjNGiX5TASKa+vkXSBUWZnMQfrvKQka3PSERGBNPmOyLn6Pp28Nm3e4mNpzvAHzvooSgEFPzXt6I9 x-ms-office365-filtering-ht: Tenant x-ms-office365-filtering-correlation-id: ebb07106-5c29-4f43-3a0f-08d581573b9c x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(48565401081)(5600026)(4604075)(3008032)(4534165)(4627221)(201703031133081)(201702281549075)(2017052603307)(7193020);SRVR:MW2PR2101MB1020; x-ms-traffictypediagnostic: MW2PR2101MB1020: authentication-results: spf=none (sender IP is ) smtp.mailfrom=Alexander.Levin@microsoft.com; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:(28532068793085)(89211679590171)(211936372134217)(153496737603132); x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(8211001083)(61425038)(6040501)(2401047)(8121501046)(5005006)(93006095)(93001095)(10201501046)(3231220)(944501244)(52105095)(3002001)(6055026)(61426038)(61427038)(6041288)(20161123562045)(20161123558120)(20161123564045)(20161123560045)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(6072148)(201708071742011);SRVR:MW2PR2101MB1020;BCL:0;PCL:0;RULEID:;SRVR:MW2PR2101MB1020; x-forefront-prvs: 0600F93FE1 x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(39380400002)(396003)(366004)(346002)(376002)(39860400002)(199004)(189003)(6436002)(5250100002)(99286004)(3846002)(6116002)(8936002)(22452003)(86612001)(86362001)(4326008)(10090500001)(68736007)(6512007)(7736002)(97736004)(25786009)(76176011)(1076002)(6486002)(2501003)(6306002)(66066001)(36756003)(107886003)(2950100002)(8676002)(305945005)(5660300001)(105586002)(53936002)(3280700002)(81166006)(6506007)(106356001)(2906002)(81156014)(316002)(478600001)(72206003)(10290500003)(2900100001)(54906003)(966005)(110136005)(59450400001)(186003)(102836004)(26005)(14454004)(3660700001)(22906009)(217873001);DIR:OUT;SFP:1102;SCL:1;SRVR:MW2PR2101MB1020;H:MW2PR2101MB1034.namprd21.prod.outlook.com;FPR:;SPF:None;PTR:InfoNoRecords;A:1;MX:1;LANG:en; received-spf: None (protection.outlook.com: microsoft.com does not designate permitted sender hosts) x-microsoft-antispam-message-info: oTFVn6TSJfwxN4UYG/p1CV1X8BQ+ISGoF1A9Rckb2kgXYZevVTvaqdnY3ogKzR5oP+Klis7YUffQ9PBgpg/mYSBMjw8L8tz5O4RnpPt08kPF5act3iG7kqxTFXOrIagLFwy/mjYDfl6E3qefWMtnQFvsXGh8LtrXZSDQ6log7xw= spamdiagnosticoutput: 1:99 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-OriginatorOrg: microsoft.com X-MS-Exchange-CrossTenant-Network-Message-Id: ebb07106-5c29-4f43-3a0f-08d581573b9c X-MS-Exchange-CrossTenant-originalarrivaltime: 03 Mar 2018 22:29:43.2132 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47 X-MS-Exchange-Transport-CrossTenantHeadersStamped: MW2PR2101MB1020 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lorenzo Colitti [ Upstream commit be8f8284cd897af2482d4e54fbc2bdfc15557259 ] Currently it is possible to add or update socket policies, but not clear them. Therefore, once a socket policy has been applied, the socket cannot be used for unencrypted traffic. This patch allows (privileged) users to clear socket policies by passing in a NULL pointer and zero length argument to the {IP,IPV6}_{IPSEC,XFRM}_POLICY setsockopts. This results in both the incoming and outgoing policies being cleared. The simple approach taken in this patch cannot clear socket policies in only one direction. If desired this could be added in the future, for example by continuing to pass in a length of zero (which currently is guaranteed to return EMSGSIZE) and making the policy be a pointer to an integer that contains one of the XFRM_POLICY_{IN,OUT} enum values. An alternative would have been to interpret the length as a signed integer and use XFRM_POLICY_IN (i.e., 0) to clear the input policy and -XFRM_POLICY_OUT (i.e., -1) to clear the output policy. Tested: https://android-review.googlesource.com/539816 Signed-off-by: Lorenzo Colitti Signed-off-by: Steffen Klassert Signed-off-by: Sasha Levin --- net/xfrm/xfrm_policy.c | 2 +- net/xfrm/xfrm_state.c | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c index 5e89b7461f99..5b8fa6832687 100644 --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c @@ -1346,7 +1346,7 @@ EXPORT_SYMBOL(xfrm_policy_delete); =20 int xfrm_sk_policy_insert(struct sock *sk, int dir, struct xfrm_policy *po= l) { - struct net *net =3D xp_net(pol); + struct net *net =3D sock_net(sk); struct xfrm_policy *old_pol; =20 #ifdef CONFIG_XFRM_SUB_POLICY diff --git a/net/xfrm/xfrm_state.c b/net/xfrm/xfrm_state.c index 419bf5d463bd..13e0611a9085 100644 --- a/net/xfrm/xfrm_state.c +++ b/net/xfrm/xfrm_state.c @@ -1883,6 +1883,13 @@ int xfrm_user_policy(struct sock *sk, int optname, u= 8 __user *optval, int optlen struct xfrm_mgr *km; struct xfrm_policy *pol =3D NULL; =20 + if (!optval && !optlen) { + xfrm_sk_policy_insert(sk, XFRM_POLICY_IN, NULL); + xfrm_sk_policy_insert(sk, XFRM_POLICY_OUT, NULL); + __sk_dst_reset(sk); + return 0; + } + if (optlen <=3D 0 || optlen > PAGE_SIZE) return -EMSGSIZE; =20 --=20 2.14.1