2 * Copyright (c) 2002-2004 MontaVista Software, Inc.
3 * Copyright (c) 2004 Open Source Development Lab
4 * Copyright (c) 2006-2007 Red Hat, Inc.
8 * Author: Steven Dake (sdake@mvista.com), Mark Haverkamp (markh@osdl.org)
10 * This software licensed under BSD license, the text of which follows:
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions are met:
15 * - Redistributions of source code must retain the above copyright notice,
16 * this list of conditions and the following disclaimer.
17 * - Redistributions in binary form must reproduce the above copyright notice,
18 * this list of conditions and the following disclaimer in the documentation
19 * and/or other materials provided with the distribution.
20 * - Neither the name of the MontaVista Software, Inc. nor the names of its
21 * contributors may be used to endorse or promote products derived from this
22 * software without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
34 * THE POSSIBILITY OF SUCH DAMAGE.
42 #include "../include/saAis.h"
43 #include "../include/list.h"
47 LOGSYS_DECLARE_SUBSYS ("MAIN", LOG_INFO
);
50 * Compare two names. returns non-zero on match.
52 int name_match(SaNameT
*name1
, SaNameT
*name2
)
54 if (name1
->length
== name2
->length
) {
55 return ((strncmp ((char *)name1
->value
, (char *)name2
->value
,
56 name1
->length
)) == 0);
61 int mar_name_match(mar_name_t
*name1
, mar_name_t
*name2
)
63 if (name1
->length
== name2
->length
) {
64 return ((strncmp ((char *)name1
->value
, (char *)name2
->value
,
65 name1
->length
)) == 0);
71 * Get the time of day and convert to nanoseconds
73 SaTimeT
clust_time_now(void)
78 if (gettimeofday(&tv
, 0)) {
82 time_now
= (SaTimeT
)(tv
.tv_sec
) * 1000000000ULL;
83 time_now
+= (SaTimeT
)(tv
.tv_usec
) * 1000ULL;
89 void _openais_exit_error (
90 enum e_ais_done err
, const char *file
, unsigned int line
)
92 log_printf (LOG_LEVEL_ERROR
, "AIS Executive exiting "
93 "with status %d at %s:%u.\n", err
, file
, line
);
98 char *getSaNameT (SaNameT
*name
)
101 static char ret_name
[300];
103 memset (ret_name
, 0, sizeof (ret_name
));
104 if (name
->length
> 299) {
105 memcpy (ret_name
, name
->value
, 299);
108 memcpy (ret_name
, name
->value
, name
->length
);
113 return ((char *)name
->value
);
116 char *get_mar_name_t (mar_name_t
*name
) {
117 return ((char *)name
->value
);
120 char *strstr_rs (const char *haystack
, const char *needle
)
125 new_needle
= (char *)strdup (needle
);
126 new_needle
[strlen (new_needle
) - 1] = '\0';
128 end_address
= strstr (haystack
, new_needle
);
130 end_address
+= strlen (new_needle
);
131 end_address
= strstr (end_address
, needle
+ strlen (new_needle
));
134 end_address
+= 1; /* skip past { or = */
136 if (*end_address
== '\t' || *end_address
== ' ') {
141 } while (*end_address
!= '\0');
145 return (end_address
);
148 void setSaNameT (SaNameT
*name
, char *str
) {
149 strncpy ((char *)name
->value
, str
, SA_MAX_NAME_LENGTH
);
150 if (strlen ((char *)name
->value
) > SA_MAX_NAME_LENGTH
) {
151 name
->length
= SA_MAX_NAME_LENGTH
;
153 name
->length
= strlen (str
);
157 int SaNameTisEqual (SaNameT
*str1
, char *str2
) {
158 if (str1
->length
== strlen (str2
)) {
159 return ((strncmp ((char *)str1
->value
, (char *)str2
,
160 str1
->length
)) == 0);