source: mainline/uspace/lib/libc/include/async.h@ 8498915

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 8498915 was 116d3f6f, checked in by Jakub Jermar <jakub@…>, 18 years ago

Rename fibril_schedule_next_adv() to fibril_switch(). Rename
fibril_schedule_next() to fibril_yield(). Some fibril structures could be
uninitialized, set them to zero in fibril_setup(). For some fibrils, the stack
member can be NULL (e.g. every thread's first/main fibril); don't do free on
these stacks when cleaning up after a dead fibril.

  • Property mode set to 100644
File size: 4.2 KB
Line 
1/*
2 * Copyright (c) 2006 Ondrej Palkovsky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup libc
30 * @{
31 */
32/** @file
33 */
34
35#ifndef LIBC_ASYNC_H_
36#define LIBC_ASYNC_H_
37
38#include <ipc/ipc.h>
39#include <fibril.h>
40#include <sys/time.h>
41#include <atomic.h>
42
43typedef ipc_callid_t aid_t;
44typedef void (*async_client_conn_t)(ipc_callid_t callid, ipc_call_t *call);
45
46static inline void async_manager(void)
47{
48 fibril_switch(FIBRIL_TO_MANAGER);
49}
50
51ipc_callid_t async_get_call_timeout(ipc_call_t *call, suseconds_t usecs);
52static inline ipc_callid_t async_get_call(ipc_call_t *data)
53{
54 return async_get_call_timeout(data, 0);
55}
56
57aid_t async_send_2(int phoneid, ipcarg_t method, ipcarg_t arg1, ipcarg_t arg2,
58 ipc_call_t *dataptr);
59aid_t async_send_3(int phoneid, ipcarg_t method, ipcarg_t arg1, ipcarg_t arg2,
60 ipcarg_t arg3, ipc_call_t *dataptr);
61void async_wait_for(aid_t amsgid, ipcarg_t *result);
62int async_wait_timeout(aid_t amsgid, ipcarg_t *retval, suseconds_t timeout);
63
64/** Pseudo-synchronous message sending
65 *
66 * Send message through IPC, wait in the event loop, until it is received
67 *
68 * @return Return code of message
69 */
70static inline ipcarg_t async_req_2(int phoneid, ipcarg_t method, ipcarg_t arg1,
71 ipcarg_t arg2, ipcarg_t *r1, ipcarg_t *r2)
72{
73 ipc_call_t result;
74 ipcarg_t rc;
75
76 aid_t eid = async_send_2(phoneid, method, arg1, arg2, &result);
77 async_wait_for(eid, &rc);
78 if (r1)
79 *r1 = IPC_GET_ARG1(result);
80 if (r2)
81 *r2 = IPC_GET_ARG2(result);
82 return rc;
83}
84#define async_req(phoneid, method, arg1, r1) \
85 async_req_2(phoneid, method, arg1, 0, r1, 0)
86
87static inline ipcarg_t async_req_3(int phoneid, ipcarg_t method, ipcarg_t arg1,
88 ipcarg_t arg2, ipcarg_t arg3, ipcarg_t *r1, ipcarg_t *r2, ipcarg_t *r3)
89{
90 ipc_call_t result;
91 ipcarg_t rc;
92
93 aid_t eid = async_send_3(phoneid, method, arg1, arg2, arg3, &result);
94 async_wait_for(eid, &rc);
95 if (r1)
96 *r1 = IPC_GET_ARG1(result);
97 if (r2)
98 *r2 = IPC_GET_ARG2(result);
99 if (r3)
100 *r3 = IPC_GET_ARG3(result);
101 return rc;
102}
103
104
105fid_t async_new_connection(ipcarg_t in_phone_hash,ipc_callid_t callid,
106 ipc_call_t *call, void (*cthread)(ipc_callid_t,ipc_call_t *));
107void async_usleep(suseconds_t timeout);
108void async_create_manager(void);
109void async_destroy_manager(void);
110void async_set_client_connection(async_client_conn_t conn);
111void async_set_interrupt_received(async_client_conn_t conn);
112int _async_init(void);
113
114
115/* Primitve functions for IPC communication */
116void async_msg_3(int phoneid, ipcarg_t method, ipcarg_t arg1, ipcarg_t arg2,
117 ipcarg_t arg3);
118void async_msg_2(int phoneid, ipcarg_t method, ipcarg_t arg1, ipcarg_t arg2);
119#define async_msg(ph, m, a1) async_msg_2(ph, m, a1, 0)
120
121static inline void async_serialize_start(void)
122{
123 fibril_inc_sercount();
124}
125
126static inline void async_serialize_end(void)
127{
128 fibril_dec_sercount();
129}
130
131extern atomic_t async_futex;
132#endif
133
134/** @}
135 */
Note: See TracBrowser for help on using the repository browser.