1*7836SJohn.Forte@Sun.COM /* 2*7836SJohn.Forte@Sun.COM * CDDL HEADER START 3*7836SJohn.Forte@Sun.COM * 4*7836SJohn.Forte@Sun.COM * The contents of this file are subject to the terms of the 5*7836SJohn.Forte@Sun.COM * Common Development and Distribution License (the "License"). 6*7836SJohn.Forte@Sun.COM * You may not use this file except in compliance with the License. 7*7836SJohn.Forte@Sun.COM * 8*7836SJohn.Forte@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*7836SJohn.Forte@Sun.COM * or http://www.opensolaris.org/os/licensing. 10*7836SJohn.Forte@Sun.COM * See the License for the specific language governing permissions 11*7836SJohn.Forte@Sun.COM * and limitations under the License. 12*7836SJohn.Forte@Sun.COM * 13*7836SJohn.Forte@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each 14*7836SJohn.Forte@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*7836SJohn.Forte@Sun.COM * If applicable, add the following below this CDDL HEADER, with the 16*7836SJohn.Forte@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*7836SJohn.Forte@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*7836SJohn.Forte@Sun.COM * 19*7836SJohn.Forte@Sun.COM * CDDL HEADER END 20*7836SJohn.Forte@Sun.COM */ 21*7836SJohn.Forte@Sun.COM /* 22*7836SJohn.Forte@Sun.COM * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23*7836SJohn.Forte@Sun.COM * Use is subject to license terms. 24*7836SJohn.Forte@Sun.COM */ 25*7836SJohn.Forte@Sun.COM 26*7836SJohn.Forte@Sun.COM 27*7836SJohn.Forte@Sun.COM #include <sys/stat.h> 28*7836SJohn.Forte@Sun.COM #include <fcntl.h> 29*7836SJohn.Forte@Sun.COM #include <errno.h> 30*7836SJohn.Forte@Sun.COM 31*7836SJohn.Forte@Sun.COM #include "mp_utils.h" 32*7836SJohn.Forte@Sun.COM 33*7836SJohn.Forte@Sun.COM 34*7836SJohn.Forte@Sun.COM /* 35*7836SJohn.Forte@Sun.COM * Global Variables 36*7836SJohn.Forte@Sun.COM */ 37*7836SJohn.Forte@Sun.COM 38*7836SJohn.Forte@Sun.COM MP_UINT32 g_pluginOwnerID = 0; 39*7836SJohn.Forte@Sun.COM int g_scsi_vhci_fd = -1; 40*7836SJohn.Forte@Sun.COM 41*7836SJohn.Forte@Sun.COM PROPERTY_CALLBACK_NODE g_Property_Callback_List[MP_OBJECT_TYPE_MAX + 1]; 42*7836SJohn.Forte@Sun.COM VISIBILITY_CALLBACK_NODE g_Visibility_Callback_List[MP_OBJECT_TYPE_MAX + 1]; 43*7836SJohn.Forte@Sun.COM 44*7836SJohn.Forte@Sun.COM sysevent_handle_t *g_SysEventHandle = NULL; 45*7836SJohn.Forte@Sun.COM 46*7836SJohn.Forte@Sun.COM pthread_mutex_t g_visa_mutex = PTHREAD_MUTEX_INITIALIZER; 47*7836SJohn.Forte@Sun.COM pthread_mutex_t g_prop_mutex = PTHREAD_MUTEX_INITIALIZER; 48*7836SJohn.Forte@Sun.COM 49*7836SJohn.Forte@Sun.COM /* 50*7836SJohn.Forte@Sun.COM * Called by the common layer to request the plugin to initialize 51*7836SJohn.Forte@Sun.COM * itself. 52*7836SJohn.Forte@Sun.COM */ 53*7836SJohn.Forte@Sun.COM 54*7836SJohn.Forte@Sun.COM MP_STATUS 55*7836SJohn.Forte@Sun.COM Initialize(MP_UINT32 pluginOwnerID) 56*7836SJohn.Forte@Sun.COM { 57*7836SJohn.Forte@Sun.COM MP_STATUS mpStatus = MP_STATUS_SUCCESS; 58*7836SJohn.Forte@Sun.COM 59*7836SJohn.Forte@Sun.COM 60*7836SJohn.Forte@Sun.COM log(LOG_INFO, "Initialize()", " - enter"); 61*7836SJohn.Forte@Sun.COM 62*7836SJohn.Forte@Sun.COM 63*7836SJohn.Forte@Sun.COM (void) memset(&g_Property_Callback_List, 0, 64*7836SJohn.Forte@Sun.COM sizeof (PROPERTY_CALLBACK_NODE) * (MP_OBJECT_TYPE_MAX + 1)); 65*7836SJohn.Forte@Sun.COM 66*7836SJohn.Forte@Sun.COM (void) memset(&g_Visibility_Callback_List, 0, 67*7836SJohn.Forte@Sun.COM sizeof (VISIBILITY_CALLBACK_NODE) * (MP_OBJECT_TYPE_MAX + 1)); 68*7836SJohn.Forte@Sun.COM 69*7836SJohn.Forte@Sun.COM /* Attempt to open the driver that this plugin will make request of. */ 70*7836SJohn.Forte@Sun.COM g_scsi_vhci_fd = open("/devices/scsi_vhci:devctl", 71*7836SJohn.Forte@Sun.COM O_NDELAY | O_RDONLY); 72*7836SJohn.Forte@Sun.COM 73*7836SJohn.Forte@Sun.COM if (g_scsi_vhci_fd < 0) { 74*7836SJohn.Forte@Sun.COM log(LOG_INFO, "Initialize()", 75*7836SJohn.Forte@Sun.COM " - failed to open driver. error is : %s", 76*7836SJohn.Forte@Sun.COM strerror(errno)); 77*7836SJohn.Forte@Sun.COM log(LOG_INFO, "Initialize()", " - error exit"); 78*7836SJohn.Forte@Sun.COM return (MP_STATUS_FAILED); 79*7836SJohn.Forte@Sun.COM } 80*7836SJohn.Forte@Sun.COM 81*7836SJohn.Forte@Sun.COM g_pluginOwnerID = pluginOwnerID; 82*7836SJohn.Forte@Sun.COM 83*7836SJohn.Forte@Sun.COM /* Register to listen for visibility and property change events */ 84*7836SJohn.Forte@Sun.COM mpStatus = init_sysevents(); 85*7836SJohn.Forte@Sun.COM 86*7836SJohn.Forte@Sun.COM log(LOG_INFO, "Initialize()", 87*7836SJohn.Forte@Sun.COM " - init_sysevents() returned %d", 88*7836SJohn.Forte@Sun.COM mpStatus); 89*7836SJohn.Forte@Sun.COM 90*7836SJohn.Forte@Sun.COM 91*7836SJohn.Forte@Sun.COM log(LOG_INFO, "Initialize()", " - exit"); 92*7836SJohn.Forte@Sun.COM 93*7836SJohn.Forte@Sun.COM return (mpStatus); 94*7836SJohn.Forte@Sun.COM } 95