. all invocations were S or D, so can safely be dropped to prepare for the segmentless world . still assign D to the SCP_SEG field in the message to make previous kernels usable
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* VTreeFS - link.c - by Alen Stojanov and David van Moolenbroek */
 | 
						|
 | 
						|
#include "inc.h"
 | 
						|
 | 
						|
/*===========================================================================*
 | 
						|
 *				fs_rdlink				     *
 | 
						|
 *===========================================================================*/
 | 
						|
int fs_rdlink(void)
 | 
						|
{
 | 
						|
	/* Retrieve symbolic link target.
 | 
						|
	 */
 | 
						|
	char path[PATH_MAX];
 | 
						|
	struct inode *node;
 | 
						|
	size_t len;
 | 
						|
	int r;
 | 
						|
 | 
						|
	if ((node = find_inode(fs_m_in.REQ_INODE_NR)) == NULL)
 | 
						|
		return EINVAL;
 | 
						|
 | 
						|
	/* Call the rdlink hook. */
 | 
						|
	assert(vtreefs_hooks->rdlink_hook != NULL);
 | 
						|
	assert(!is_inode_deleted(node));	/* symlinks cannot be opened */
 | 
						|
 | 
						|
	r = vtreefs_hooks->rdlink_hook(node, path, sizeof(path),
 | 
						|
		get_inode_cbdata(node));
 | 
						|
	if (r != OK) return r;
 | 
						|
 | 
						|
	len = strlen(path);
 | 
						|
	assert(len > 0 && len < sizeof(path));
 | 
						|
 | 
						|
	if (len > fs_m_in.REQ_MEM_SIZE)
 | 
						|
		len = fs_m_in.REQ_MEM_SIZE;
 | 
						|
 | 
						|
	/* Copy out the result. */
 | 
						|
	r = sys_safecopyto(fs_m_in.m_source, fs_m_in.REQ_GRANT, 0,
 | 
						|
		(vir_bytes) path, len);
 | 
						|
	if (r != OK) return r;
 | 
						|
 | 
						|
	fs_m_out.RES_NBYTES = len;
 | 
						|
	return OK;
 | 
						|
}
 |