From patchwork Sat Feb 6 23:17:07 2010 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: andrew hendry X-Patchwork-Id: 44734 X-Patchwork-Delegate: davem@davemloft.net Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 78B8BB7D15 for ; Sun, 7 Feb 2010 10:17:55 +1100 (EST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933466Ab0BFXRS (ORCPT ); Sat, 6 Feb 2010 18:17:18 -0500 Received: from mail-iw0-f189.google.com ([209.85.223.189]:61894 "EHLO mail-iw0-f189.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756370Ab0BFXRH (ORCPT ); Sat, 6 Feb 2010 18:17:07 -0500 Received: by mail-iw0-f189.google.com with SMTP id 27so807891iwn.5 for ; Sat, 06 Feb 2010 15:17:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:received:date:message-id:subject :from:to:content-type; bh=uFjzKV221XtQikoD0xhoKxal6OQ9aFnTfV5BAnD1xvM=; b=PAcRv0Q+zDZKTyu/q6CMrvr7YMLB2dAZJF37XGCFA5xjY4UjVbzGIe2DovaMfIS4oZ kFriZ06h3U8aOVzB02pj/b3fWNsZR3FBFFtqjLFiD91Hil3zZ1EE32EdW7RxlxTQXEUs EbuSVyxPZdon6b6L3Jo5eoRWDS5SkfRpNiops= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:date:message-id:subject:from:to:content-type; b=gmjHHneARsL8cPCgqywXUa2qiVUPLalNxcusY0/NS8aT8BfTdHh31oZsSF/U2jHaEO MWmR3DjRc5JSS0Xe135D4mA/Mf37DGa9UF3btlnY3U6hJGNTzlaaxWNz1os4yRx6E6ql 5JKhkmKVZnaV3xdsoPCX9Z6QFYahfanQ/jj2s= MIME-Version: 1.0 Received: by 10.231.149.201 with SMTP id u9mr3020235ibv.1.1265498227151; Sat, 06 Feb 2010 15:17:07 -0800 (PST) Date: Sun, 7 Feb 2010 10:17:07 +1100 Message-ID: Subject: [PATCH 2/2] X25: Dont let x25_bind use addresses containing characters From: andrew hendry To: netdev@vger.kernel.org, linux-kernel Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Addresses should be all digits. Stops x25_bind using addresses containing characters. Signed-off-by: Andrew Hendry --- if (!sock_flag(sk, SOCK_ZAPPED) || @@ -658,6 +659,14 @@ static int x25_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len) goto out; } + len = strlen(addr->sx25_addr.x25_addr); + for (i = 0; i < len; i++) { + if (!isdigit(addr->sx25_addr.x25_addr[i])) { + rc = -EINVAL; + goto out; + } + } + x25_sk(sk)->source_addr = addr->sx25_addr; x25_insert_socket(sk); sock_reset_flag(sk, SOCK_ZAPPED); diff --git a/net/x25/af_x25.c b/net/x25/af_x25.c index 6c7104e..8cc7583 100644 --- a/net/x25/af_x25.c +++ b/net/x25/af_x25.c @@ -55,6 +55,7 @@ #include #include #include +#include #include #include @@ -648,7 +649,7 @@ static int x25_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len) { struct sock *sk = sock->sk; struct sockaddr_x25 *addr = (struct sockaddr_x25 *)uaddr; - int rc = 0; + int len, i, rc = 0; lock_kernel();