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 /*
23*7836SJohn.Forte@Sun.COM * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24*7836SJohn.Forte@Sun.COM * Use is subject to license terms.
25*7836SJohn.Forte@Sun.COM */
26*7836SJohn.Forte@Sun.COM
27*7836SJohn.Forte@Sun.COM #include <stdio.h>
28*7836SJohn.Forte@Sun.COM #include <stdlib.h>
29*7836SJohn.Forte@Sun.COM #include <unistd.h>
30*7836SJohn.Forte@Sun.COM #include <pthread.h>
31*7836SJohn.Forte@Sun.COM #include <synch.h>
32*7836SJohn.Forte@Sun.COM
33*7836SJohn.Forte@Sun.COM #include "isns_server.h"
34*7836SJohn.Forte@Sun.COM #include "isns_msgq.h"
35*7836SJohn.Forte@Sun.COM #include "isns_cache.h"
36*7836SJohn.Forte@Sun.COM #include "isns_obj.h"
37*7836SJohn.Forte@Sun.COM #include "isns_log.h"
38*7836SJohn.Forte@Sun.COM
39*7836SJohn.Forte@Sun.COM msg_queue_t *
queue_calloc()40*7836SJohn.Forte@Sun.COM queue_calloc(
41*7836SJohn.Forte@Sun.COM )
42*7836SJohn.Forte@Sun.COM {
43*7836SJohn.Forte@Sun.COM msg_queue_t *q;
44*7836SJohn.Forte@Sun.COM
45*7836SJohn.Forte@Sun.COM q = (msg_queue_t *)calloc(1, sizeof (msg_queue_t));
46*7836SJohn.Forte@Sun.COM
47*7836SJohn.Forte@Sun.COM if (q) {
48*7836SJohn.Forte@Sun.COM if (sema_init(&q->q_sema, 0, USYNC_THREAD, NULL) ||
49*7836SJohn.Forte@Sun.COM pthread_mutex_init(&q->q_mutex, NULL)) {
50*7836SJohn.Forte@Sun.COM free(q);
51*7836SJohn.Forte@Sun.COM q = NULL;
52*7836SJohn.Forte@Sun.COM }
53*7836SJohn.Forte@Sun.COM }
54*7836SJohn.Forte@Sun.COM
55*7836SJohn.Forte@Sun.COM return (q);
56*7836SJohn.Forte@Sun.COM }
57*7836SJohn.Forte@Sun.COM
58*7836SJohn.Forte@Sun.COM int
queue_msg_set(msg_queue_t * q,msg_id_t id,void * data)59*7836SJohn.Forte@Sun.COM queue_msg_set(
60*7836SJohn.Forte@Sun.COM msg_queue_t *q,
61*7836SJohn.Forte@Sun.COM msg_id_t id,
62*7836SJohn.Forte@Sun.COM void *data
63*7836SJohn.Forte@Sun.COM )
64*7836SJohn.Forte@Sun.COM {
65*7836SJohn.Forte@Sun.COM msg_text_t *msg;
66*7836SJohn.Forte@Sun.COM
67*7836SJohn.Forte@Sun.COM msg = (msg_text_t *)calloc(1, sizeof (msg_text_t));
68*7836SJohn.Forte@Sun.COM
69*7836SJohn.Forte@Sun.COM if (!msg) {
70*7836SJohn.Forte@Sun.COM return (1);
71*7836SJohn.Forte@Sun.COM }
72*7836SJohn.Forte@Sun.COM
73*7836SJohn.Forte@Sun.COM msg->id = id;
74*7836SJohn.Forte@Sun.COM msg->data = data;
75*7836SJohn.Forte@Sun.COM
76*7836SJohn.Forte@Sun.COM (void) pthread_mutex_lock(&q->q_mutex);
77*7836SJohn.Forte@Sun.COM
78*7836SJohn.Forte@Sun.COM if (q->q_head == NULL) {
79*7836SJohn.Forte@Sun.COM ASSERT(!q->q_tail);
80*7836SJohn.Forte@Sun.COM q->q_head = msg;
81*7836SJohn.Forte@Sun.COM q->q_tail = msg;
82*7836SJohn.Forte@Sun.COM } else {
83*7836SJohn.Forte@Sun.COM ASSERT(q->q_tail);
84*7836SJohn.Forte@Sun.COM q->q_tail->next = msg;
85*7836SJohn.Forte@Sun.COM msg->prev = q->q_tail;
86*7836SJohn.Forte@Sun.COM q->q_tail = msg;
87*7836SJohn.Forte@Sun.COM }
88*7836SJohn.Forte@Sun.COM
89*7836SJohn.Forte@Sun.COM (void) pthread_mutex_unlock(&q->q_mutex);
90*7836SJohn.Forte@Sun.COM
91*7836SJohn.Forte@Sun.COM (void) sema_post(&q->q_sema);
92*7836SJohn.Forte@Sun.COM
93*7836SJohn.Forte@Sun.COM return (0);
94*7836SJohn.Forte@Sun.COM }
95*7836SJohn.Forte@Sun.COM
96*7836SJohn.Forte@Sun.COM msg_text_t *
queue_msg_get(msg_queue_t * q)97*7836SJohn.Forte@Sun.COM queue_msg_get(
98*7836SJohn.Forte@Sun.COM msg_queue_t *q
99*7836SJohn.Forte@Sun.COM )
100*7836SJohn.Forte@Sun.COM {
101*7836SJohn.Forte@Sun.COM msg_text_t *msg;
102*7836SJohn.Forte@Sun.COM
103*7836SJohn.Forte@Sun.COM while (sema_wait(&q->q_sema)) {
104*7836SJohn.Forte@Sun.COM (void) sleep(1);
105*7836SJohn.Forte@Sun.COM }
106*7836SJohn.Forte@Sun.COM
107*7836SJohn.Forte@Sun.COM (void) pthread_mutex_lock(&q->q_mutex);
108*7836SJohn.Forte@Sun.COM
109*7836SJohn.Forte@Sun.COM msg = q->q_head;
110*7836SJohn.Forte@Sun.COM ASSERT(msg);
111*7836SJohn.Forte@Sun.COM q->q_head = msg->next;
112*7836SJohn.Forte@Sun.COM if (q->q_head == NULL) {
113*7836SJohn.Forte@Sun.COM q->q_tail = NULL;
114*7836SJohn.Forte@Sun.COM }
115*7836SJohn.Forte@Sun.COM
116*7836SJohn.Forte@Sun.COM (void) pthread_mutex_unlock(&q->q_mutex);
117*7836SJohn.Forte@Sun.COM
118*7836SJohn.Forte@Sun.COM return (msg);
119*7836SJohn.Forte@Sun.COM }
120*7836SJohn.Forte@Sun.COM
121*7836SJohn.Forte@Sun.COM void
queue_msg_free(msg_text_t * msg)122*7836SJohn.Forte@Sun.COM queue_msg_free(
123*7836SJohn.Forte@Sun.COM msg_text_t *msg
124*7836SJohn.Forte@Sun.COM )
125*7836SJohn.Forte@Sun.COM {
126*7836SJohn.Forte@Sun.COM free(msg);
127*7836SJohn.Forte@Sun.COM }
128