patch-2.4.0-test4 linux/arch/sparc/mm/srmmu.c
Next file: linux/arch/sparc/mm/sun4c.c
Previous file: linux/arch/sparc/mm/init.c
Back to the patch index
Back to the overall index
- Lines: 47
- Date:
Tue Jul 11 11:07:55 2000
- Orig file:
v2.4.0-test3/linux/arch/sparc/mm/srmmu.c
- Orig date:
Mon Jul 10 16:47:20 2000
diff -u --recursive --new-file v2.4.0-test3/linux/arch/sparc/mm/srmmu.c linux/arch/sparc/mm/srmmu.c
@@ -1,4 +1,4 @@
-/* $Id: srmmu.c,v 1.215 2000/06/30 13:25:28 anton Exp $
+/* $Id: srmmu.c,v 1.218 2000/07/10 23:22:32 anton Exp $
* srmmu.c: SRMMU specific routines for memory management.
*
* Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu)
@@ -57,6 +57,8 @@
extern unsigned long last_valid_pfn;
+extern unsigned long page_kernel;
+
pgd_t *srmmu_swapper_pg_dir;
#ifdef CONFIG_SMP
@@ -442,7 +444,6 @@
if(srmmu_pmd_none(*pmd)) {
pte_t *page = (pte_t *)srmmu_get_nocache(SRMMU_PTE_TABLE_SIZE, SRMMU_PTE_TABLE_SIZE);
if(page) {
- spin_unlock(&pte_spinlock);
srmmu_pmd_set(pmd, page);
return page + address;
}
@@ -467,7 +468,6 @@
if(srmmu_pgd_none(*pgd)) {
pmd_t *page = (pmd_t *)srmmu_get_nocache(SRMMU_PMD_TABLE_SIZE, SRMMU_PMD_TABLE_SIZE);
if(page) {
- spin_unlock(&pte_spinlock);
srmmu_pgd_set(pgd, page);
return page + address;
}
@@ -2101,6 +2101,7 @@
static void smp_flush_page_for_dma(unsigned long page)
{
xc1((smpfunc_t) BTFIXUP_CALL(local_flush_page_for_dma), page);
+ local_flush_page_for_dma(page);
}
#endif
@@ -2129,6 +2130,7 @@
BTFIXUPSET_INT(page_copy, pgprot_val(SRMMU_PAGE_COPY));
BTFIXUPSET_INT(page_readonly, pgprot_val(SRMMU_PAGE_RDONLY));
BTFIXUPSET_INT(page_kernel, pgprot_val(SRMMU_PAGE_KERNEL));
+ page_kernel = pgprot_val(SRMMU_PAGE_KERNEL);
pg_iobits = SRMMU_VALID | SRMMU_WRITE | SRMMU_REF;
/* Functions */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)