Subversion Repositories HelenOS

Rev

Rev 2787 | Rev 4377 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2787 Rev 3597
Line 45... Line 45...
45
#include <config.h>
45
#include <config.h>
46
#include <panic.h>
46
#include <panic.h>
47
#include <arch/asm.h>
47
#include <arch/asm.h>
48
#include <arch/barrier.h>
48
#include <arch/barrier.h>
49
#include <memstr.h>
49
#include <memstr.h>
-
 
50
#include <align.h>
50
 
51
 
51
static void set_environment(void);
52
static void set_environment(void);
52
 
53
 
53
/** Initialize ia64 virtual address translation subsystem. */
54
/** Initialize ia64 virtual address translation subsystem. */
54
void page_arch_init(void)
55
void page_arch_init(void)
Line 260... Line 261...
260
    v->present.ps = PAGE_WIDTH;
261
    v->present.ps = PAGE_WIDTH;
261
    v->present.key = 0;
262
    v->present.key = 0;
262
    v->present.tag.tag_word = tag;
263
    v->present.tag.tag_word = tag;
263
}
264
}
264
 
265
 
-
 
266
extern uintptr_t last_frame;
-
 
267
 
-
 
268
 
-
 
269
uintptr_t hw_map(uintptr_t physaddr, size_t size)
-
 
270
{
-
 
271
    if (last_frame + ALIGN_UP(size, PAGE_SIZE) > KA2PA(KERNEL_ADDRESS_SPACE_END_ARCH))
-
 
272
        panic("Unable to map physical memory %p (%d bytes)", physaddr, size)
-
 
273
   
-
 
274
    uintptr_t virtaddr = PA2KA(last_frame);
-
 
275
    pfn_t i;
-
 
276
    for (i = 0; i < ADDR2PFN(ALIGN_UP(size, PAGE_SIZE)); i++) {
-
 
277
        uintptr_t addr = PFN2ADDR(i);
-
 
278
        page_mapping_insert(AS_KERNEL, virtaddr + addr, physaddr + addr, PAGE_NOT_CACHEABLE | PAGE_WRITE);
-
 
279
    }
-
 
280
   
-
 
281
    last_frame = ALIGN_UP(last_frame + size, FRAME_SIZE);
-
 
282
   
-
 
283
    return virtaddr;
-
 
284
}
-
 
285
 
-
 
286
 
-
 
287
 
265
/** @}
288
/** @}
266
 */
289
 */