aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc
diff options
context:
space:
mode:
authorSam Ravnborg <sam@ravnborg.org>2012-07-26 07:02:24 -0400
committerDavid S. Miller <davem@davemloft.net>2012-07-26 19:46:16 -0400
commitb585e8551b352cee95cf060b7eddc76d16e6120a (patch)
tree92f5346a503111037a5cbb80b0892b7a04fd97c6 /arch/sparc
parent59b00c792f0302b43e098849febc52386be5fd54 (diff)
sparc32: centralize all mmu context handling in srmmu.c
Signed-off-by: Sam Ravnborg <sam@ravnborg.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc')
-rw-r--r--arch/sparc/include/asm/mmu_context_32.h8
-rw-r--r--arch/sparc/include/asm/pgtable_32.h32
-rw-r--r--arch/sparc/kernel/setup_32.c1
-rw-r--r--arch/sparc/mm/fault_32.c6
-rw-r--r--arch/sparc/mm/init_32.c18
-rw-r--r--arch/sparc/mm/srmmu.c69
6 files changed, 63 insertions, 71 deletions
diff --git a/arch/sparc/include/asm/mmu_context_32.h b/arch/sparc/include/asm/mmu_context_32.h
index 01456c900720..2df2a9be8f6d 100644
--- a/arch/sparc/include/asm/mmu_context_32.h
+++ b/arch/sparc/include/asm/mmu_context_32.h
@@ -9,14 +9,12 @@ static inline void enter_lazy_tlb(struct mm_struct *mm, struct task_struct *tsk)
9{ 9{
10} 10}
11 11
12/* 12/* Initialize a new mmu context. This is invoked when a new
13 * Initialize a new mmu context. This is invoked when a new
14 * address space instance (unique or shared) is instantiated. 13 * address space instance (unique or shared) is instantiated.
15 */ 14 */
16#define init_new_context(tsk, mm) (((mm)->context = NO_CONTEXT), 0) 15int init_new_context(struct task_struct *tsk, struct mm_struct *mm);
17 16
18/* 17/* Destroy a dead context. This occurs when mmput drops the
19 * Destroy a dead context. This occurs when mmput drops the
20 * mm_users count to zero, the mmaps have been released, and 18 * mm_users count to zero, the mmaps have been released, and
21 * all the page tables have been flushed. Our job is to destroy 19 * all the page tables have been flushed. Our job is to destroy
22 * any remaining processor-specific state. 20 * any remaining processor-specific state.
diff --git a/arch/sparc/include/asm/pgtable_32.h b/arch/sparc/include/asm/pgtable_32.h
index c704f949b7ef..97a48807361e 100644
--- a/arch/sparc/include/asm/pgtable_32.h
+++ b/arch/sparc/include/asm/pgtable_32.h
@@ -79,8 +79,6 @@ extern unsigned long ptr_in_current_pgd;
79#define __S110 PAGE_SHARED 79#define __S110 PAGE_SHARED
80#define __S111 PAGE_SHARED 80#define __S111 PAGE_SHARED
81 81
82extern int num_contexts;
83
84/* First physical page can be anywhere, the following is needed so that 82/* First physical page can be anywhere, the following is needed so that
85 * va-->pa and vice versa conversions work properly without performance 83 * va-->pa and vice versa conversions work properly without performance
86 * hit for all __pa()/__va() operations. 84 * hit for all __pa()/__va() operations.
@@ -399,36 +397,6 @@ static inline pte_t pgoff_to_pte(unsigned long pgoff)
399 */ 397 */
400#define PTE_FILE_MAX_BITS 24 398#define PTE_FILE_MAX_BITS 24
401 399
402/*
403 */
404struct ctx_list {
405 struct ctx_list *next;
406 struct ctx_list *prev;
407 unsigned int ctx_number;
408 struct mm_struct *ctx_mm;
409};
410
411extern struct ctx_list *ctx_list_pool; /* Dynamically allocated */
412extern struct ctx_list ctx_free; /* Head of free list */
413extern struct ctx_list ctx_used; /* Head of used contexts list */
414
415#define NO_CONTEXT -1
416
417static inline void remove_from_ctx_list(struct ctx_list *entry)
418{
419 entry->next->prev = entry->prev;
420 entry->prev->next = entry->next;
421}
422
423static inline void add_to_ctx_list(struct ctx_list *head, struct ctx_list *entry)
424{
425 entry->next = head;
426 (entry->prev = head->prev)->next = entry;
427 head->prev = entry;
428}
429#define add_to_free_ctxlist(entry) add_to_ctx_list(&ctx_free, entry)
430#define add_to_used_ctxlist(entry) add_to_ctx_list(&ctx_used, entry)
431
432static inline unsigned long 400static inline unsigned long
433__get_phys (unsigned long addr) 401__get_phys (unsigned long addr)
434{ 402{
diff --git a/arch/sparc/kernel/setup_32.c b/arch/sparc/kernel/setup_32.c
index efe3e64bba38..38bf80a22f02 100644
--- a/arch/sparc/kernel/setup_32.c
+++ b/arch/sparc/kernel/setup_32.c
@@ -371,7 +371,6 @@ void __init setup_arch(char **cmdline_p)
371 (*(linux_dbvec->teach_debugger))(); 371 (*(linux_dbvec->teach_debugger))();
372 } 372 }
373 373
374 init_mm.context = (unsigned long) NO_CONTEXT;
375 init_task.thread.kregs = &fake_swapper_regs; 374 init_task.thread.kregs = &fake_swapper_regs;
376 375
377 /* Run-time patch instructions to match the cpu model */ 376 /* Run-time patch instructions to match the cpu model */
diff --git a/arch/sparc/mm/fault_32.c b/arch/sparc/mm/fault_32.c
index f46cf6be3370..e58f9ee718cb 100644
--- a/arch/sparc/mm/fault_32.c
+++ b/arch/sparc/mm/fault_32.c
@@ -32,12 +32,6 @@
32 32
33int show_unhandled_signals = 1; 33int show_unhandled_signals = 1;
34 34
35/* At boot time we determine these two values necessary for setting
36 * up the segment maps and page table entries (pte's).
37 */
38
39int num_contexts;
40
41/* Return how much physical memory we have. */ 35/* Return how much physical memory we have. */
42unsigned long probe_memory(void) 36unsigned long probe_memory(void)
43{ 37{
diff --git a/arch/sparc/mm/init_32.c b/arch/sparc/mm/init_32.c
index 6d44c2b80d66..020d2afa0030 100644
--- a/arch/sparc/mm/init_32.c
+++ b/arch/sparc/mm/init_32.c
@@ -82,24 +82,6 @@ void show_mem(unsigned int filter)
82#endif 82#endif
83} 83}
84 84
85void __init sparc_context_init(int numctx)
86{
87 int ctx;
88
89 ctx_list_pool = __alloc_bootmem(numctx * sizeof(struct ctx_list), SMP_CACHE_BYTES, 0UL);
90
91 for(ctx = 0; ctx < numctx; ctx++) {
92 struct ctx_list *clist;
93
94 clist = (ctx_list_pool + ctx);
95 clist->ctx_number = ctx;
96 clist->ctx_mm = NULL;
97 }
98 ctx_free.next = ctx_free.prev = &ctx_free;
99 ctx_used.next = ctx_used.prev = &ctx_used;
100 for(ctx = 0; ctx < numctx; ctx++)
101 add_to_free_ctxlist(ctx_list_pool + ctx);
102}
103 85
104extern unsigned long cmdline_memory_size; 86extern unsigned long cmdline_memory_size;
105unsigned long last_valid_pfn; 87unsigned long last_valid_pfn;
diff --git a/arch/sparc/mm/srmmu.c b/arch/sparc/mm/srmmu.c
index ab62595cf366..ad93d2ee6be2 100644
--- a/arch/sparc/mm/srmmu.c
+++ b/arch/sparc/mm/srmmu.c
@@ -55,10 +55,6 @@ static unsigned int hwbug_bitmask;
55int vac_cache_size; 55int vac_cache_size;
56int vac_line_size; 56int vac_line_size;
57 57
58struct ctx_list *ctx_list_pool;
59struct ctx_list ctx_free;
60struct ctx_list ctx_used;
61
62extern struct resource sparc_iomap; 58extern struct resource sparc_iomap;
63 59
64extern unsigned long last_valid_pfn; 60extern unsigned long last_valid_pfn;
@@ -355,8 +351,39 @@ void pte_free(struct mm_struct *mm, pgtable_t pte)
355 srmmu_free_nocache(__nocache_va(p), PTE_SIZE); 351 srmmu_free_nocache(__nocache_va(p), PTE_SIZE);
356} 352}
357 353
358/* 354/* context handling - a dynamically sized pool is used */
359 */ 355#define NO_CONTEXT -1
356
357struct ctx_list {
358 struct ctx_list *next;
359 struct ctx_list *prev;
360 unsigned int ctx_number;
361 struct mm_struct *ctx_mm;
362};
363
364static struct ctx_list *ctx_list_pool;
365static struct ctx_list ctx_free;
366static struct ctx_list ctx_used;
367
368/* At boot time we determine the number of contexts */
369static int num_contexts;
370
371static inline void remove_from_ctx_list(struct ctx_list *entry)
372{
373 entry->next->prev = entry->prev;
374 entry->prev->next = entry->next;
375}
376
377static inline void add_to_ctx_list(struct ctx_list *head, struct ctx_list *entry)
378{
379 entry->next = head;
380 (entry->prev = head->prev)->next = entry;
381 head->prev = entry;
382}
383#define add_to_free_ctxlist(entry) add_to_ctx_list(&ctx_free, entry)
384#define add_to_used_ctxlist(entry) add_to_ctx_list(&ctx_used, entry)
385
386
360static inline void alloc_context(struct mm_struct *old_mm, struct mm_struct *mm) 387static inline void alloc_context(struct mm_struct *old_mm, struct mm_struct *mm)
361{ 388{
362 struct ctx_list *ctxp; 389 struct ctx_list *ctxp;
@@ -392,6 +419,26 @@ static inline void free_context(int context)
392 add_to_free_ctxlist(ctx_old); 419 add_to_free_ctxlist(ctx_old);
393} 420}
394 421
422static void __init sparc_context_init(int numctx)
423{
424 int ctx;
425 unsigned long size;
426
427 size = numctx * sizeof(struct ctx_list);
428 ctx_list_pool = __alloc_bootmem(size, SMP_CACHE_BYTES, 0UL);
429
430 for (ctx = 0; ctx < numctx; ctx++) {
431 struct ctx_list *clist;
432
433 clist = (ctx_list_pool + ctx);
434 clist->ctx_number = ctx;
435 clist->ctx_mm = NULL;
436 }
437 ctx_free.next = ctx_free.prev = &ctx_free;
438 ctx_used.next = ctx_used.prev = &ctx_used;
439 for (ctx = 0; ctx < numctx; ctx++)
440 add_to_free_ctxlist(ctx_list_pool + ctx);
441}
395 442
396void switch_mm(struct mm_struct *old_mm, struct mm_struct *mm, 443void switch_mm(struct mm_struct *old_mm, struct mm_struct *mm,
397 struct task_struct *tsk) 444 struct task_struct *tsk)
@@ -799,9 +846,6 @@ static void __init map_kernel(void)
799 } 846 }
800} 847}
801 848
802/* Paging initialization on the Sparc Reference MMU. */
803extern void sparc_context_init(int);
804
805void (*poke_srmmu)(void) __cpuinitdata = NULL; 849void (*poke_srmmu)(void) __cpuinitdata = NULL;
806 850
807extern unsigned long bootmem_init(unsigned long *pages_avail); 851extern unsigned long bootmem_init(unsigned long *pages_avail);
@@ -816,6 +860,7 @@ void __init srmmu_paging_init(void)
816 pte_t *pte; 860 pte_t *pte;
817 unsigned long pages_avail; 861 unsigned long pages_avail;
818 862
863 init_mm.context = (unsigned long) NO_CONTEXT;
819 sparc_iomap.start = SUN4M_IOBASE_VADDR; /* 16MB of IOSPACE on all sun4m's. */ 864 sparc_iomap.start = SUN4M_IOBASE_VADDR; /* 16MB of IOSPACE on all sun4m's. */
820 865
821 if (sparc_cpu_model == sun4d) 866 if (sparc_cpu_model == sun4d)
@@ -918,6 +963,12 @@ void mmu_info(struct seq_file *m)
918 srmmu_nocache_map.used << SRMMU_NOCACHE_BITMAP_SHIFT); 963 srmmu_nocache_map.used << SRMMU_NOCACHE_BITMAP_SHIFT);
919} 964}
920 965
966int init_new_context(struct task_struct *tsk, struct mm_struct *mm)
967{
968 mm->context = NO_CONTEXT;
969 return 0;
970}
971
921void destroy_context(struct mm_struct *mm) 972void destroy_context(struct mm_struct *mm)
922{ 973{
923 974