reproducible panic in netisr
    Robert Watson 
    rwatson at FreeBSD.org
       
    Thu Aug  6 16:33:23 UTC 2009
    
    
  
On Thu, 6 Aug 2009, Rick Macklem wrote:
> On Thu, 6 Aug 2009, Robert Watson wrote:
>
>> other places where we have very strong alignment requirements on 
>> i386/amd64, such as the td_ucred pointer that we check for change on system 
>> calls/traps to see if we need to refresh the thread's credential from the 
>> process credential.
>> 
> Does this imply that the nfs/krpc hack of:
> 	oldcred = td->td_ucred;
> 	td->td_ucred = "some other cred ptr"
> 	...
> 	td->td_ucred = oldcred;
>
> could be dangerous?
>
> Maybe it should be converted to code that replaces the contents instead of 
> replacing the *cred? (Variants of the above live in a bunch of places in the 
> krpc, nlm and nfs code, due to the fact that the socket functions use 
> td->td_ucred in various places.)
td->td_ucred is a thread-local variable, meaning that it will only be accessed 
and modified from the current thread.  So the above construct is fine.  Also, 
struct thread should be properly aligned. :-)
Robert N M Watson
Computer Laboratory
University of Cambridge
    
    
More information about the freebsd-current
mailing list