. vfs read_only() assumes vnode->v_vmnt is non-NULL, but it can be NULL sometimes . e.g. fchmod() on UDS triggered NULL deref; add a check and add REQ_CHMOD to pfs so unix domain sockets can be fchmod()ded . add to test56 Change-Id: I83c840f101b647516897cc99fcf472116d762012
		
			
				
	
	
		
			29 lines
		
	
	
		
			978 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
		
			978 B
		
	
	
	
		
			C
		
	
	
	
	
	
#include "fs.h"
 | 
						|
#include "inode.h"
 | 
						|
 | 
						|
 | 
						|
/*===========================================================================*
 | 
						|
 *				fs_sync					     *
 | 
						|
 *===========================================================================*/
 | 
						|
int fs_sync(message *fs_m_in, message *fs_m_out)
 | 
						|
{
 | 
						|
/* Perform the sync() system call.  No-op on this FS. */
 | 
						|
 | 
						|
  return(OK);		/* sync() can't fail */
 | 
						|
}
 | 
						|
 | 
						|
/*===========================================================================*
 | 
						|
 *                             fs_chmod					     *
 | 
						|
 *===========================================================================*/
 | 
						|
int fs_chmod(message *fs_m_in, message *fs_m_out)
 | 
						|
{
 | 
						|
  struct inode *rip;  /* target inode */
 | 
						|
  mode_t mode = (mode_t) fs_m_in->REQ_MODE;
 | 
						|
 | 
						|
  if( (rip = find_inode(fs_m_in->REQ_INODE_NR)) == NULL) return(EINVAL);
 | 
						|
  get_inode(rip->i_dev, rip->i_num);	/* mark inode in use */
 | 
						|
  rip->i_mode = (rip->i_mode & ~ALL_MODES) | (mode & ALL_MODES);
 | 
						|
  put_inode(rip);			/* release the inode */
 | 
						|
  return OK;
 | 
						|
}
 |