source: mainline/uspace/lib/c/generic/event.c@ b412168

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since b412168 was 8820544, checked in by Martin Decky <martin@…>, 11 years ago

support for kernel notification multiplexing in the async framework

  • rename SYS_EVENT_* and SYS_IRQ_* syscalls to unify the terminology
  • add SYS_IPC_EVENT_UNSUBSCRIBE
  • remove IRQ handler multiplexing from DDF, the generic mechanism replaces it (unfortunatelly the order of arguments used by interrupt_handler_t needs to be permutated to align with the async framework conventions)
  • Property mode set to 100644
File size: 3.2 KB
Line 
1/*
2 * Copyright (c) 2009 Jakub Jermar
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 */
33
34/** @addtogroup libc
35 */
36/** @file
37 */
38
39#include <libc.h>
40#include <ipc/event.h>
41
42/** Subscribe to event notifications.
43 *
44 * @param evno Event type to subscribe.
45 * @param imethod Use this interface and method for notifying me.
46 *
47 * @return Value returned by the kernel.
48 *
49 */
50int ipc_event_subscribe(event_type_t evno, sysarg_t imethod)
51{
52 return __SYSCALL2(SYS_IPC_EVENT_SUBSCRIBE, (sysarg_t) evno,
53 (sysarg_t) imethod);
54}
55
56/** Subscribe to task event notifications.
57 *
58 * @param evno Event type to subscribe.
59 * @param imethod Use this interface and method for notifying me.
60 *
61 * @return Value returned by the kernel.
62 *
63 */
64int ipc_event_task_subscribe(event_task_type_t evno, sysarg_t imethod)
65{
66 return __SYSCALL2(SYS_IPC_EVENT_SUBSCRIBE, (sysarg_t) evno,
67 (sysarg_t) imethod);
68}
69
70/** Unsubscribe from event notifications.
71 *
72 * @param evno Event type to unsubscribe.
73 *
74 * @return Value returned by the kernel.
75 *
76 */
77int ipc_event_unsubscribe(event_type_t evno)
78{
79 return __SYSCALL1(SYS_IPC_EVENT_UNSUBSCRIBE, (sysarg_t) evno);
80}
81
82/** Unsubscribe from task event notifications.
83 *
84 * @param evno Event type to unsubscribe.
85 *
86 * @return Value returned by the kernel.
87 *
88 */
89int ipc_event_task_unsubscribe(event_task_type_t evno)
90{
91 return __SYSCALL1(SYS_IPC_EVENT_UNSUBSCRIBE, (sysarg_t) evno);
92}
93
94/** Unmask event notifications.
95 *
96 * @param evno Event type to unmask.
97 *
98 * @return Value returned by the kernel.
99 *
100 */
101int ipc_event_unmask(event_type_t evno)
102{
103 return __SYSCALL1(SYS_IPC_EVENT_UNMASK, (sysarg_t) evno);
104}
105
106/** Unmask task event notifications.
107 *
108 * @param evno Event type to unmask.
109 *
110 * @return Value returned by the kernel.
111 *
112 */
113int ipc_event_task_unmask(event_task_type_t evno)
114{
115 return __SYSCALL1(SYS_IPC_EVENT_UNMASK, (sysarg_t) evno);
116}
117
118/** @}
119 */
Note: See TracBrowser for help on using the repository browser.