Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Thu, 27 Feb 2003 09:30:15 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Thu, 27 Feb 2003 09:30:15 -0500 Received: from e33.co.us.ibm.com ([32.97.110.131]:63735 "EHLO e33.co.us.ibm.com") by vger.kernel.org with ESMTP id ; Thu, 27 Feb 2003 09:30:13 -0500 Content-Type: text/plain; charset=US-ASCII From: Kevin Corry Organization: IBM To: Horst von Brand , Joe Thornber Subject: Re: [PATCH 3/8] dm: prevent possible buffer overflow in ioctl interface Date: Thu, 27 Feb 2003 08:36:53 -0600 X-Mailer: KMail [version 1.2] Cc: Linus Torvalds , Linux Mailing List References: <200302262104.h1QL4aiC001941@eeyore.valparaiso.cl> <03022708205903.05199@boiler> In-Reply-To: <03022708205903.05199@boiler> MIME-Version: 1.0 Message-Id: <03022708365304.05199@boiler> Content-Transfer-Encoding: 7BIT Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1978 Lines: 55 On Thursday 27 February 2003 08:20, Kevin Corry wrote: > On Wednesday 26 February 2003 15:04, Horst von Brand wrote: > > Joe Thornber said: > > > Use the correct size for "name" in register_with_devfs(). > > > > > > During Al Viro's devfs cleanup a few versions ago, this function was > > > rewritten, and the "name" string added. The 32-byte size is not large > > > enough to prevent a possible buffer overflow in the sprintf() call, > > > since the hash cell can have a name up to 128 characters. > > > > > > [Kevin Corry] > > > > > > --- diff/drivers/md/dm-ioctl.c 2003-02-26 16:09:42.000000000 +0000 > > > +++ source/drivers/md/dm-ioctl.c 2003-02-26 16:09:52.000000000 +0000 > > > @@ -173,7 +173,7 @@ > > > */ > > > static int register_with_devfs(struct hash_cell *hc) > > > { > > > - char name[32]; > > > + char name[DM_NAME_LEN + strlen(DM_DIR) + 1]; > > > > This either makes a large name array or generates a possibly huge array > > at runtime (bad if your stack is < 8KiB). > > Would this be better? As Joe pointed out to me, that should have been: --- linux-2.5.60a/drivers/md/dm-ioctl.c 2003/02/13 16:43:26 +++ linux-2.5.60b/drivers/md/dm-ioctl.c 2003/02/27 14:35:20 @@ -173,14 +173,18 @@ */ static int register_with_devfs(struct hash_cell *hc) { - char name[DM_NAME_LEN + strlen(DM_DIR) + 1]; struct gendisk *disk = dm_disk(hc->md); + char *name = kmalloc(DM_NAME_LEN + strlen(DM_DIR) + 1); + if (!name) { + return -ENOMEM; + } sprintf(name, DM_DIR "/%s", hc->name); devfs_register(NULL, name, DEVFS_FL_CURRENT_OWNER, disk->major, disk->first_minor, S_IFBLK | S_IRUSR | S_IWUSR | S_IRGRP, &dm_blk_dops, NULL); + kfree(name); return 0; } - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/