Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 14 Nov 2006 02:00:15 GMT
From:      Adam Martin <adamartin@FreeBSD.org>
To:        Perforce Change Reviews <perforce@FreeBSD.org>
Subject:   PERFORCE change 109900 for review
Message-ID:  <200611140200.kAE20FLc089899@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=109900

Change 109900 by adamartin@adamartin_hobbes on 2006/11/14 01:59:39

	Adding autofs_subr.[ch] for using circular queue mechanisms.  Importing
	updated versions of macro headers, and adding more autofs_ctl device
	support.

Affected files ...

.. //depot/projects/soc2006/adamartin_autofs/autofs/Makefile#4 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/README#3 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs.c#5 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs.h#5 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_ctl.c#4 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_ctl.h#3 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_dev.c#4 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_dev.h#2 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_pfsops.c#4 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_subr.c#1 add
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_subr.h#1 add
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_vfsops.c#5 delete
.. //depot/projects/soc2006/adamartin_autofs/autofs/autofs_vnops.c#4 delete
.. //depot/projects/soc2006/adamartin_autofs/autofs/cleanup.h#5 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/protocol.c#4 edit
.. //depot/projects/soc2006/adamartin_autofs/autofs/protocol.h#4 edit
.. //depot/projects/soc2006/adamartin_autofs/pseudofs/pseudofs.h#2 edit
.. //depot/projects/soc2006/adamartin_autofs/pseudofs/pseudofs_vnops.c#3 edit

Differences ...

==== //depot/projects/soc2006/adamartin_autofs/autofs/Makefile#4 (text+ko) ====


==== //depot/projects/soc2006/adamartin_autofs/autofs/README#3 (text+ko) ====


==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs.c#5 (text+ko) ====

@@ -50,13 +50,10 @@
 #include "autofs.h"
 #include "autofs_ctl.h"
 
-
-
+#include "debug.h"
 
 
 
-/** There's no more block devices, so all are cdevs, as c represents char
-in cdev **/
 
 
 
