From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756363AbcDDThQ (ORCPT ); Mon, 4 Apr 2016 15:37:16 -0400 Received: from mail-pf0-f180.google.com ([209.85.192.180]:34446 "EHLO mail-pf0-f180.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756347AbcDDThN (ORCPT ); Mon, 4 Apr 2016 15:37:13 -0400 Subject: Re: tty: memory leak in tty_open To: Dmitry Vyukov , Greg Kroah-Hartman References: Cc: Jiri Slaby , LKML , syzkaller , Kostya Serebryany , Alexander Potapenko , Sasha Levin From: Peter Hurley Message-ID: <5702C265.9070107@hurleysoftware.com> Date: Mon, 4 Apr 2016 12:37:09 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Dmitry, On 04/04/2016 01:56 AM, Dmitry Vyukov wrote: > Hello, > > The following program causes a memory leak: Thanks for the report. This is the same problem fixed in 4.5 There was a merge snafu; Greg has the patch in his queue that fixes this for 4.6 Regards, Peter Hurley > unreferenced object 0xffff8800643c3168 (size 2048): > comm "syz-executor", pid 29328, jiffies 4295358628 (age 32.380s) > hex dump (first 32 bytes): > 01 54 00 00 0c 00 00 00 88 27 e1 67 00 88 ff ff .T.......'.g.... > 88 1f 54 68 00 88 ff ff 40 b1 f0 86 ff ff ff ff ..Th....@....... > backtrace: > [] kmemleak_alloc+0x63/0xa0 mm/kmemleak.c:915 > [< inline >] kmemleak_alloc_recursive include/linux/kmemleak.h:47 > [< inline >] slab_post_alloc_hook mm/slab.h:406 > [< inline >] slab_alloc_node mm/slub.c:2602 > [< inline >] slab_alloc mm/slub.c:2610 > [] kmem_cache_alloc_trace+0x160/0x3d0 mm/slub.c:2627 > [< inline >] kmalloc include/linux/slab.h:478 > [< inline >] kzalloc include/linux/slab.h:622 > [] alloc_tty_struct+0x98/0x840 drivers/tty/tty_io.c:3156 > [] tty_init_dev+0x78/0x4b0 drivers/tty/tty_io.c:1532 > [< inline >] tty_open_by_driver drivers/tty/tty_io.c:2066 > [] tty_open+0xde1/0x1140 drivers/tty/tty_io.c:2114 > [] chrdev_open+0x22a/0x4c0 fs/char_dev.c:388 > [] do_dentry_open+0x6a2/0xcb0 fs/open.c:736 > [] vfs_open+0x17b/0x1f0 fs/open.c:853 > [< inline >] do_last fs/namei.c:3238 > [] path_openat+0x51bb/0x5ce0 fs/namei.c:3374 > [] do_filp_open+0x18e/0x250 fs/namei.c:3409 > [] do_sys_open+0x1fc/0x420 fs/open.c:1020 > [< inline >] SYSC_open fs/open.c:1038 > [] SyS_open+0x2d/0x40 fs/open.c:1033 > > > // autogenerated by syzkaller (http://github.com/google/syzkaller) > #include > #include > #include > > void* thr(void* arg) > { > syscall(SYS_open, "/dev/console", 0, 0, 0, 0); > return 0; > } > > int main() > { > int i; > pthread_t th[4]; > > for (i = 0; i < 4; i++) > pthread_create(&th[i], 0, thr, 0); > usleep(100); > return 0; > } > > > On commit 05cf8077e54b20dddb756eaa26f3aeb5c38dd3cf (Apr 1). >