blob: 9e7d52a62261dcf2fd289c7c74fb33685f0bf316 [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
2 * Copyright (c) 2015 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15/*
16 * physmem.h: virtual <-> physical memory mapping for VLIB buffers
17 *
18 * Copyright (c) 2008 Eliot Dresselhaus
19 *
20 * Permission is hereby granted, free of charge, to any person obtaining
21 * a copy of this software and associated documentation files (the
22 * "Software"), to deal in the Software without restriction, including
23 * without limitation the rights to use, copy, modify, merge, publish,
24 * distribute, sublicense, and/or sell copies of the Software, and to
25 * permit persons to whom the Software is furnished to do so, subject to
26 * the following conditions:
27 *
28 * The above copyright notice and this permission notice shall be
29 * included in all copies or substantial portions of the Software.
30 *
31 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
33 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
35 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
36 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
37 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
38 */
39
40#ifndef included_vlib_physmem_h
41#define included_vlib_physmem_h
42
Dave Barach9b8ffd92016-07-08 08:13:45 -040043typedef struct
44{
Ed Warnickecb9cada2015-12-08 15:45:58 -070045 uword start, end, size;
46} vlib_physmem_region_t;
47
Dave Barach9b8ffd92016-07-08 08:13:45 -040048typedef struct
49{
Ed Warnickecb9cada2015-12-08 15:45:58 -070050 vlib_physmem_region_t virtual;
51
52 uword log2_n_bytes_per_page;
53
54 /* 1 << log2_n_bytes_per_page - 1. */
55 uword page_mask;
56
Dave Barach9b8ffd92016-07-08 08:13:45 -040057 u64 *page_table;
Damjan Marionb4d89272016-05-12 22:14:45 +020058
59 /* is fake physmem */
60 u8 is_fake;
Ed Warnickecb9cada2015-12-08 15:45:58 -070061} vlib_physmem_main_t;
62
63always_inline u64
64vlib_physmem_offset_to_physical (vlib_physmem_main_t * pm, uword o)
65{
66 uword page_index = o >> pm->log2_n_bytes_per_page;
67 ASSERT (o < pm->virtual.size);
68 ASSERT (pm->page_table[page_index] != 0);
69 return (vec_elt (pm->page_table, page_index) + (o & pm->page_mask));
70}
71
72always_inline int
73vlib_physmem_is_virtual (vlib_physmem_main_t * pm, uword p)
Dave Barach9b8ffd92016-07-08 08:13:45 -040074{
75 return p >= pm->virtual.start && p < pm->virtual.end;
76}
Ed Warnickecb9cada2015-12-08 15:45:58 -070077
78always_inline uword
Dave Barach9b8ffd92016-07-08 08:13:45 -040079vlib_physmem_offset_of (vlib_physmem_main_t * pm, void *p)
Ed Warnickecb9cada2015-12-08 15:45:58 -070080{
81 uword a = pointer_to_uword (p);
82 uword o;
83
84 ASSERT (vlib_physmem_is_virtual (pm, a));
85 o = a - pm->virtual.start;
86
87 /* Offset must fit in 32 bits. */
88 ASSERT ((uword) o == a - pm->virtual.start);
89
90 return o;
91}
92
93always_inline void *
94vlib_physmem_at_offset (vlib_physmem_main_t * pm, uword offset)
95{
96 ASSERT (offset < pm->virtual.size);
97 return uword_to_pointer (pm->virtual.start + offset, void *);
98}
99
100#endif /* included_vlib_physmem_h */
Dave Barach9b8ffd92016-07-08 08:13:45 -0400101
102/*
103 * fd.io coding-style-patch-verification: ON
104 *
105 * Local Variables:
106 * eval: (c-set-style "gnu")
107 * End:
108 */