From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753966AbYL1SSZ (ORCPT ); Sun, 28 Dec 2008 13:18:25 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754664AbYL1SR5 (ORCPT ); Sun, 28 Dec 2008 13:17:57 -0500 Received: from brick.kernel.dk ([93.163.65.50]:17076 "EHLO kernel.dk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754073AbYL1SR4 (ORCPT ); Sun, 28 Dec 2008 13:17:56 -0500 Date: Sun, 28 Dec 2008 19:17:06 +0100 From: Jens Axboe To: eagle black Cc: Linus Torvalds , Linux Kernel Mailing List , Russell King Subject: Re: [BUG] It seems that i found a bug in the linux kernel, and it also in the newest kernel version Message-ID: <20081228181706.GW32491@kernel.dk> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Dec 26 2008, eagle black wrote: > let's see, int the function elevator_init of block/elevator.c , > if the function elevator_init_queue failed for some reason, and the memory > of elevator_alloc alloced does not free! > > int elevator_init(struct request_queue *q, char *name) > { > struct elevator_type *e = NULL; > struct elevator_queue *eq; > int ret = 0; > void *data; > > INIT_LIST_HEAD(&q->queue_head); > q->last_merge = NULL; > q->end_sector = 0; > q->boundary_rq = NULL; > > if (name) { > e = elevator_get(name); > if (!e) > return -EINVAL; > } > > if (!e && *chosen_elevator) { > e = elevator_get(chosen_elevator); > if (!e) > printk(KERN_ERR "I/O scheduler %s not found\n", > chosen_elevator); > } > > if (!e) { > e = elevator_get(CONFIG_DEFAULT_IOSCHED); > if (!e) { > printk(KERN_ERR > "Default I/O scheduler not found. " \ > "Using noop.\n"); > e = elevator_get("noop"); > } > } > > eq = elevator_alloc(q, e); > if (!eq) > return -ENOMEM; > > data = elevator_init_queue(q, eq); > if (!data) { > kobject_put(&eq->kobj); See the kobject_put() there. It'll put the one and only reference to this kobject, which wil end up in elevator_release() that then frees 'eq' (called 'e' there). -- Jens Axboe