From patchwork Tue Oct 31 23:08:09 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Florian Westphal X-Patchwork-Id: 10036291 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id E5DAA603B5 for ; Wed, 1 Nov 2017 12:17:22 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id CD967286BB for ; Wed, 1 Nov 2017 12:17:22 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id C242928914; Wed, 1 Nov 2017 12:17:22 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-4.2 required=2.0 tests=BAYES_00, RCVD_IN_DNSWL_MED autolearn=unavailable version=3.3.1 Received: from UCOL19PA11.eemsg.mail.mil (ucol19pa11.eemsg.mail.mil [214.24.24.84]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id CEA7C286BB for ; Wed, 1 Nov 2017 12:17:21 +0000 (UTC) X-IronPort-AV: E=Sophos;i="5.44,327,1505779200"; d="scan'208";a="369274206" Received: from emsm-gh1-uea11.ncsc.mil ([214.29.60.3]) by UCOL19PA11.eemsg.mail.mil with ESMTP/TLS/AES256-SHA; 01 Nov 2017 12:17:20 +0000 X-IronPort-AV: E=Sophos;i="5.44,327,1505779200"; d="scan'208";a="5420498" IronPort-PHdr: =?us-ascii?q?9a23=3AdRiRBxczH8UmH6GdXmHdrqd4lGMj4u6mDksu8pMi?= =?us-ascii?q?zoh2WeGdxcmyYBCN2/xhgRfzUJnB7Loc0qyN4vCmATRIyK3CmUhKSIZLWR4BhJ?= =?us-ascii?q?detC0bK+nBN3fGKuX3ZTcxBsVIWQwt1Xi6NU9IBJS2PAWK8TW94jEIBxrwKxd+?= =?us-ascii?q?KPjrFY7OlcS30P2594HObwlSijewZbB/IA+qoQnNq8IbnZZsJqEtxxXTv3BGYf?= =?us-ascii?q?5WxWRmJVKSmxbz+MK994N9/ipTpvws6ddOXb31cKokQ7NYCi8mM30u683wqRbD?= =?us-ascii?q?VwqP6WACXWgQjxFFHhLK7BD+Xpf2ryv6qu9w0zSUMMHqUbw5Xymp4rx1QxH0li?= =?us-ascii?q?gIKz858HnWisNuiqJbvAmhrAF7z4LNfY2ZKOZycqbbcNwUX2pBWttaWTJHDI2y?= =?us-ascii?q?coADC+QMMeNeooLgpVUBsAG+CBGiCu3v1DFGhXH20qIm3Os8Ew7J0hEuH8oMvX?= =?us-ascii?q?jJotj6KrwSXPupzKXU1zjPc+9a1C3j5IXObxsvoeuMXbV1ccfJyUcvEwTFjk+R?= =?us-ascii?q?qYP/OTOey+QCvHaA7+p8TeKvi3QoqwVsqTWoyMcthJLEhpkJylDe8SV23oA1Kc?= =?us-ascii?q?elR0FleNOpFoZbuS+dN4tzWMwiQmdotT4nxb0dpZ63ZjUFx4o5xxLHc/yHdIyI?= =?us-ascii?q?4hP/W+eROzt3mGtpdKumixmo90Wr1+7yVtGs3VpXoSdIncPAu3AQ2xDJ9MSKRe?= =?us-ascii?q?Vx8l281TqXygze5eBJLVoomabBNZIszL09moASvEnBGCL9hV/4g7WMdko+/+il?= =?us-ascii?q?8+HnYrL7qZCCL4J0kQT+Mrg2msy4HOQ4LhACX2iF9uS4073u5VH5T69Qjv03j6?= =?us-ascii?q?nZq4rWJdgbp6GlAw9V1Zwv6xCjADe9zNsUh3wHLFNBeB6fjojpPU/BIOzgAPui?= =?us-ascii?q?jFmhny1nyvDbMrH7HJnAIWbPnK38cbpl7k5T0gszzdRR55JODbEBJer+WlTvu9?= =?us-ascii?q?zcDx85NRG0wun+BNpm0YMeRGSPDbOHP6PJqlKI+uIuLPWMZI8Sojr9LeMl6OT0?= =?us-ascii?q?gX82nl8dY7Gl3YELZ3CgAvRmP0KZbGLugtcGF2cFpBY+TOzwh12ESjNTZXGyX6?= =?us-ascii?q?Q55j4hE4KmEZnMRpq2gLCb2ye7BJJWbHhcCl+QCXfoa5mEW/AUZSKQIM9uiCAL?= =?us-ascii?q?Vbu6S48m0xGutRH6xqFpLurQ5y0Zuons1MVz5+3PiBE+7zt0D96S02uVVWF7gn?= =?us-ascii?q?sIRyMq3KB4uUF8xFaD0ax9g/NGD9xe/P1JXRknOp7b1ex1EcjyWhjGfteLVlmp?= =?us-ascii?q?XsmmDSs2TtIrzN8Ee1x9FMm6jhDfwyqqBKcYmKGXC5wx9aLc2WTxK9tmxnbYyq?= =?us-ascii?q?YhlVgmQ8pINW2gnKJ/8RbcB5LRmUWDi6mqbbgc3DLK9Gqb0GWOoFtXUBRrXKrZ?= =?us-ascii?q?WnAfY1fZos7i5kPeVbOuD6ooMhdZw86YNqRKcsHpjUlBRPr7ONXfYmWxm2GrCB?= =?us-ascii?q?aNwrOAdYvqe2MH0CXbEkcEiQMT/XeYNQcgHCuhpXzRDCB2H1L1f0zs6fV+qG+8?= =?us-ascii?q?TkIs0Q6Kd1du16C0+h4OnvGcU+kc3qgFuCc6szV0GEyy0M7IBNaaoAphZqpca8?= =?us-ascii?q?sn4FhbzWLZqxB9Ppu4IqBsnF4RaQJ3sF/v1xVsEYhAlNAqrHIzwAppJ6OYy0lN?= =?us-ascii?q?dzSC3ZD/IrfXMHX9/Aiza67K3VHTyNWW9b0M6PQ/tlXupwKpGVAh83VgztlZyX?= =?us-ascii?q?yc5o/FDAAKS5L+Tl439wRmp7HdeiQy/Z7b1WdtMaaqqD/PwMgmC/cgyhq6eNdf?= =?us-ascii?q?KqyEHhfoE8IGH8iuNPAqm1+xYxIeIe9d6bU5P8yjd/qJwqKrOvhvnC6+h2Rd/I?= =?us-ascii?q?99yl6M9zZ7SuPQxJYFzeuY3gycVzfgl1qhqcb3mYdKZDEXBGW/zzLoBIhPaa1u?= =?us-ascii?q?ZYwLE3uhI9WrxtVigJ7gQ3BZ+0SnB1MaxsCpYwGSYkfj3QJOz0QYumGnmS6iwz?= =?us-ascii?q?xziTEpobKV3DbSzOT6aBoHJmlLSXF+jVjxPIe0jsoVXEyzYgc1kxul4Fr1yLJA?= =?us-ascii?q?pKRjNWXTR1lHfzTuJWF4TqSwrqaCY9JI6J4wtyVXUeC8YVSERb7muBYVyT3sH3?= =?us-ascii?q?FZxDwhcDGqoJr5lQRgiG2BNHZzsGbZecZoyBfB5dzTWeJR3j0cRCVilTbXBl+8?= =?us-ascii?q?P9+m/diPk5fDs+a+WHi7Vp1UayXrypmAtCSj721wHRK/h+yzmsHgEQUi1S/71s?= =?us-ascii?q?JqVTnRoBbnfIbr06W6MeR6fkhnH1L88NJ6GoB4kosxmJ4QwmIWhpOL8nobiW3z?= =?us-ascii?q?K8lU2bribHoRQj4G28TV4A/h2E1nMH2J3Z72VnKTw8Z6fNm6f38Z2jkn48BNEq?= =?us-ascii?q?eU46ROnTFprVqgsQLRff99ky8eyfQw7n4amPoEuAkzwSWbGbASG1dXPTD2mxSP?= =?us-ascii?q?9dC+o71dZHyzfrioyEp+gdehAamaog5GRXb5foktHTdq4cV5LFLDzmfz55r5eN?= =?us-ascii?q?nLc90TrAaUnw3bj+hSNZIxjOYFijRpOWL6p30lxPA0gQZo3Z6koIiNM39t876h?= =?us-ascii?q?Ah5EKj31YNse+i/rjalDhcuWwYavEYhhGjkRWpvnU+6oGioItfv7LwaODCE8qn?= =?us-ascii?q?CDFLrHBwCf9UNmomnTHJCqK3GWJGAVzdt4SxmbPkBfhxoUXDoilJ4jCg+q3NDh?= =?us-ascii?q?cFt+5j0J6F73sB1Myv5vNxn6SWrfqhmnZSozSJiFNhVW9htC50DXMcOA8u1zAz?= =?us-ascii?q?tU/pq7rAyCMmabfRhHDXkVWkyYAFDuJryu6sPE8+icGOW+M+fObq+UpuFFUfeH?= =?us-ascii?q?246v0pB68DmWLsWAIGNuD/sl1UpfRXp5AdjWmy0TSywLkCLAd9SbqA2y+yFtq8?= =?us-ascii?q?Cw6vDrWAXv5IaUEbRdLdBv9wqxgaeZOO6anDx5JipA1pMQ2X/Iz6AS3FAIiy5w?= =?us-ascii?q?ajatCq4PtSjRTKLXga9aFAQUZD92NMdS6KI8xAZNM9bBitzpzr54kuI1C1BdWF?= =?us-ascii?q?zngMGmf9QKI3mmOVPJBUaLLq+GJSHFw8H2Z6OzU7tQg/lVtxKqvTaXCUjjPi6M?= =?us-ascii?q?lzPxTRCgLflMjD2HPBxZoIy9aghiBnP9Q9Lgax27LNh3gCY3wbIqmHzFK3QQMT?= =?us-ascii?q?9mc0NCtreQ9z9Xgu1jG2xd6XpoNfKLlD2e4+ncK5YWqudrAj9um+JB/ns116FZ?= =?us-ascii?q?7DpaS/xxmSvSqMNuol69n+aTyjtnSgdOqi1RiIOFp0piJb7Z9p5GWXre+xIN92?= =?us-ascii?q?qQAQwQp9R5Et3vp7xQyt/Xma3oKTdC/NXU/c0HCsfJNs2IK3shPgDvGDLOCwsF?= =?us-ascii?q?VzGrP3nFh0NBiPGS6mGVrp8ip5f2l5oBUKFbW0IuG/MdEkRqAtoCIJJtUTMllb?= =?us-ascii?q?6Ul8kI5HWkoBnWXsVasYjNVuiODvX3NDaZkb5EagMUwbP/KIQfLJf720tja1Zk?= =?us-ascii?q?moTFAFDQXddTrS1idQI7vEJN8H1iQWIpwELldhmh4HkNGv6ohhQ2kBdxYfwx9D?= =?us-ascii?q?fw5Fc6PlnKpSs0kEYvgtjlhDeRcDD/LKiuQYFWFyr0t080MpzlWQp1axO9nVB8?= =?us-ascii?q?PjfeW71Rl6dgdXxsiALEv5tAB+RTTalfbR8TwvGXfOko3k5aqiW8xk9H5PHJCZ?= =?us-ascii?q?18mws2aZSstW5P2xp/bN4pIqzdPLBJwUZLhq2QpCCozPw+wA8FKkkW8WOSYjMH?= =?us-ascii?q?uEsGNrk+PSqn4Oxt5RaEmzRdZGgGT+Aqre5y9kMhJ+SAyDrt3KNEKkC3MeyQMr?= =?us-ascii?q?2Wu2zBlcOTWFw/yFkIl05f8bhxy8cjfFKeV1ozw7uJCxQJKc3CJBlIYMVI6njT?= =?us-ascii?q?fDuBsf7WzJ1vJYW9DOfoTOGVtKkKnk2kARwpH4UQ7sUBBJWs1l/XLdv/Jr4f1R?= =?us-ascii?q?ot/BjrJEmCDPlRfBKLly0HrN+5zJ522olQPT4dAWNgMSmt4bbXvAAqiuKZXNgq?= =?us-ascii?q?encaQpcENnUuVc2hhSFZu3VADD+q0uMW0wWN8zj8piHMAzbmdNpjeO2YZRVyB9?= =?us-ascii?q?Gq4T8/6bS5iUbL8pXCIGH3Lchiut7K6eMdu5aHC/NVQKJgvEfdm4hXXWelX3TJ?= =?us-ascii?q?EdGrO5j6c5MsYsDsCnamTly/jCo4QN31PNasMqeHnxnnRYNUsYmd2zAjM9WyGy?= =?us-ascii?q?oFFBdxve4D4rtwZQMeY5YhZx7nqRg+PbSlIAiEytWuX3qtKTxOQvZE0+q6Yada?= =?us-ascii?q?wDAxYe+k1nQgVIo6wPOt8U8NXp0KiQvexfm7bYlETSfzAmBdexnIpSchmGhhK+?= =?us-ascii?q?cywuM7wBzWtFkRKC2Ee/JyZ2xFpd48A0meIXJsCmo3X1Wcl5bM4haw37AO+CtQ?= =?us-ascii?q?h8xU0etEsHfivp/fZzasWLezp5vMriQud8QrrapqPIP/JcuGsY/RkSbETJnMqA?= =?us-ascii?q?GFVjC1F+ZCkNhKPC1YWOVImX0iOcEeo4pO81AxVsAlKLFUFKksvKqlaSR6Ai4W?= =?us-ascii?q?zC8ZUYyA3DgDguez27vaihmQf444MBwBqplChMUSUzJuaCMEuKCjT5nWl3ODSm?= =?us-ascii?q?UTLgYf9xhD5AIBlo91f+Dq+onIQYRNyzFIvf17TDHHFp5y91v0UmuWm0T3SO29?= =?us-ascii?q?k+y12gJf1Ojj0sMGWB55E0RdxP1blkopKLF2N6kfpZTGsjmWekPmpGjt0vepJE?= =?us-ascii?q?FNyc3IcF31FIvFtWzgUiIC/X0bW4pPx2/DFZQIkwt0c6ErpE1SL4Cgf0bx/T0k?= =?us-ascii?q?x4ByELm/WsGn3VElrWwJRy2yCdpOF/lmsE7LWD1ie52rp4/lNI9UQm9M45Cdql?= =?us-ascii?q?BZkUtrMy6lyZpTNcBN4jgQXDdRuzWRpt2yR9Nf2cVuFZ8DPs9/u2vhGKNDIJWR?= =?us-ascii?q?v3o2urn0x3/F5zw8tUy1yC+1G6CmU+JT53ceFRkxJ2SCtkkvCPMh8mfI/VDXqF?= =?us-ascii?q?90+/pUC6OSgkpvuDZ9Bo5BBjJX2nC/NVhzS2NGs+pCIqTPb8NcW+UyZQOoOxEm?= =?us-ascii?q?F/4m2FKG8FppknjneCx9qBFa+zzDUAYpTyUVhKnimSEGoMG9JTAaU45IbSkmby?= =?us-ascii?q?rdMA2blzxYsApdZk13VZ0UGcpK+7Ye3YRI5MXCUlqsJTsDXBN8KgIyyeBfmlJb?= =?us-ascii?q?sEWEZSDdChKldezRvRJqfceettKpIe/9/AdAlIPorv40+LkER3K7hwKhW9beoJ?= =?us-ascii?q?HgtteSrEuBaL/4M/GgYX/GVDXMlQuwhas+AJbX4yjeKxFbK55nyXo+fZfuF2jL?= =?us-ascii?q?PQhcJ60BI0pXT6d6ac9JoupCfc9rZL4J+bNxBhKAXh7vBJavo+dYIVnOXjneMi?= =?us-ascii?q?GB8vCloY3J87zdSO/gZsiSyHbbWa53OY166TbjEbfwzYBe4lb22utq9k5iS1jJ?= =?us-ascii?q?KTqBrNP6JgMP/saiaFDvvpg0HTPSHJdwkWbixkBaeMoRWC2m6pMYyIlW6HzoU+?= =?us-ascii?q?J3zlDzsPFO97lj8YQ34apmycG6JafILvRVrFFoDwOIBgpw8JUtG29/S3pXYuAP?= =?us-ascii?q?NPfbZb4Zgtz2q+DrC6wX7wWY++pdadbcJkHBnMy/BiudSRxCkgcBsyQVLhCA1/?= =?us-ascii?q?6fhq97VdqlpfXj2k0z+VS+KQQGzL9174ee5qWIvPPXbwfWzbUcXKjqR9/8rrMo?= =?us-ascii?q?u0yI/v0ojr8OemtyYw28C+gQTcsdy2jvzKwwyiIsCczDFar6+PFfT3I5gi7gm5?= =?us-ascii?q?dlEloKAPwUGaSE/Z9CnmY4nOzULcYWfbxDmmmREx6kDr4CxmSx5yuRPmZlngnE?= =?us-ascii?q?0wvsTmOr8F/2sSh4TDPIz9f4l0pYVqK6BUlMUCW0Pk94qimAPBLytNrwu6Q68l?= =?us-ascii?q?05MnD+uNKKjmuhN6tdH9fjK9yEPSk0uFUXgYUzRtyu3IAWAt+9L8kR8X5gdPve?= =?us-ascii?q?6mWrkyBbr6dBmYXe/tmf+u/LEnm4k62at7KNyShZynk5p14w8MyvO+rV59KUX/?= =?us-ascii?q?SnyXoeQz14uwvbUB6/sqbboEwMOUyXzEfLn5QHMcpY3Xkj2EDp/uojQNMv9AVG?= =?us-ascii?q?DInAevcCqCvvNzvz3FmQfcg4VjSE0ztQBFL6C0N0GK8m2GL/pMjJj2vf+0U0Ro?= =?us-ascii?q?lscEzqnQR3AJ8kKU0x6FgWzC0DERIOaRyCF7GnG0DlLYoCVUgeZhWKx6C6db0r?= =?us-ascii?q?3UJvwrOu6ujTbfZ/B6YXNfZSkBSOnF5FFZISq6EeR6h8e1BF/q7NugfiE5TnX+?= =?us-ascii?q?ThlXcoKf21WN5V8cQDuHsk/AmyXAev6ZZM77YalJCHbLVEboLWvMBh9Utn4yAA?= =?us-ascii?q?djBVihhlkxy5SfwcpPzk4tXDv5qn8PyuW7gxR+UX7BU0A2V+j4fuj1Aju97Xyv?= =?us-ascii?q?xcRpfTiYvh7ABHO2SKt5rC0xlgNeoOLJqmfLl++HUBOygeIHUOMd2Na/Yi5y9t?= =?us-ascii?q?MTPT50FNA84XYdMXItDNmABOhUHzXrFc6NbbEEeCC4hvb8Ao83b3yDct/JQgUO?= =?us-ascii?q?bv8iO5KIvD4FFKO/NDiCRsm8zYpOgJ3/XdFCgX7WOeaxhvzSOI04ONBOro/eWQ?= =?us-ascii?q?1NHUUEsLHisxU4dbODqC9hKoS/GwlJXoSAyU7NH8gI4wdUKXXHyxn78FvrxKEe?= =?us-ascii?q?FeliXxxiJeGZzth/KJr9qs73NatlJbH4Zo9h3JAbhRMJp9NxT5kMmrW0d9CzDw?= =?us-ascii?q?eMHRbBUuvvSZyv0L4+VkOEv0fZUbLQ4cy7Lm9XpVSRNjSLzxvlaZW+IdfsdpSP?= =?us-ascii?q?PArnBI9I1hKq4PPF6GpJzprzdFs042AA43aLAqqjxVa0jOkBdTW6nqpL4KkhEc?= =?us-ascii?q?XsJhuU9QBWKwP3oz5zvZVatPiqmcE/gV8iiOQawPVEVoKTlyQxSv2JVhY7Gph+?= =?us-ascii?q?xIsntaniNhp/gnyz5mSwWyuS3io6IAwjwh96u+tDofpXxJVOOenDnUCV9b1vQF?= =?us-ascii?q?kb8cC2r+6Vy7eHQDY4/y4L5pJMv+8Ykh528yYQ4kfy0AXOSvFzv8j6WWDYyTqN?= =?us-ascii?q?hcngKCuN3Sbb+vKigfLrY9yRLjRnhl1QjemBdo8HcVTTi76d8kJZm9Odw7ySay?= =?us-ascii?q?HmjbblkM6LtTsMTtrV4LUPc2aVR5zWV/08iHQzYARNDOG2kpjQgrd2FEfIhF6R?= =?us-ascii?q?AEC6kimiyIsbVe/gEIfDfUFZyo+ozRncfL2nk9SsxnxmDMqa2GgZMq1mNqm9Vu?= =?us-ascii?q?4i6IpnsSa/TSU9VwDXjryodf1ev+au22ve8ZTotm1K+sUOQGMsmk5Wu2xItqVV?= =?us-ascii?q?G4ybgEGFq5KuADzK/BUyi5UW2YRfiLc2+UkjYhNU7y4QOnLkc5acdNq089PPDP?= =?us-ascii?q?hptblw3mSrN7WDmfpUXczGw4KuMadgQ2uIi9dwwNVu4RaPCWJfIyz/0mFFsMc3?= =?us-ascii?q?jJEDN4C+CotV6tnZB7NGt77ET7YOTt9wXmP8WIGhkAD4HWtJlx+ea1RmiZI39v?= =?us-ascii?q?0AVyPFVo9+fYD1kwuPdcc4yQndfMmdt2yusFd/ZxMS0npNEfgIVj6ZOb0M2Sax?= =?us-ascii?q?He0o7yJc3JovifG/DfyEAqdX9BX7oBZQP6/Z46PsI4W7LPAbtZpwoTCrYgTJwn?= =?us-ascii?q?KWjx6Ll+LBlvfQ7JeLS0ns7qq/qPZptVoX/W810xID7Yux0C0fy0URd7Yourh3?= =?us-ascii?q?roJpAwQShNr9p3ChtpBIFPAd8PrxK7A56In6G2k9qx9FlmtO8KsKrwDPfK2c+n?= =?us-ascii?q?34VwWZhV+0iLPDfXBKl2jUVplOOygu3P0pPpE8PtZcsEVPRnQm7CcrLGHJ+wKj?= =?us-ascii?q?GJOs3nYENG7ric0K55UhWWeSD5UKqGtDG+OPVi/0o71pRyfPDPwzw187HbxNzy?= =?us-ascii?q?anlZpiemqn6JLoFf7F3RBeHFWRJbU/+F/3hkHaENaov07ugOO8Q4wNeA+wlz8C?= =?us-ascii?q?hC0MydLqi6oE/M3150eJPYIUbyxSY2R5MKIBW+MEsrh2/VsHLdDmpALpvsFc44?= =?us-ascii?q?uN+IClTI4E5rlCl5fmdcHkLwTMqVfG0c3NizIgaN8VQYIcwEmruZfUkit6S0Ad?= =?us-ascii?q?ZlIYldmeyu/OEJjv5yNzvLSc4cMyyGf+w+BSZYEuia/AtgWRUDqbVgH9ZqaA?= =?us-ascii?q?=3D=3D?= X-IPAS-Result: =?us-ascii?q?A2CLAgD1uvlZ/wHyM5BcGwEBAQMBAQEJAQEBFgEBAQMBAQE?= =?us-ascii?q?JAQEBgzEDgVInjxCOJIF8lkOCCimKIUAXAQEBAQEBAQEBAQFqKII4JIJBAQEBA?= =?us-ascii?q?QIBAQIkEz8DAwkBAQoYCRMKCAMBCwVJEwWKFggDqiM6ixABCyaDLoIHgVOFE4F?= =?us-ascii?q?IAYcMgjIBBKIKgQqTZYt+hz+XTCABNoFsVSYUgy2CXAwQgWh2iissghYBAQE?= Received: from tarius.tycho.ncsc.mil ([144.51.242.1]) by emsm-gh1-uea11.NCSC.MIL with ESMTP; 01 Nov 2017 12:17:18 +0000 Received: from prometheus.infosec.tycho.ncsc.mil (prometheus [192.168.25.40]) by tarius.tycho.ncsc.mil (8.14.4/8.14.4) with ESMTP id vA1CGk88022575; Wed, 1 Nov 2017 08:16:53 -0400 Received: from tarius.tycho.ncsc.mil (tarius.infosec.tycho.ncsc.mil [144.51.242.1]) by prometheus.infosec.tycho.ncsc.mil (8.15.2/8.15.2) with ESMTP id v9VNeqLg165096 for ; Tue, 31 Oct 2017 19:40:52 -0400 Received: from goalie.tycho.ncsc.mil (goalie [144.51.242.250]) by tarius.tycho.ncsc.mil (8.14.4/8.14.4) with ESMTP id v9VNeodF004013; Tue, 31 Oct 2017 19:40:50 -0400 X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: =?us-ascii?q?A1D1AAA7CflZfy0bGNZcHAEBBAEBCgEBg?= =?us-ascii?q?1yBVSefLZZCghGFRQKEdEEWAQIBAQEBAQEBEwEBCxaFegEBAgIBJxM/ECMJExI?= =?us-ascii?q?PBUkTihsIA6pMOosOAQEBAQEBAQMBAQEBAQEigy6CB4FThlsBhiBsgjIFogaBC?= =?us-ascii?q?pNli3yHP5dLJgOCGVUmFIMtglwMEBmBT3aKJCyCFgEBAQ?= X-IPAS-Result: =?us-ascii?q?A1D1AAA7CflZfy0bGNZcHAEBBAEBCgEBg1yBVSefLZZCghG?= =?us-ascii?q?FRQKEdEEWAQIBAQEBAQEBEwEBCxaFegEBAgIBJxM/ECMJExIPBUkTihsIA6pMO?= =?us-ascii?q?osOAQEBAQEBAQMBAQEBAQEigy6CB4FThlsBhiBsgjIFogaBCpNli3yHP5dLJgO?= =?us-ascii?q?CGVUmFIMtglwMEBmBT3aKJCyCFgEBAQ?= X-IronPort-AV: E=Sophos;i="5.44,326,1505793600"; d="scan'208";a="102896" Received: from emsm-gh1-uea10.ncsc.mil ([214.29.60.34]) by goalie.tycho.ncsc.mil with ESMTP; 31 Oct 2017 19:40:50 -0400 IronPort-PHdr: =?us-ascii?q?9a23=3AqVcTghzp6f1+xunXCy+O+j09IxM/srCxBDY+r6Qd?= =?us-ascii?q?2+IfIJqq85mqBkHD//Il1AaPAd2Dra4fwLCP+4nbGkU4qa6bt34DdJEeHzQksu?= =?us-ascii?q?4x2zIaPcieFEfgJ+TrZSFpVO5LVVti4m3peRMNQJW2aFLduGC94iAPERvjKwV1?= =?us-ascii?q?Ov71GonPhMiryuy+4ZLebxlUiDanbr5/Ihq6oRvMusILnYZsN6E9xwfTrHBVYe?= =?us-ascii?q?pW32RoJVySnxb4+Mi9+YNo/jpTtfw86cNOSL32cKskQ7NWCjQmKH0169bwtRbf?= =?us-ascii?q?VwuP52ATXXsQnxFVHgXK9hD6XpP2sivnqupw3TSRMMPqQbwoXzmp8rxmQwH0hi?= =?us-ascii?q?gZKzE58XnXis1ug6JdvBKhvAF0z4rNbI2IKPZyYqbRcNUUSmpbWsZaSjJPDIWy?= =?us-ascii?q?YYASC+YNIOZVo4z7qlATrxWxGBOsCfvyxDFGhnH4w6400+ouHg7awQMvHdwBvW?= =?us-ascii?q?/IrNnpLqoeTfy5wbPWwTjFcvhY2S396I/Nch05of+MWbVwcdDQyUY1EQPOk1Wf?= =?us-ascii?q?ppL+PzOJzuQNs3KU7+59Xu+ohW4mpRp8oiOzxsc2jonGmIQVxkrZ+ipn2Ys4I8?= =?us-ascii?q?CzRkB8Yd6hCpRQtieaOpNrTcM5X2Fkojs1xaMYuZKjZCgKz5Anxx/DZP2HaYSH?= =?us-ascii?q?/gvvWP+ILThign9uZbGxhw6q/ES+1+HxWdO43EhFoyZfjNXBtGoB2hPT58SfV/?= =?us-ascii?q?dw8Uas1SyT2wzJ9O1JL0M5mbDaJpMjxLM7i4Advl7ZHiDsnUX7lK+WeVsg+uiv?= =?us-ascii?q?8+nobK/oqJGCOoJ6lAzwKLgjltC+DOgiLAcBQW2b+f+z1LH5+E32WrRKjvksnq?= =?us-ascii?q?ncsZDaIdwXpq+/AwBLzoYu8wizAyqp3dgCg3UKI0hJdAyFgoTzNFzDIOj0DfKl?= =?us-ascii?q?jFStlDdryerGPrrkApjVIHjCnqzsfa1h605GzAo809Zf64hJBb4fOP7zQFP+tM?= =?us-ascii?q?TEDh8lNAy52/3nB8hm1o4FRWKOArOWMKPVsVOS4OIvOPODaJUauDb6Nfgv/+Tu?= =?us-ascii?q?gmMhmV8BYamp2oMaaGumEfRiIkWZZ2fsg9gaHGcWvgsxUOzqiFqYXT5VfHa9Rb?= =?us-ascii?q?gw5j48CIK4Xs//QdWViaGFlAK8GYdbLjReA02IOW/haoHBXvALci/UKchkxG8q?= =?us-ascii?q?T7+kHqEl0guvvQmy9Ld8MvLU8ylQ4Zz8/MNp/enek1c++GonXIymz2iRQjQszS?= =?us-ascii?q?szTDgs0fU68RFw?= X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: =?us-ascii?q?A0DiAAC7CPlZfy0bGNZcHAEBBAEBCgEBF?= =?us-ascii?q?wEBBAEBCgEBgzGBVSefLZZCghGFRQKEdEEWAQEBAQEBAQEBAQESAQELFl2COCS?= =?us-ascii?q?CQQEBAgIBJxM/ECMJExIPBUkTihsIA6pMOosOAQEBAQEBAQMBAQEBAQEigy6CB?= =?us-ascii?q?4FThlsBhiBsgjIFogaBCpNli3yHP5dLJgOCGVUmFIMtglwMEBmBT3aKJCyCFgE?= =?us-ascii?q?BAQ?= X-IPAS-Result: =?us-ascii?q?A0DiAAC7CPlZfy0bGNZcHAEBBAEBCgEBFwEBBAEBCgEBgzG?= =?us-ascii?q?BVSefLZZCghGFRQKEdEEWAQEBAQEBAQEBAQESAQELFl2COCSCQQEBAgIBJxM/E?= =?us-ascii?q?CMJExIPBUkTihsIA6pMOosOAQEBAQEBAQMBAQEBAQEigy6CB4FThlsBhiBsgjI?= =?us-ascii?q?FogaBCpNli3yHP5dLJgOCGVUmFIMtglwMEBmBT3aKJCyCFgEBAQ?= X-IronPort-AV: E=Sophos;i="5.44,326,1505779200"; d="scan'208";a="5337431" X-IronPort-Outbreak-Status: No, level 0, Unknown - Unknown Received: from updc3cpa06.eemsg.mail.mil ([214.24.27.45]) by EMSM-GH1-UEA10.NCSC.MIL with ESMTP; 31 Oct 2017 23:40:49 +0000 X-EEMSG-check-005: 0 X-EEMSG-check-006: 000-001;54ecae00-ecb2-4e22-b273-9bc38216c05c Received: from localhost.localdomain (localhost [127.0.0.1]) by UPDCF3IC02.oob.disa.mil (Postfix) with SMTP id 3yRSXJ5zwgz2Sj8V; Tue, 31 Oct 2017 23:40:48 +0000 (UTC) Received: from UPBD19PA05.eemsg.mil (unknown [192.168.18.6]) by UPDCF3IC02.oob.disa.mil (Postfix) with ESMTP id 3yRSXJ5KlQz2Sj8G; Tue, 31 Oct 2017 23:40:48 +0000 (UTC) Authentication-Results: upbd19pa05.eemsg.mail.mil; dkim=neutral (message not signed) header.i=none X-EEMSG-check-008: 258800750|UPBD19PA05_EEMSG_MP5.csd.disa.mil X-EEMSG-SBRS: 0.0 X-EEMSG-ORIG-IP: 146.0.238.67 X-EEMSG-check-002: true X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: A0BbFAASCPlZZEPuAJJcHAEBBAEBCgEBg1+BUiefLZZCghGFRQKEdEEWAQIBAQEBAQEBBFM8hR0BAQEBAgEnEz8QCxgJExIPBUkTihsIqk86iw4BAQEBAQUBAQEBJIMuggeBU4UTgUgBhwyCMgWiBoEKk2WLfIc/l0smDiKBbFUmFIMtglwMEIFoQDaKJCyCFgEBAQ X-IPAS-Result: A0BbFAASCPlZZEPuAJJcHAEBBAEBCgEBg1+BUiefLZZCghGFRQKEdEEWAQIBAQEBAQEBBFM8hR0BAQEBAgEnEz8QCxgJExIPBUkTihsIqk86iw4BAQEBAQUBAQEBJIMuggeBU4UTgUgBhwyCMgWiBoEKk2WLfIc/l0smDiKBbFUmFIMtglwMEIFoQDaKJCyCFgEBAQ Received: from chamillionaire.breakpoint.cc ([146.0.238.67]) by upbd19pa05.eemsg.mail.mil with ESMTP; 31 Oct 2017 23:10:54 +0000 Received: from fw by Chamillionaire.breakpoint.cc with local (Exim 4.84_2) (envelope-from ) id 1e9fdh-0005Et-Qs; Wed, 01 Nov 2017 00:08:09 +0100 Date: Wed, 1 Nov 2017 00:08:09 +0100 X-EEMSG-check-009: 444-444 From: Florian Westphal To: Paul Moore Message-ID: <20171031230809.GD7663@breakpoint.cc> References: <20171030145843.13496-1-sds@tycho.nsa.gov> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23 (2014-03-12) X-Mailman-Approved-At: Wed, 01 Nov 2017 08:16:45 -0400 Subject: Re: [RFC PATCH] xfrm: fix regression introduced by xdst pcpu cache X-BeenThere: selinux@tycho.nsa.gov X-Mailman-Version: 2.1.21 Precedence: list List-Id: "Security-Enhanced Linux \(SELinux\) mailing list" List-Post: List-Help: Cc: herbert@gondor.apana.org.au, netdev@vger.kernel.org, fw@strlen.de, linux-security-module@vger.kernel.org, selinux@tycho.nsa.gov, Stephen Smalley , davem@davemloft.net Errors-To: selinux-bounces@tycho.nsa.gov Sender: "Selinux" X-Virus-Scanned: ClamAV using ClamSMTP Paul Moore wrote: > On Mon, Oct 30, 2017 at 10:58 AM, Stephen Smalley wrote: > > matching before (as in this patch) or after calling xfrm_bundle_ok()? > > I would probably make the LSM call the last check, as you've done; but > I have to say that is just so it is consistent with the "LSM last" > philosophy and not because of any performance related argument. > > > ... Also, > > do we need to test xfrm->sel.family before calling xfrm_selector_match > > (as in this patch) or not - xfrm_state_look_at() does so when the > > state is XFRM_STATE_VALID but not when it is _ERROR or _EXPIRED? > > Speaking purely from a SELinux perspective, I'm not sure it matters: > as long as the labels match we are happy. However, from a general > IPsec perspective it does seem like a reasonable thing. > > Granted I'm probably missing something, but it seems a little odd that > the code isn't already checking that the selectors match (... what am > I missing?). It does check the policies, maybe that is enough in the > normal IPsec case? The assumption was that identical policies would yield the same SAs, but thats not correct. > > diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c > > index 2746b62..171818b 100644 > > --- a/net/xfrm/xfrm_policy.c > > +++ b/net/xfrm/xfrm_policy.c > > @@ -1820,6 +1820,11 @@ xfrm_resolve_and_create_bundle(struct xfrm_policy **pols, int num_pols, > > !xfrm_pol_dead(xdst) && > > memcmp(xdst->pols, pols, > > sizeof(struct xfrm_policy *) * num_pols) == 0 && > > + (!xdst->u.dst.xfrm->sel.family || > > + xfrm_selector_match(&xdst->u.dst.xfrm->sel, fl, > > + xdst->u.dst.xfrm->sel.family)) && > > + security_xfrm_state_pol_flow_match(xdst->u.dst.xfrm, > > + xdst->pols[0], fl) && ... so this needs to walk the bundle and validate each selector. Alternatively we could always do template resolution and then check that all states found match those of the old pcpu xdst: Tested-by: Stephen Smalley diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c @@ -1786,19 +1786,23 @@ void xfrm_policy_cache_flush(void) put_online_cpus(); } -static bool xfrm_pol_dead(struct xfrm_dst *xdst) +static bool xfrm_xdst_can_reuse(struct xfrm_dst *xdst, + struct xfrm_state * const xfrm[], + int num) { - unsigned int num_pols = xdst->num_pols; - unsigned int pol_dead = 0, i; + const struct dst_entry *dst = &xdst->u.dst; + int i; - for (i = 0; i < num_pols; i++) - pol_dead |= xdst->pols[i]->walk.dead; + if (xdst->num_xfrms != num) + return false; - /* Mark DST_OBSOLETE_DEAD to fail the next xfrm_dst_check() */ - if (pol_dead) - xdst->u.dst.obsolete = DST_OBSOLETE_DEAD; + for (i = 0; i < num; i++) { + if (!dst || dst->xfrm != xfrm[i]) + return false; + dst = dst->child; + } - return pol_dead; + return xfrm_bundle_ok(xdst); } static struct xfrm_dst * @@ -1812,26 +1816,28 @@ xfrm_resolve_and_create_bundle(struct xfrm_policy **pols, int num_pols, struct dst_entry *dst; int err; + /* Try to instantiate a bundle */ + err = xfrm_tmpl_resolve(pols, num_pols, fl, xfrm, family); + if (err <= 0) { + if (err != 0 && err != -EAGAIN) + XFRM_INC_STATS(net, LINUX_MIB_XFRMOUTPOLERROR); + return ERR_PTR(err); + } + xdst = this_cpu_read(xfrm_last_dst); if (xdst && xdst->u.dst.dev == dst_orig->dev && xdst->num_pols == num_pols && - !xfrm_pol_dead(xdst) && memcmp(xdst->pols, pols, sizeof(struct xfrm_policy *) * num_pols) == 0 && - xfrm_bundle_ok(xdst)) { + xfrm_xdst_can_reuse(xdst, xfrm, err)) { dst_hold(&xdst->u.dst); + while (err > 0) + xfrm_state_put(xfrm[--err]); return xdst; } old = xdst; - /* Try to instantiate a bundle */ - err = xfrm_tmpl_resolve(pols, num_pols, fl, xfrm, family); - if (err <= 0) { - if (err != 0 && err != -EAGAIN) - XFRM_INC_STATS(net, LINUX_MIB_XFRMOUTPOLERROR); - return ERR_PTR(err); - } dst = xfrm_bundle_create(pols[0], xfrm, err, fl, dst_orig); if (IS_ERR(dst)) {