Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3688032imm; Mon, 18 Jun 2018 02:18:42 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKIQL5cVtlNg2uDDgiOaIVbxQq3cQwfbUEAeFEuWkKt2YeCECz4jqRJIBKnLWfvUNBoJ/Oz X-Received: by 2002:a62:8f8c:: with SMTP id n134-v6mr12742905pfd.66.1529313522086; Mon, 18 Jun 2018 02:18:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529313522; cv=none; d=google.com; s=arc-20160816; b=BV2RkfQD5oq9W73fDVmXru08dx7ZWtGLcpB41wHCYJKQ9PiM9zdkZAMt9KvOzpvX2R wthd9Xdy2XEjuiyNOWHMOuIi+IDQlzNx3cf0ygnKTHrxAfMgv4qDPdvmboqHcM9Ak7PB x4wQWrAtreS35rwnO6hXCVhP1I0sWUJ6I5czyb7+X24xpqfKhZ8OwyucYOKH5Zu5UJ/U 7DTa9SCu8JeWMnzCMk2IrpT2qZ5xmrdnygnYA7aVF7IIFvxN1Kbi4BH1JJVGyCErhWPP Po/uRqdkZ7EiK957FY+rhwuqVuWGLGIryar3xPHHzqh1DmChHQW+citla0XJbfAuTwUV R6cg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=a3Ih94Waiai0Ps2qW0XDVb+HydbRF3c3/RZMm5BG0v4=; b=l47h8/1v096HvLyGaCWZSsNIxC4sa5d0RvQI3UjVL8rub3NKQiOFl3pD/Y/2SZRv+R pCLYun+g96+BF5vHmx+O/PzQiQ4Exlt8y7jLJRvqHhbIxd1CDgAooT6usH3fG06ypd4P VWW1jVrfgYOqiEXHhaRL2rQTv1I9x4EsBaiu5m7c10ybkiLM5+XKUBihl02nKa7nPK41 0TruIZw9eIWPg9OzGzuv8o/NUMjz9xkbbV8+8QqjMAS7NjsYVJRpsojJAt9VnGm0Wf1D vIscFNktMPwfcub8pU0Mjo91l5n2EN2DXCeTsGsVPymbRQrXqyo69fZz42om68m1Z2Da R7Xg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f20-v6si11598844pgn.464.2018.06.18.02.18.28; Mon, 18 Jun 2018 02:18:42 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S966610AbeFRI2Q (ORCPT + 99 others); Mon, 18 Jun 2018 04:28:16 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:59074 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966579AbeFRI2N (ORCPT ); Mon, 18 Jun 2018 04:28:13 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id F09CECEF; Mon, 18 Jun 2018 08:28:12 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, David Howells , Sasha Levin Subject: [PATCH 4.16 248/279] afs: Fix address list parsing Date: Mon, 18 Jun 2018 10:13:53 +0200 Message-Id: <20180618080619.024537548@linuxfoundation.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20180618080608.851973560@linuxfoundation.org> References: <20180618080608.851973560@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.16-stable review patch. If anyone has any objections, please let me know. ------------------ From: David Howells [ Upstream commit 01fd79e6de74a447c5657913a335d9ce6508cdb1 ] The parsing of port specifiers in the address list obtained from the DNS resolution upcall doesn't work as in4_pton() and in6_pton() will fail on encountering an unexpected delimiter (in this case, the '+' marking the port number). However, in*_pton() can't be given multiple specifiers. Fix this by finding the delimiter in advance and not relying on in*_pton() to find the end of the address for us. Fixes: 8b2a464ced77 ("afs: Add an address list concept") Signed-off-by: David Howells Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- fs/afs/addr_list.c | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) --- a/fs/afs/addr_list.c +++ b/fs/afs/addr_list.c @@ -121,7 +121,7 @@ struct afs_addr_list *afs_parse_text_add p = text; do { struct sockaddr_rxrpc *srx = &alist->addrs[alist->nr_addrs]; - char tdelim = delim; + const char *q, *stop; if (*p == delim) { p++; @@ -130,28 +130,33 @@ struct afs_addr_list *afs_parse_text_add if (*p == '[') { p++; - tdelim = ']'; + q = memchr(p, ']', end - p); + } else { + for (q = p; q < end; q++) + if (*q == '+' || *q == delim) + break; } - if (in4_pton(p, end - p, + if (in4_pton(p, q - p, (u8 *)&srx->transport.sin6.sin6_addr.s6_addr32[3], - tdelim, &p)) { + -1, &stop)) { srx->transport.sin6.sin6_addr.s6_addr32[0] = 0; srx->transport.sin6.sin6_addr.s6_addr32[1] = 0; srx->transport.sin6.sin6_addr.s6_addr32[2] = htonl(0xffff); - } else if (in6_pton(p, end - p, + } else if (in6_pton(p, q - p, srx->transport.sin6.sin6_addr.s6_addr, - tdelim, &p)) { + -1, &stop)) { /* Nothing to do */ } else { goto bad_address; } - if (tdelim == ']') { - if (p == end || *p != ']') - goto bad_address; + if (stop != q) + goto bad_address; + + p = q; + if (q < end && *q == ']') p++; - } if (p < end) { if (*p == '+') {