Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S264781AbUFTA0A (ORCPT ); Sat, 19 Jun 2004 20:26:00 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S264782AbUFTAZ7 (ORCPT ); Sat, 19 Jun 2004 20:25:59 -0400 Received: from dragnfire.mtl.istop.com ([66.11.160.179]:24805 "EHLO dsl.commfireservices.com") by vger.kernel.org with ESMTP id S264781AbUFTAZy (ORCPT ); Sat, 19 Jun 2004 20:25:54 -0400 Date: Sat, 19 Jun 2004 20:27:57 -0400 (EDT) From: Zwane Mwaikambo To: Christophe Saout Cc: Brice Goglin , Linux Kernel Subject: Re: 2.6.7 Samba OOPS (in smb_readdir) In-Reply-To: Message-ID: References: <20040618163759.GN1146@ens-lyon.fr> <20040618164125.GO1146@ens-lyon.fr> <1087585251.13235.3.camel@leto.cs.pocnet.net> <1087586532.9085.1.camel@leto.cs.pocnet.net> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4277 Lines: 136 On Sat, 19 Jun 2004, Zwane Mwaikambo wrote: > On Sat, 19 Jun 2004, Zwane Mwaikambo wrote: > > > On Fri, 18 Jun 2004, Christophe Saout wrote: > > > > > Well, it's not. :( > > > > > > The oops is gone but the processes are still hanging. I'm posting the > > > SysRq-T trace on bugzilla. Hope it helps. If you need some help > > > debugging the problem, please tell me if I can do something. > > > > This is an updated debugging patch (which is also added to Bugzilla), > > please give this a spin. There are still a few issues with this patch but > > lets try at least avoid oopsing for now. > > Hold on, this is buggy garbage. i'll have something in a bit. Index: linux-2.6.7/include/linux/smb_fs_sb.h =================================================================== RCS file: /home/cvsroot/linux-2.6.7/include/linux/smb_fs_sb.h,v retrieving revision 1.1.1.1 diff -u -p -B -r1.1.1.1 smb_fs_sb.h --- linux-2.6.7/include/linux/smb_fs_sb.h 16 Jun 2004 16:49:26 -0000 1.1.1.1 +++ linux-2.6.7/include/linux/smb_fs_sb.h 20 Jun 2004 00:06:45 -0000 @@ -57,7 +57,8 @@ struct smb_sb_info { unsigned int generation; pid_t conn_pid; struct smb_conn_opt opt; - + wait_queue_head_t conn_wq; + int conn_complete; struct semaphore sem; unsigned short rcls; /* The error codes we received */ Index: linux-2.6.7/fs/smbfs/inode.c =================================================================== RCS file: /home/cvsroot/linux-2.6.7/fs/smbfs/inode.c,v retrieving revision 1.1.1.1 diff -u -p -B -r1.1.1.1 inode.c --- linux-2.6.7/fs/smbfs/inode.c 16 Jun 2004 16:49:47 -0000 1.1.1.1 +++ linux-2.6.7/fs/smbfs/inode.c 19 Jun 2004 21:19:04 -0000 @@ -521,6 +521,7 @@ int smb_fill_super(struct super_block *s server->super_block = sb; server->mnt = NULL; server->sock_file = NULL; + init_waitqueue_head(&server->conn_wq); init_MUTEX(&server->sem); INIT_LIST_HEAD(&server->entry); INIT_LIST_HEAD(&server->xmitq); Index: linux-2.6.7/fs/smbfs/proc.c =================================================================== RCS file: /home/cvsroot/linux-2.6.7/fs/smbfs/proc.c,v retrieving revision 1.1.1.1 diff -u -p -B -r1.1.1.1 proc.c --- linux-2.6.7/fs/smbfs/proc.c 16 Jun 2004 16:49:47 -0000 1.1.1.1 +++ linux-2.6.7/fs/smbfs/proc.c 20 Jun 2004 00:26:57 -0000 @@ -56,6 +56,7 @@ static struct smb_ops smb_ops_os2; static struct smb_ops smb_ops_win95; static struct smb_ops smb_ops_winNT; static struct smb_ops smb_ops_unix; +static struct smb_ops smb_ops_null; static void smb_init_dirent(struct smb_sb_info *server, struct smb_fattr *fattr); @@ -981,6 +982,9 @@ smb_newconn(struct smb_sb_info *server, smbiod_wake_up(); if (server->opt.capabilities & SMB_CAP_UNIX) smb_proc_query_cifsunix(server); + + server->conn_complete++; + wake_up_interruptible_all(&server->conn_wq); return error; out: @@ -2794,10 +2798,45 @@ out: } static int +smb_proc_ops_wait(struct smb_sb_info *server) +{ + int result; + + result = wait_event_interruptible_timeout(server->conn_wq, + server->conn_complete, 30*HZ); + + if (!result || signal_pending(current)) + return -EIO; + + return 0; +} + +static int smb_proc_getattr_null(struct smb_sb_info *server, struct dentry *dir, - struct smb_fattr *attr) + struct smb_fattr *fattr) { - return -EIO; + int result; + + if (smb_proc_ops_wait(server) < 0) + return -EIO; + + smb_init_dirent(server, fattr); + result = server->ops->getattr(server, dir, fattr); + smb_finish_dirent(server, fattr); + + return result; +} + +static int +smb_proc_readdir_null(struct file *filp, void *dirent, filldir_t filldir, + struct smb_cache_control *ctl) +{ + struct smb_sb_info *server = server_from_dentry(filp->f_dentry); + + if (smb_proc_ops_wait(server) < 0) + return -EIO; + + return server->ops->readdir(filp, dirent, filldir, ctl); } int @@ -3431,6 +3470,7 @@ static struct smb_ops smb_ops_unix = /* Place holder until real ops are in place */ static struct smb_ops smb_ops_null = { + .readdir = smb_proc_readdir_null, .getattr = smb_proc_getattr_null, }; - 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/