Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 31 Dec 2015 14:47:45 +0000 (UTC)
From:      Hans Petter Selasky <hselasky@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r292989 - head/sys/compat/linuxkpi/common/include/linux
Message-ID:  <201512311447.tBVEljHv035688@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: hselasky
Date: Thu Dec 31 14:47:45 2015
New Revision: 292989
URL: https://svnweb.freebsd.org/changeset/base/292989

Log:
  Handle when filedescriptors are closed before initialized. An early
  fdclose() call can cause fget_unlocked() to fail.
  
  Found by:	mjg @
  MFC after:	1 week
  Reviewed by:	Mark Block <markb@mellanox.com>
  Sponsored by:	Mellanox Technologies
  Differential Revision:	https://reviews.freebsd.org/D4351

Modified:
  head/sys/compat/linuxkpi/common/include/linux/file.h

Modified: head/sys/compat/linuxkpi/common/include/linux/file.h
==============================================================================
--- head/sys/compat/linuxkpi/common/include/linux/file.h	Thu Dec 31 14:39:45 2015	(r292988)
+++ head/sys/compat/linuxkpi/common/include/linux/file.h	Thu Dec 31 14:47:45 2015	(r292989)
@@ -101,10 +101,11 @@ fd_install(unsigned int fd, struct linux
 
 	if (fget_unlocked(curthread->td_proc->p_fd, fd,
 	    cap_rights_init(&rights), &file, NULL) != 0) {
-		file = NULL;
+		filp->_file = NULL;
+	} else {
+		filp->_file = file;
+		finit(file, filp->f_mode, DTYPE_DEV, filp, &linuxfileops);
 	}
-	filp->_file = file;
-	finit(file, filp->f_mode, DTYPE_DEV, filp, &linuxfileops);
 
 	/* drop the extra reference */
 	fput(filp);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201512311447.tBVEljHv035688>