|
@@ -71,7 +71,7 @@ void show_mem(void)
|
|
* Associate a virtual page frame with a given physical page frame
|
|
* Associate a virtual page frame with a given physical page frame
|
|
* and protection flags for that frame.
|
|
* and protection flags for that frame.
|
|
*/
|
|
*/
|
|
-static void set_pte_pfn(unsigned long vaddr, unsigned long pfn, pgprot_t flags)
|
|
|
|
|
|
+void set_pte_vaddr(unsigned long vaddr, pte_t pteval)
|
|
{
|
|
{
|
|
pgd_t *pgd;
|
|
pgd_t *pgd;
|
|
pud_t *pud;
|
|
pud_t *pud;
|
|
@@ -94,8 +94,8 @@ static void set_pte_pfn(unsigned long vaddr, unsigned long pfn, pgprot_t flags)
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
pte = pte_offset_kernel(pmd, vaddr);
|
|
pte = pte_offset_kernel(pmd, vaddr);
|
|
- if (pgprot_val(flags))
|
|
|
|
- set_pte_present(&init_mm, vaddr, pte, pfn_pte(pfn, flags));
|
|
|
|
|
|
+ if (pte_val(pteval))
|
|
|
|
+ set_pte_present(&init_mm, vaddr, pte, pteval);
|
|
else
|
|
else
|
|
pte_clear(&init_mm, vaddr, pte);
|
|
pte_clear(&init_mm, vaddr, pte);
|
|
|
|
|
|
@@ -145,18 +145,6 @@ static int fixmaps;
|
|
unsigned long __FIXADDR_TOP = 0xfffff000;
|
|
unsigned long __FIXADDR_TOP = 0xfffff000;
|
|
EXPORT_SYMBOL(__FIXADDR_TOP);
|
|
EXPORT_SYMBOL(__FIXADDR_TOP);
|
|
|
|
|
|
-void __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t flags)
|
|
|
|
-{
|
|
|
|
- unsigned long address = __fix_to_virt(idx);
|
|
|
|
-
|
|
|
|
- if (idx >= __end_of_fixed_addresses) {
|
|
|
|
- BUG();
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
- set_pte_pfn(address, phys >> PAGE_SHIFT, flags);
|
|
|
|
- fixmaps++;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
/**
|
|
/**
|
|
* reserve_top_address - reserves a hole in the top of kernel address space
|
|
* reserve_top_address - reserves a hole in the top of kernel address space
|
|
* @reserve - size of hole to reserve
|
|
* @reserve - size of hole to reserve
|
|
@@ -166,7 +154,7 @@ void __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t flags)
|
|
*/
|
|
*/
|
|
void reserve_top_address(unsigned long reserve)
|
|
void reserve_top_address(unsigned long reserve)
|
|
{
|
|
{
|
|
- BUG_ON(fixmaps > 0);
|
|
|
|
|
|
+ BUG_ON(fixmaps_set > 0);
|
|
printk(KERN_INFO "Reserving virtual address space above 0x%08x\n",
|
|
printk(KERN_INFO "Reserving virtual address space above 0x%08x\n",
|
|
(int)-reserve);
|
|
(int)-reserve);
|
|
__FIXADDR_TOP = -reserve - PAGE_SIZE;
|
|
__FIXADDR_TOP = -reserve - PAGE_SIZE;
|