svn commit: r292989 - head/sys/compat/linuxkpi/common/include/linux

Hans Petter Selasky hselasky at FreeBSD.org
Thu Dec 31 14:47:46 UTC 2015


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 at 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);


More information about the svn-src-all mailing list