xref: /freebsd-src/contrib/ofed/opensm/opensm/osm_event_plugin.c (revision 87181516ef48be852d5e5fee53c6e0dbfc62f21e)
1*d6b92ffaSHans Petter Selasky /*
2*d6b92ffaSHans Petter Selasky  * Copyright (c) 2008-2009 Voltaire, Inc. All rights reserved.
3*d6b92ffaSHans Petter Selasky  * Copyright (c) 2007 The Regents of the University of California.
4*d6b92ffaSHans Petter Selasky  *
5*d6b92ffaSHans Petter Selasky  * This software is available to you under a choice of one of two
6*d6b92ffaSHans Petter Selasky  * licenses.  You may choose to be licensed under the terms of the GNU
7*d6b92ffaSHans Petter Selasky  * General Public License (GPL) Version 2, available from the file
8*d6b92ffaSHans Petter Selasky  * COPYING in the main directory of this source tree, or the
9*d6b92ffaSHans Petter Selasky  * OpenIB.org BSD license below:
10*d6b92ffaSHans Petter Selasky  *
11*d6b92ffaSHans Petter Selasky  *     Redistribution and use in source and binary forms, with or
12*d6b92ffaSHans Petter Selasky  *     without modification, are permitted provided that the following
13*d6b92ffaSHans Petter Selasky  *     conditions are met:
14*d6b92ffaSHans Petter Selasky  *
15*d6b92ffaSHans Petter Selasky  *      - Redistributions of source code must retain the above
16*d6b92ffaSHans Petter Selasky  *        copyright notice, this list of conditions and the following
17*d6b92ffaSHans Petter Selasky  *        disclaimer.
18*d6b92ffaSHans Petter Selasky  *
19*d6b92ffaSHans Petter Selasky  *      - Redistributions in binary form must reproduce the above
20*d6b92ffaSHans Petter Selasky  *        copyright notice, this list of conditions and the following
21*d6b92ffaSHans Petter Selasky  *        disclaimer in the documentation and/or other materials
22*d6b92ffaSHans Petter Selasky  *        provided with the distribution.
23*d6b92ffaSHans Petter Selasky  *
24*d6b92ffaSHans Petter Selasky  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25*d6b92ffaSHans Petter Selasky  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26*d6b92ffaSHans Petter Selasky  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27*d6b92ffaSHans Petter Selasky  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
28*d6b92ffaSHans Petter Selasky  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
29*d6b92ffaSHans Petter Selasky  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
30*d6b92ffaSHans Petter Selasky  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
31*d6b92ffaSHans Petter Selasky  * SOFTWARE.
32*d6b92ffaSHans Petter Selasky  *
33*d6b92ffaSHans Petter Selasky  */
34*d6b92ffaSHans Petter Selasky 
35*d6b92ffaSHans Petter Selasky /****h* OpenSM Event plugin interface
36*d6b92ffaSHans Petter Selasky * DESCRIPTION
37*d6b92ffaSHans Petter Selasky *       Database interface to record subnet events
38*d6b92ffaSHans Petter Selasky *
39*d6b92ffaSHans Petter Selasky *       Implementations of this object _MUST_ be thread safe.
40*d6b92ffaSHans Petter Selasky *
41*d6b92ffaSHans Petter Selasky * AUTHOR
42*d6b92ffaSHans Petter Selasky *	Ira Weiny, LLNL
43*d6b92ffaSHans Petter Selasky *
44*d6b92ffaSHans Petter Selasky *********/
45*d6b92ffaSHans Petter Selasky 
46*d6b92ffaSHans Petter Selasky #if HAVE_CONFIG_H
47*d6b92ffaSHans Petter Selasky #  include <config.h>
48*d6b92ffaSHans Petter Selasky #endif				/* HAVE_CONFIG_H */
49*d6b92ffaSHans Petter Selasky 
50*d6b92ffaSHans Petter Selasky #include <stdlib.h>
51*d6b92ffaSHans Petter Selasky #include <dlfcn.h>
52*d6b92ffaSHans Petter Selasky #include <opensm/osm_file_ids.h>
53*d6b92ffaSHans Petter Selasky #define FILE_ID OSM_FILE_EVENT_PLUGIN_C
54*d6b92ffaSHans Petter Selasky #include <opensm/osm_event_plugin.h>
55*d6b92ffaSHans Petter Selasky #include <opensm/osm_opensm.h>
56*d6b92ffaSHans Petter Selasky 
57*d6b92ffaSHans Petter Selasky #if defined(PATH_MAX)
58*d6b92ffaSHans Petter Selasky #define OSM_PATH_MAX	(PATH_MAX + 1)
59*d6b92ffaSHans Petter Selasky #elif defined (_POSIX_PATH_MAX)
60*d6b92ffaSHans Petter Selasky #define OSM_PATH_MAX	(_POSIX_PATH_MAX + 1)
61*d6b92ffaSHans Petter Selasky #else
62*d6b92ffaSHans Petter Selasky #define OSM_PATH_MAX	256
63*d6b92ffaSHans Petter Selasky #endif
64*d6b92ffaSHans Petter Selasky 
65*d6b92ffaSHans Petter Selasky /**
66*d6b92ffaSHans Petter Selasky  * functions
67*d6b92ffaSHans Petter Selasky  */
osm_epi_construct(osm_opensm_t * osm,char * plugin_name)68*d6b92ffaSHans Petter Selasky osm_epi_plugin_t *osm_epi_construct(osm_opensm_t *osm, char *plugin_name)
69*d6b92ffaSHans Petter Selasky {
70*d6b92ffaSHans Petter Selasky 	char lib_name[OSM_PATH_MAX];
71*d6b92ffaSHans Petter Selasky 	struct old_if { unsigned ver; } *old_impl;
72*d6b92ffaSHans Petter Selasky 	osm_epi_plugin_t *rc = NULL;
73*d6b92ffaSHans Petter Selasky 
74*d6b92ffaSHans Petter Selasky 	if (!plugin_name || !*plugin_name)
75*d6b92ffaSHans Petter Selasky 		return NULL;
76*d6b92ffaSHans Petter Selasky 
77*d6b92ffaSHans Petter Selasky 	/* find the plugin */
78*d6b92ffaSHans Petter Selasky 	snprintf(lib_name, sizeof(lib_name), "lib%s.so", plugin_name);
79*d6b92ffaSHans Petter Selasky 
80*d6b92ffaSHans Petter Selasky 	rc = malloc(sizeof(*rc));
81*d6b92ffaSHans Petter Selasky 	if (!rc)
82*d6b92ffaSHans Petter Selasky 		return NULL;
83*d6b92ffaSHans Petter Selasky 
84*d6b92ffaSHans Petter Selasky 	rc->handle = dlopen(lib_name, RTLD_LAZY);
85*d6b92ffaSHans Petter Selasky 	if (!rc->handle) {
86*d6b92ffaSHans Petter Selasky 		OSM_LOG(&osm->log, OSM_LOG_ERROR,
87*d6b92ffaSHans Petter Selasky 			"Failed to open event plugin \"%s\" : \"%s\"\n",
88*d6b92ffaSHans Petter Selasky 			lib_name, dlerror());
89*d6b92ffaSHans Petter Selasky 		goto DLOPENFAIL;
90*d6b92ffaSHans Petter Selasky 	}
91*d6b92ffaSHans Petter Selasky 
92*d6b92ffaSHans Petter Selasky 	rc->impl =
93*d6b92ffaSHans Petter Selasky 	    (osm_event_plugin_t *) dlsym(rc->handle,
94*d6b92ffaSHans Petter Selasky 					 OSM_EVENT_PLUGIN_IMPL_NAME);
95*d6b92ffaSHans Petter Selasky 	if (!rc->impl) {
96*d6b92ffaSHans Petter Selasky 		OSM_LOG(&osm->log, OSM_LOG_ERROR,
97*d6b92ffaSHans Petter Selasky 			"Failed to find \"%s\" symbol in \"%s\" : \"%s\"\n",
98*d6b92ffaSHans Petter Selasky 			OSM_EVENT_PLUGIN_IMPL_NAME, lib_name, dlerror());
99*d6b92ffaSHans Petter Selasky 		goto Exit;
100*d6b92ffaSHans Petter Selasky 	}
101*d6b92ffaSHans Petter Selasky 
102*d6b92ffaSHans Petter Selasky 	/* check for old interface */
103*d6b92ffaSHans Petter Selasky 	old_impl = (struct old_if *) rc->impl;
104*d6b92ffaSHans Petter Selasky 	if (old_impl->ver == OSM_ORIG_EVENT_PLUGIN_INTERFACE_VER) {
105*d6b92ffaSHans Petter Selasky 		OSM_LOG(&osm->log, OSM_LOG_ERROR, "Error loading plugin: "
106*d6b92ffaSHans Petter Selasky 			"\'%s\' contains a depricated interface version %d\n"
107*d6b92ffaSHans Petter Selasky 			"   Please recompile with the new interface.\n",
108*d6b92ffaSHans Petter Selasky 			plugin_name, old_impl->ver);
109*d6b92ffaSHans Petter Selasky 		goto Exit;
110*d6b92ffaSHans Petter Selasky 	}
111*d6b92ffaSHans Petter Selasky 
112*d6b92ffaSHans Petter Selasky 	/* Check the version to make sure this module will work with us */
113*d6b92ffaSHans Petter Selasky 	if (strcmp(rc->impl->osm_version, osm->osm_version)) {
114*d6b92ffaSHans Petter Selasky 		OSM_LOG(&osm->log, OSM_LOG_ERROR, "Error loading plugin"
115*d6b92ffaSHans Petter Selasky 			" \'%s\': OpenSM version mismatch - plugin was built"
116*d6b92ffaSHans Petter Selasky 			" against %s version of OpenSM. Skip loading.\n",
117*d6b92ffaSHans Petter Selasky 			plugin_name, rc->impl->osm_version);
118*d6b92ffaSHans Petter Selasky 		goto Exit;
119*d6b92ffaSHans Petter Selasky 	}
120*d6b92ffaSHans Petter Selasky 
121*d6b92ffaSHans Petter Selasky 	if (!rc->impl->create) {
122*d6b92ffaSHans Petter Selasky 		OSM_LOG(&osm->log, OSM_LOG_ERROR,
123*d6b92ffaSHans Petter Selasky 			"Error loading plugin \'%s\': no create() method.\n",
124*d6b92ffaSHans Petter Selasky 			plugin_name);
125*d6b92ffaSHans Petter Selasky 		goto Exit;
126*d6b92ffaSHans Petter Selasky 	}
127*d6b92ffaSHans Petter Selasky 
128*d6b92ffaSHans Petter Selasky 	rc->plugin_data = rc->impl->create(osm);
129*d6b92ffaSHans Petter Selasky 
130*d6b92ffaSHans Petter Selasky 	if (!rc->plugin_data)
131*d6b92ffaSHans Petter Selasky 		goto Exit;
132*d6b92ffaSHans Petter Selasky 
133*d6b92ffaSHans Petter Selasky 	rc->plugin_name = strdup(plugin_name);
134*d6b92ffaSHans Petter Selasky 	return rc;
135*d6b92ffaSHans Petter Selasky 
136*d6b92ffaSHans Petter Selasky Exit:
137*d6b92ffaSHans Petter Selasky 	dlclose(rc->handle);
138*d6b92ffaSHans Petter Selasky DLOPENFAIL:
139*d6b92ffaSHans Petter Selasky 	free(rc);
140*d6b92ffaSHans Petter Selasky 	return NULL;
141*d6b92ffaSHans Petter Selasky }
142*d6b92ffaSHans Petter Selasky 
osm_epi_destroy(osm_epi_plugin_t * plugin)143*d6b92ffaSHans Petter Selasky void osm_epi_destroy(osm_epi_plugin_t * plugin)
144*d6b92ffaSHans Petter Selasky {
145*d6b92ffaSHans Petter Selasky 	if (plugin) {
146*d6b92ffaSHans Petter Selasky 		if (plugin->impl->delete)
147*d6b92ffaSHans Petter Selasky 			plugin->impl->delete(plugin->plugin_data);
148*d6b92ffaSHans Petter Selasky 		dlclose(plugin->handle);
149*d6b92ffaSHans Petter Selasky 		free(plugin->plugin_name);
150*d6b92ffaSHans Petter Selasky 		free(plugin);
151*d6b92ffaSHans Petter Selasky 	}
152*d6b92ffaSHans Petter Selasky }
153