source: mainline/uspace/srv/vfs/vfs.c@ 01c3bb4

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

Convert call-handling syscalls to capabilities

This commit modifies the behavior of sys_ipc_wait_for_call() to return a
capability handle for requests. This capability handle can be used
either by sys_ipc_answer*() to answer the call or by sys_ipc_forward*()
to forward it further along. Answering or forwarding the call results in
destruction of the respective capability. For requests and
notifications, sys_ipc_wait_for_call() returns CAP_NIL and sets call
flags accordingly.

  • Property mode set to 100644
File size: 3.9 KB
Line 
1/*
2 * Copyright (c) 2008 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 fs
30 * @{
31 */
32
33/**
34 * @file vfs.c
35 * @brief VFS service for HelenOS.
36 */
37
38#include <vfs/vfs.h>
39#include <stdlib.h>
40#include <ipc/services.h>
41#include <abi/ipc/methods.h>
42#include <libarch/config.h>
43#include <ns.h>
44#include <async.h>
45#include <errno.h>
46#include <stdio.h>
47#include <stdbool.h>
48#include <str.h>
49#include <as.h>
50#include <atomic.h>
51#include <macros.h>
52#include "vfs.h"
53
54#define NAME "vfs"
55
56static void vfs_pager(ipc_callid_t iid, ipc_call_t *icall, void *arg)
57{
58 async_answer_0(iid, EOK);
59
60 while (true) {
61 ipc_call_t call;
62 ipc_callid_t callid = async_get_call(&call);
63
64 if (!IPC_GET_IMETHOD(call))
65 break;
66
67 switch (IPC_GET_IMETHOD(call)) {
68 case IPC_M_PAGE_IN:
69 vfs_page_in(callid, &call);
70 break;
71 default:
72 async_answer_0(callid, ENOTSUP);
73 break;
74 }
75 }
76}
77
78static void notification_handler(ipc_call_t *call, void *arg)
79{
80 if (IPC_GET_ARG1(*call) == VFS_PASS_HANDLE)
81 vfs_op_pass_handle(
82 (task_id_t) MERGE_LOUP32(IPC_GET_ARG4(*call),
83 IPC_GET_ARG5(*call)), call->in_task_id,
84 (int) IPC_GET_ARG2(*call));
85}
86
87int main(int argc, char **argv)
88{
89 int rc;
90
91 printf("%s: HelenOS VFS server\n", NAME);
92
93 /*
94 * Initialize VFS node hash table.
95 */
96 if (!vfs_nodes_init()) {
97 printf("%s: Failed to initialize VFS node hash table\n",
98 NAME);
99 return ENOMEM;
100 }
101
102 /*
103 * Allocate and initialize the Path Lookup Buffer.
104 */
105 plb = as_area_create(AS_AREA_ANY, PLB_SIZE,
106 AS_AREA_READ | AS_AREA_WRITE | AS_AREA_CACHEABLE, AS_AREA_UNPAGED);
107 if (plb == AS_MAP_FAILED) {
108 printf("%s: Cannot create address space area\n", NAME);
109 return ENOMEM;
110 }
111 memset(plb, 0, PLB_SIZE);
112
113 /*
114 * Set client data constructor and destructor.
115 */
116 async_set_client_data_constructor(vfs_client_data_create);
117 async_set_client_data_destructor(vfs_client_data_destroy);
118
119 /*
120 * Create a port for the pager.
121 */
122 port_id_t port;
123 rc = async_create_port(INTERFACE_PAGER, vfs_pager, NULL, &port);
124 if (rc != EOK)
125 return rc;
126
127 /*
128 * Set a connection handling function/fibril.
129 */
130 async_set_fallback_port_handler(vfs_connection, NULL);
131
132 /*
133 * Subscribe to notifications.
134 */
135 async_event_task_subscribe(EVENT_TASK_STATE_CHANGE, notification_handler,
136 NULL);
137
138 /*
139 * Register at the naming service.
140 */
141 rc = service_register(SERVICE_VFS);
142 if (rc != EOK) {
143 printf("%s: Cannot register VFS service\n", NAME);
144 return rc;
145 }
146
147 /*
148 * Start accepting connections.
149 */
150 printf("%s: Accepting connections\n", NAME);
151 async_manager();
152 return 0;
153}
154
155/**
156 * @}
157 */
Note: See TracBrowser for help on using the repository browser.