@@ -65,19 +62,20 @@
 autofs_handle_loader( struct module *mod, int action, void *args )
 {
 	int err= 0;
-	switch (action) {
+	switch( action )
+	{
 		case MOD_LOAD:
-			KPRINTF("Now loading AutoFS module: \n");
-			autofs_ctl_dev = make_dev(&autofs_ctl_devops,
-			00,
-			UID_ROOT,
-			GID_WHEEL,
-			0600,
-			AUTOFS_CTL_DEV_NAME);
-			DEBUG KPRINTF(".");
+			EPRINTF( "Now loading AutoFS module: \n" );
+			autofs_ctl_dev = make_dev( &autofs_ctl_devops,
+					00,
+					UID_ROOT,
+					GID_WHEEL,
+					0600,
+					AUTOFS_CTL_DEV_NAME );
+			DEBUG EPRINTF( "." );
 			autofs_ctl_init();
-			DEBUG KPRINTF(".");
-			KPRINTF("AutoFS module successfully loaded.\n");
+			DEBUG EPRINTF( "." );
+			EPRINTF( "AutoFS module successfully loaded.\n" );
 			break;
 
 		case MOD_QUIESCE:
@@ -86,22 +84,23 @@
 			 * Find out what we should do for QUIESCE option?
 			 *
 			 */
-			KPRINTF("AutoFS quiesced.\n");
+			EPRINTF( "AutoFS quiesced.\n" );
 
 			return 0;
+			break;
 
 		case MOD_UNLOAD:
-			destroy_dev(autofs_ctl_dev);
-			//free(autofs_ctl_state, M_AUTOFS_CTL_NODES);
-			KPRINTF("AutoFS unloaded.\n");
+			destroy_dev( autofs_ctl_dev );
+			//free( autofs_ctl_state, M_AUTOFS_CTL_NODES );
+			EPRINTF( "AutoFS unloaded.\n" );
 			break;
 
 		default:
 			err= EINVAL;
-			KPRINTF("Error -- action %d not supported!\n",
-				action);
-			KPRINTF("MOD_LOAD= %d, MOD_UNLOAD= %d\n",
-					MOD_LOAD, MOD_UNLOAD);
+			EPRINTF( "Error -- action %d not supported!\n",
+					action );
+			EPRINTF( "MOD_LOAD= %d, MOD_UNLOAD= %d\n",
+					MOD_LOAD, MOD_UNLOAD );
 			break;
 
 	}
@@ -110,30 +109,36 @@
 
 
 
-int vn_iscdev(struct vnode *vp, int *errp);
+int vn_iscdev( struct vnode *vp, int *errp );
 
 int
-vn_iscdev(struct vnode *vp, int *errp)
+vn_iscdev( struct vnode *vp, int *errp )
 {
-	int error = 0;
+	$cleanup_init_size( 8 );
+	int error= 0;
 
-	dev_lock();
+	dev_lock(); 
+	$cleanup( dev_unlock(); );
+	
 
-	if (vp->v_type != VCHR)
+	if( vp->v_type != VCHR )
 		error = ENODEV;
 
 	#ifdef USE_EXTENDED_DEV_CHECK
-	else if (vp->v_rdev == NULL)
-		error = ENXIO;
-	else if (vp->v_rdev->si_devsw == NULL)
-		error = ENXIO;
+	else if( vp->v_rdev == NULL )
+	{
+		error= ENXIO;
+	}
+	else if( vp->v_rdev->si_devsw == NULL )
+	{
+		error= ENXIO;
+	}
 	#endif
-	dev_unlock();
-
+	$do_cleanup;
 
 	if (errp != NULL)
-		*errp = error;
-	return (error == 0);
+		*errp= error;
+	$return ( error == 0 );
 }
 
 DEV_MODULE( AutoFS, autofs_handle_loader, NULL );

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs.h#5 (text+ko) ====

@@ -30,7 +30,13 @@
 #ifndef	__AUTOFS_MAIN_HEADER__
 #define	__AUTOFS_MAIN_HEADER__
 
+#define	USE_SETJMP_CLEANUP
+#define NO_USE_SETJMP_INCLUDE
+#define NO_CLEANUP_WARNING
+#define FREEBSD_SYS
+#include "cleanup.h"
 
+
 #define		AUTOFS_VERSION		( 1 )
 
 //#define		MIN( a, b )		( ( a ) < ( b ) ? ( a ) : ( b ) )
@@ -41,34 +47,6 @@
 //#define NO_CLEANUP_WARNING
 
 
-#define KPRINTF( a, ... )	\
-			do {\
-				printf( a, ## __VA_ARGS__ );\
-				uprintf( a, ## __VA_ARGS__ );\
-			} while( 0 )
-
-
-
-#ifndef	DEBUG_LEVEL
-#define	DEBUG_LEVEL	8
-#endif	/** DEBUG_LEVEL **/
-
-#define DEBUG_L( level )		if( DEBUG_LEVEL >= level ) 
-
-#define DEBUG	DEBUG5
-
-#define DEBUG1 DEBUG_L( 1 )
-#define DEBUG2 DEBUG_L( 2 )
-#define DEBUG3 DEBUG_L( 3 )
-#define DEBUG4 DEBUG_L( 4 )
-#define DEBUG5 DEBUG_L( 5 )
-#define DEBUG6 DEBUG_L( 6 )
-#define DEBUG7 DEBUG_L( 7 )
-#define DEBUG8 DEBUG_L( 8 )
-
-
-
-
 #define MNT_TARGET		( "fspath" )
 #define MNT_DEVICE		( "from" )
 
@@ -76,8 +54,9 @@
 
 
 #define	entity( member,	value )\
-		.member = value
+		.member= value
 
 
+#define KPRINTF	EPRINTF
 
 #endif	/*** __AUTOFS_MAIN_HEADER__ ***/

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs_ctl.c#4 (text+ko) ====

@@ -50,7 +50,7 @@
 
 static d_ioctl_t autofs_ctl_ioctl;
 
-struct cdevsw autofs_ctl_devops = {
+static struct cdevsw autofs_ctl_devops = {
 	.d_version= D_VERSION,
 	.d_open= NULL,
 	.d_close= NULL,
@@ -63,8 +63,48 @@
 int
 autofs_ctl_init()
 {
-	DEBUG KPRINTF("Initializing "
+	DEBUG KPRINTF( "Initializing " )
+}
+
+MALLOC_DECLARE( M_AUTOFS_DEV );
+MALLOC_DEFINE( M_AUTOFS_DEV, "autofs_dev", "autofs device structure" );
+
+MALLOC_DECLARE( M_AUTOFS_DEV_BUFFERS );
+MALLOC_DEFINE( M_AUTOFS_DEV_BUFFERS, "autofs_dev_buffers", "autofs device io buffers" );
+
+int create_autofs_node( int num )
+{
+	int error;
+	struct cdevsw *autofs_cdevsw;
+	struct cdev *autofs_cdev;
+	struct autofs_dev_data *autofs_dev_data;
+
+	autofs_cdevsw= malloc( sizeof( struct cdevsw ), M_AUTOFS_DEV, M_WAITOK );
+	autofs_dev_data= malloc( sizeof( struct autofs_dev_data ), M_AUTOFS_DEV_BUFFERS,
+			M_WAITOK );
+
+	autofs_dev_data.input= malloc( IOV_BUF_COUNT * sizeof( struct iovec * ), M_AUTOFS_DEV_BUFFERS, M_WAITOK );
+	autofs_dev_data.output= malloc( IOV_BUF_COUNT * sizeof( struct iovec * ), M_AUTOFS_DEV_BUFFERS, M_WAITOK );
+
+	autofs_cdevsw->d_open= autofs_dev_open;
+	autofs_cdevsw->d_close= autofs_dev_close;
+	autofs_cdevsw->d_read= autofs_dev_read;
+	autofs_cdevsw->d_write= autofs_dev_write;
+	autofs_cdevsw->d_poll= autofs_dev_poll;
+	autofs_cdevsw->d_version= D_VERSION;
+	autofs_cdevsw->d_name= "autofs_dev";
+
+	autofs_cdev= make_dev( autofs_cdevsw, num, UID_ROOT, GID_WHEEL, 0600, "autofs%d", num );
+	if( autofs_cdev == NULL )
+	{
+		panic( "Bad autofs_cdev\n" );
+	}
+	autofs_cdev->si_priv= (struct cdev_priv *) autofs_dev_data;
+
+	return 0;
+}
 
+	
 
 /*
  * We only handle the IOCTLS for create and destroy autofs_dev instances.
@@ -78,8 +118,8 @@
 
 
 static int
-autofs_ctl_ioctl(struct cdev *i_dev, u_long cmd, caddr_t arg_c, int mode,
-		struct thread *td)
+autofs_ctl_ioctl( struct cdev *i_dev, u_long cmd, caddr_t arg_c, int mode,
+		struct thread *td )
 {
 	$cleanup_init_size( 8 );
 	int error= 0;
@@ -89,17 +129,17 @@
 	arg= NULL;
 	$return EOPNOTSUPP;
 
-	#if 0
+	#if 1
 	switch( cmd ) {
 		case AFSIOCREATDEV:
 
-			mtx_lock(&autofs_ctl_state.lock);
+			/* mtx_lock(&autofs_ctl_state.lock);
 			$cleanup(
 				mtx_unlock(&autofs_ctl_state.lock);
 			)
-
+			*/
 			arg= autofs_ctl_state.next_assignable_node++;
-			error= create_autofs_node(arg);
+			error= create_autofs_node( arg );
 
 			$do_cleanup;
 
@@ -115,4 +155,5 @@
 			error= EIO;
 			
 	#endif
+	return error;
 }

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs_ctl.h#3 (text+ko) ====

@@ -74,7 +74,10 @@
 
 
 
-
+struct autofs_dev_data {
+	struct uio	input;
+	struct uio	output
+};
 
 
 /** Are we allowed to reuse group "a"? **/

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs_dev.c#4 (text+ko) ====

@@ -28,6 +28,7 @@
  */
 
 #include "autofs.h"
+#include "protocol.h"
 
 #include <sys/types.h>
 #include <sys/module.h>
@@ -46,19 +47,19 @@
 
 struct uio *in_buffer, *out_buffer;
 
-#define IOV_BUF_COUNT	( 16 )
-
 int
 write_buffer( struct uio *buf, void *data, int len )
 {
 	$cleanup_init_size( 8 );
 	int error;
-	error = 0;
+	error= 0;
 	if( buf->uio_iovcnt < IOV_BUF_COUNT )
 	{
 		buf->uio_iov[ buf->uio_iovcnt ].iov_base= data;
 		buf->uio_iov[ buf->uio_iovcnt ].iov_len= len;
 		buf->uio_iovcnt++;
+
+		parse_messages();
 	}
 	else
 	{
@@ -68,3 +69,10 @@
 	$return error;
 }
 
+
+
+int autofs_dev_open( struct cdev *dev, int oflags, int devtype, struct thread *td )
+{
+	int error;
+	int i;
+}

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs_dev.h#2 (text+ko) ====

@@ -1,6 +1,16 @@
 #include <sys/types.h>
 #include <sys/uio.h>
 
+
+#define IOV_BUF_COUNT	( 16 )
+
 extern struct uio *in_buffer, *out_buffer;
 
 int write_buffer( struct uio *buf, void *data, int len );
+
+
+int autofs_dev_open( struct cdev *dev, int oflags, int devtype, struct thread *td );
+int autofs_dev_close( struct cdev *dev, int oflags, int devtype, struct thread *td );
+int autofs_dev_read( struct cdev *dev, struct uio *uio, int ioflag );
+int autofs_dev_write( struct cdev *dev, struct uio *uio, int ioflag );
+int autofs_dev_poll( struct cdev *dev, int events, struct thread *td );

==== //depot/projects/soc2006/adamartin_autofs/autofs/autofs_pfsops.c#4 (text+ko) ====

@@ -56,6 +56,7 @@
 #include <fs/pseudofs/pseudofs.h>
 
 #include "protocol.h"
+#include "debug.h"
 
 
 MALLOC_DEFINE(M_AUTOFS_MOUNTBUF, "AutoFS mntbuf", "AutoFS mountpoint data, to simulate filesystem contents.");

==== //depot/projects/soc2006/adamartin_autofs/autofs/cleanup.h#5 (text+ko) ====

@@ -1,7 +1,10 @@
-/*-
+/*
  * Copyright (c) 2006		ADAM David Alan Martin
  *	LSD Kernel Project, All Rights Reserved.
  *
+ * Copyright (c) 2006		ADAM David Alan Martin
+ *	FreeBSD Project, All Rights Reserved.
+ *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  * are met:
@@ -20,7 +23,7 @@
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
  *
- * THIS SOFTWARE IS PROVIDED BY THE PROJECT ``AS IS'' AND
+ * THIS SOFTWARE IS PROVIDED BY THE PROJECT, AND CONTRIBUTORS ``AS IS'' AND
  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
@@ -37,6 +40,21 @@
 #ifndef	__CLEANUP_H__
 #define	__CLEANUP_H__
 
+#ifdef	LSD
+
+#include <cdefs.h>
+
+__LSDHEADERID( cleanup, "$Id: cleanup.i 252 2006-10-31 23:54:52Z adam $" );
+#else
+static const char *__lsdid_cleanup_header__ __attribute__(( unused ))= "$Id: cleanup.i 252 2006-10-31 23:54:52Z adam $";
+#ifdef	FREEBSD
+#include <sys/cdefs.h>
+
+/* __FBSDID( "$FreeBSD$" ); */
+#endif
+
+#endif	/* LSD */
+
 
 
 
@@ -78,11 +96,11 @@
 #define	__VOLATILE_IMPLEMENTATION__	/** No volatile for nested functions **/
 
 
-#define LN __LINE__
+#define __CLN_LN__ __LINE__
 
 #define ___cleanup_action_( a ) ___cleanup_action___ ## a
 
-#define REGISTER_ACTION( actions ) _REGISTER_ACTION( LN, actions )
+#define REGISTER_ACTION( actions ) _REGISTER_ACTION( __CLN_LN__, actions )
 
 #define _REGISTER_ACTION( name, actions ) \
 	static void ___cleanup_action_( name ) ( void )\
@@ -115,8 +133,16 @@
 /** The setjmp/longjmp implementation of the cleanup library.
 This one is really nasty-ugly **/
 
-#ifndef NO_USE_SETJMP_INCLUDE
-#include <setjmp.h>
+
+#ifdef	FREEBSD_SYS
+#	include <machine/setjmp.h>
+
+#else
+
+#	ifndef	NO_USE_SETJMP_INCLUDE
+#		include <setjmp.h>
+#	endif
+
 #endif
 
 #ifndef	NO_CLEANUP_WARNING
@@ -126,8 +152,13 @@
 #define	__VOLATILE_IMPLEMENTATION__ volatile
 /** Yes we're volatile for this one **/
 
+#ifdef	FREEBSD
+#ifdef	KERNEL
 typedef struct _jmp_buf *__cleanup_ptr;
-//#define __cleanup_ptr	struct _jmp_buf *
+#endif
+#else
+typedef jmp_buf __cleanup_ptr;
+#endif
 
 #define	___CLEANUP_STACK_EXTRAS___	\
 	__cleanup_ptr ___CLEANUP_STACK_DISPATCHER= NULL;\
@@ -168,16 +199,22 @@
 
 #define 	CLEANUP_STACK\
 	___CLEANUP_STACK_EXTRAS___\
+	__VOLATILE_IMPLEMENTATION__ ___generic___ ___CLEANUP_LOCALS___ \
+			[ __CLEANUP_STACK_MAX__ ];\
 	__VOLATILE_IMPLEMENTATION__ __cleanup_ptr ___CLEANUP_STACK \
 			[ __CLEANUP_STACK_MAX__ ];\
-	__VOLATILE_IMPLEMENTATION__ int __CLEANUP_STACK_POINTER__= 0
-
+	__VOLATILE_IMPLEMENTATION__ int __CLEANUP_STACK_POINTER__= 0;\
+	___CLEANUP_LOCALS___[ 0 ]= 0
 
 #define 	CLEANUP_STACK_SIZE( size )\
 	___CLEANUP_STACK_EXTRAS___\
+	__VOLATILE_IMPLEMENTATION__ ___generic___ ___CLEANUP_LOCALS___ \
+			[ size ];\
 	__VOLATILE_IMPLEMENTATION__ __cleanup_ptr ___CLEANUP_STACK \
 			[ size ];\
-	__VOLATILE_IMPLEMENTATION__ int __CLEANUP_STACK_POINTER__= 0
+	__VOLATILE_IMPLEMENTATION__ int __CLEANUP_STACK_POINTER__= 0;\
+	___CLEANUP_LOCALS___[ 0 ]= 0
+
 
 /** Use REGISTER_CLEANUP_LOCAL *** XXX BEFORE XXX *** you register an action
 to use that local with.  It's just a void *.  You must re-cast it to what is
@@ -190,6 +227,15 @@
 #define		GET_LOCAL()\
 			( ___CLEANUP_LOCALS___[ __CLEANUP_STACK_POINTER___ ] )
 
+#define		POP_CLEANUP\
+			do\
+			{\
+				if( __CLEANUP_STACK_POINTER___ )\
+				{\
+					( __CLEANUP_STACK_POINTER___-- );\
+				}\
+			} while( 0 );
+
 
 /*** OOPC names: ***/
 
@@ -207,6 +253,8 @@
 
 #define		$reset_cleanup		RESET_CLEANUP
 
+#define		$pop_cleanup		POP_CLEANUP
+
 
 
 #endif	/*** __CLEANUP_H__ ***/

==== //depot/projects/soc2006/adamartin_autofs/autofs/protocol.c#4 (text+ko) ====


==== //depot/projects/soc2006/adamartin_autofs/autofs/protocol.h#4 (text+ko) ====

@@ -224,4 +224,6 @@
 
 int send_mount_request(struct message_header *req);
 
+int parse_user_message();
+
 #endif	/*** AUTOFS_PROTOCOL_HEADER ***/

==== //depot/projects/soc2006/adamartin_autofs/pseudofs/pseudofs.h#2 (text+ko) ====

@@ -43,6 +43,7 @@
 struct uio;
 struct vfsconf;
 struct vnode;
+struct componentname;
 
 /*
  * Limits and constants
@@ -137,7 +138,7 @@
  */
 #define PFS_LOOKUP_ARGS \
 	struct thread *td, struct proc *p, struct pfs_node *pn, \
-	unsigned long cmd, void *data
+	struct componentname *cnp
 #define PFS_LOOKUP_PROTO(name) \
 	int name(PFS_LOOKUP_ARGS);
 typedef int (*pfs_lookup_t)(PFS_LOOKUP_ARGS);

==== //depot/projects/soc2006/adamartin_autofs/pseudofs/pseudofs_vnops.c#3 (text+ko) ====




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200611140200.kAE20FLc089899>