]> rtime.felk.cvut.cz Git - l4.git/blob - l4/pkg/l4re-core/libsigma0/lib/src/kip.c
Update
[l4.git] / l4 / pkg / l4re-core / libsigma0 / lib / src / kip.c
1 /**
2  * \file        sigma0/lib/src/kip.c
3  * \brief       map kernel info page using sigma0 protocol
4  *
5  * \date        02/2006
6  * \author      Adam Lackorzynski <adam@os.inf.tu-dresden.de>
7  *              Frank Mehnert <fm3@os.inf.tu-dresden.de> */
8
9 /*
10  * (c) 2006-2009 Author(s)
11  *     economic rights: Technische Universität Dresden (Germany)
12  * This file is part of TUD:OS and distributed under the terms of the
13  * GNU Lesser General Public License 2.1.
14  * Please see the COPYING-LGPL-2.1 file for details.
15  */
16
17 #include <l4/sys/ipc.h>
18 #include <l4/sigma0/sigma0.h>
19
20 /*
21  * \return kip address, 0 on error
22  */
23 L4_CV l4_kernel_info_t *
24 l4sigma0_map_kip(l4_cap_idx_t pager, void *adr, unsigned log2_size)
25 {
26   l4_msgtag_t tag = l4_msgtag(L4_PROTO_SIGMA0, 1, 0, 0);
27   l4_utcb_t *utcb = l4_utcb();
28   l4_msg_regs_t *m = l4_utcb_mr_u(utcb);
29   l4_buf_regs_t *b = l4_utcb_br_u(utcb);
30
31   l4_addr_t addr = (l4_addr_t)adr & (~0ULL << log2_size);
32   m->mr[0] = SIGMA0_REQ_KIP;
33   b->bdr = 0;
34   b->br[0] = L4_ITEM_MAP;
35   b->br[1] = l4_fpage(addr, log2_size, L4_FPAGE_RX).raw;
36
37   tag = l4_ipc_call(pager, utcb, tag, L4_IPC_NEVER);
38   if (l4_ipc_error(tag, utcb))
39     return 0;
40
41   if (l4_msgtag_items(tag) != 1)
42     return 0;
43
44   l4_addr_t a = addr + (m->mr[0] & (~0UL << L4_PAGESHIFT) & ((1ULL << log2_size)-1));
45
46   return (l4_kernel_info_t*)a;
47 }
48