source: mainline/src/mm/page.c@ 9c0a9b3

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 9c0a9b3 was 9c0a9b3, checked in by Jakub Vana <jakub.vana@…>, 20 years ago

1) memcopy and _memcopy functions rewriten to ANSI C norm.
2) Repaired ia32,ia64 and mips version of SPARTAN to work with this memcopy functions
3) Warning for non declared funcions added and repaired ia32,ia64 and mips versions to pass build process with this warning and Werror option

  • Property mode set to 100644
File size: 3.8 KB
RevLine 
[f761f1eb]1/*
2 * Copyright (C) 2001-2004 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#include <mm/page.h>
[ff9f858]30#include <mm/frame.h>
[f761f1eb]31#include <arch/mm/page.h>
[74df77d]32#include <arch/types.h>
33#include <typedefs.h>
[ff9f858]34#include <arch/asm.h>
[9c0a9b3]35#include <memstr.h>
36
[f761f1eb]37
38void page_init(void)
39{
40 page_arch_init();
[7eade45]41 map_page_to_frame(0x0, 0x0, PAGE_NOT_PRESENT, 0);
[f761f1eb]42}
[74df77d]43
44/** Map memory structure
45 *
46 * Identity-map memory structure
47 * considering possible crossings
48 * of page boundaries.
49 *
50 * @param s Address of the structure.
51 * @param size Size of the structure.
52 */
53void map_structure(__address s, size_t size)
54{
55 int i, cnt, length;
56
57 /* TODO: implement portable way of computing page address from address */
[76cec1e]58 length = size + (s - (s & 0xfffff000));
59 cnt = length/PAGE_SIZE + (length%PAGE_SIZE>0);
[74df77d]60
[76cec1e]61 for (i = 0; i < cnt; i++)
62 map_page_to_frame(s + i*PAGE_SIZE, s + i*PAGE_SIZE, PAGE_NOT_CACHEABLE, 0);
[74df77d]63
64}
[ff9f858]65
66/** Map page to frame
67 *
68 * Map virtual address 'page' to physical address 'frame'
69 * using 'flags'. Allocate and setup any missing page tables.
70 *
71 * @param page Virtual address of the page to be mapped.
72 * @param frame Physical address of memory frame to which the mapping is done.
73 * @param flags Flags to be used for mapping.
74 * @param root Explicit PTL0 address.
75 */
76void map_page_to_frame(__address page, __address frame, int flags, __address root)
77{
[76cec1e]78 pte_t *ptl0, *ptl1, *ptl2, *ptl3;
79 __address newpt;
[ff9f858]80
[f79e357]81 ptl0 = (pte_t *) PA2KA(root ? root : (__address) GET_PTL0_ADDRESS());
[ff9f858]82
[76cec1e]83 if (GET_PTL1_FLAGS(ptl0, PTL0_INDEX(page)) & PAGE_NOT_PRESENT) {
84 newpt = frame_alloc(FRAME_KA);
85 memsetb(newpt, PAGE_SIZE, 0);
86 SET_PTL1_ADDRESS(ptl0, PTL0_INDEX(page), KA2PA(newpt));
87 SET_PTL1_FLAGS(ptl0, PTL0_INDEX(page), PAGE_PRESENT | PAGE_USER);
88 }
[ff9f858]89
[76cec1e]90 ptl1 = (pte_t *) PA2KA(GET_PTL1_ADDRESS(ptl0, PTL0_INDEX(page)));
[ff9f858]91
[76cec1e]92 if (GET_PTL2_FLAGS(ptl1, PTL1_INDEX(page)) & PAGE_NOT_PRESENT) {
93 newpt = frame_alloc(FRAME_KA);
94 memsetb(newpt, PAGE_SIZE, 0);
95 SET_PTL2_ADDRESS(ptl1, PTL1_INDEX(page), KA2PA(newpt));
96 SET_PTL2_FLAGS(ptl1, PTL1_INDEX(page), PAGE_PRESENT | PAGE_USER);
97 }
[ff9f858]98
[76cec1e]99 ptl2 = (pte_t *) PA2KA(GET_PTL2_ADDRESS(ptl1, PTL1_INDEX(page)));
[ff9f858]100
[76cec1e]101 if (GET_PTL3_FLAGS(ptl2, PTL2_INDEX(page)) & PAGE_NOT_PRESENT) {
102 newpt = frame_alloc(FRAME_KA);
103 memsetb(newpt, PAGE_SIZE, 0);
104 SET_PTL3_ADDRESS(ptl2, PTL2_INDEX(page), KA2PA(newpt));
105 SET_PTL3_FLAGS(ptl2, PTL2_INDEX(page), PAGE_PRESENT | PAGE_USER);
106 }
[ff9f858]107
[76cec1e]108 ptl3 = (pte_t *) PA2KA(GET_PTL3_ADDRESS(ptl2, PTL2_INDEX(page)));
[ff9f858]109
[76cec1e]110 SET_FRAME_ADDRESS(ptl3, PTL3_INDEX(page), frame);
111 SET_FRAME_FLAGS(ptl3, PTL3_INDEX(page), flags);
[ff9f858]112}
Note: See TracBrowser for help on using the repository browser.