- 
                Notifications
    You must be signed in to change notification settings 
- Fork 717
Close file descriptor on drop in TimerFd #1381
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch about Clone.  I think there may be some other structs that have that problem; I'll check for them.
A few requests:
- The drop implementation should panic on EBADF, because that usually indicates a double-close.
- Document somewhere that this type closes on drop.
- Don't forget to add a CHANGELOG entry!
| I believe I've addressed the suggested changes. | 
        
          
                CHANGELOG.md
              
                Outdated
          
        
      | - Added limited Fuchsia support (#[1285](https://github.com/nix-rust/nix/pull/1285)) | ||
| - Added `getpeereid` (#[1342](https://github.com/nix-rust/nix/pull/1342)) | ||
| ### Fixed | ||
| - TimerFd now closes the underlying fd on drop. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, in the "Removed" section you should note that is no longer Clone and Copy.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
        
          
                src/sys/timerfd.rs
              
                Outdated
          
        
      | libc::close(self.fd) | ||
| }); | ||
| if let Err(Error::Sys(Errno::EBADF)) = result { | ||
| panic!("close of TimerFd encountered EBADF"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One problem: panicking during drop is usually bad, because drop itself gets called during panic.  A double-panic is difficult to debug.  Instead, you should only panic if the thread isn't already panicking.  In fact, you don't even need to close when panicking, because the process is about to abort anyway.  So I would write this as
if !std::thread::panicking() {
    //close the file descriptor, panicking on EBADF
}There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The file descriptor is now only closed if the thread isn't already panicking.
| Would you mind squashing your commits? We can't do this with Github's merge button because we use bors. | 
43799bd    to
    c33fa74      
    Compare
  
    | 
 This is done. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
bors r+
This change closes the TimerFd file descriptor on drop. Note that the TimerFd will no longer be
CloneorCopy. Since it has a destructor it can't beCopy, and if it wereCloneyou could end up trying to use a closed TimerFd, or double-closing the file descriptor.Addresses #1379.