1 0 stevel /* 2 0 stevel * CDDL HEADER START 3 0 stevel * 4 0 stevel * The contents of this file are subject to the terms of the 5 0 stevel * Common Development and Distribution License, Version 1.0 only 6 0 stevel * (the "License"). You may not use this file except in compliance 7 0 stevel * with the License. 8 0 stevel * 9 0 stevel * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10 0 stevel * or http://www.opensolaris.org/os/licensing. 11 0 stevel * See the License for the specific language governing permissions 12 0 stevel * and limitations under the License. 13 0 stevel * 14 0 stevel * When distributing Covered Code, include this CDDL HEADER in each 15 0 stevel * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16 0 stevel * If applicable, add the following below this CDDL HEADER, with the 17 0 stevel * fields enclosed by brackets "[]" replaced with your own identifying 18 0 stevel * information: Portions Copyright [yyyy] [name of copyright owner] 19 0 stevel * 20 0 stevel * CDDL HEADER END 21 0 stevel */ 22 0 stevel /* 23 0 stevel * Copyright 2004 Sun Microsystems, Inc. All rights reserved. 24 0 stevel * Use is subject to license terms. 25 0 stevel */ 26 0 stevel 27 0 stevel #pragma ident "%Z%%M% %I% %E% SMI" 28 0 stevel 29 0 stevel #include <sys/types.h> 30 0 stevel #include <sys/modctl.h> 31 0 stevel #include <sys/errno.h> 32 0 stevel #include <gssapi/kgssapi_defs.h> 33 0 stevel 34 0 stevel char _depends_on[] = "strmod/rpcmod misc/rpcsec misc/tlimod"; 35 0 stevel 36 0 stevel static struct modlmisc modlmisc = { 37 0 stevel &mod_miscops, "in-kernel GSSAPI" 38 0 stevel }; 39 0 stevel 40 0 stevel static struct modlinkage modlinkage = { 41 0 stevel MODREV_1, 42 0 stevel (void *)&modlmisc, 43 0 stevel NULL 44 0 stevel }; 45 0 stevel 46 0 stevel int 47 0 stevel _init() 48 0 stevel { 49 0 stevel int retval; 50 0 stevel 51 0 stevel mutex_init(&gssrpcb_lock, NULL, MUTEX_DEFAULT, NULL); 52 0 stevel mutex_init(&__kgss_mech_lock, NULL, MUTEX_DEFAULT, NULL); 53 0 stevel zone_key_create(&gss_zone_key, gss_zone_init, NULL, gss_zone_fini); 54 0 stevel 55 0 stevel if ((retval = mod_install(&modlinkage)) != 0) { 56 0 stevel mutex_destroy(&__kgss_mech_lock); 57 0 stevel mutex_destroy(&gssrpcb_lock); 58 0 stevel } 59 0 stevel 60 0 stevel return (retval); 61 0 stevel } 62 0 stevel 63 0 stevel int 64 0 stevel _fini() 65 0 stevel { 66 0 stevel return (EBUSY); 67 0 stevel } 68 0 stevel 69 0 stevel int 70 0 stevel _info(struct modinfo *modinfop) 71 0 stevel { 72 0 stevel return (mod_info(&modlinkage, modinfop)); 73 0 stevel } 74