Changeset 730ff63 in mainline for kernel/arch
- Timestamp:
- 2013-09-03T19:13:37Z (12 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- b3cf946
- Parents:
- 1b34360
- Location:
- kernel/arch/sparc64
- Files:
- 
      - 7 edited
 
 - 
          
  include/arch/mm/frame.h (modified) (1 diff)
- 
          
  include/arch/mm/sun4u/frame.h (modified) (1 diff)
- 
          
  include/arch/mm/sun4v/frame.h (modified) (1 diff)
- 
          
  include/arch/trap/sun4v/mmu.h (modified) (1 diff)
- 
          
  src/mm/sun4v/frame.c (modified) (1 diff)
- 
          
  src/mm/sun4v/tlb.c (modified) (3 diffs)
- 
          
  src/sun4v/start.S (modified) (1 diff)
 
Legend:
- Unmodified
- Added
- Removed
- 
      kernel/arch/sparc64/include/arch/mm/frame.hr1b34360 r730ff63 46 46 #endif 47 47 48 #ifndef __ASM__ 49 50 #include <typedefs.h> 51 52 extern uintptr_t end_of_identity; 53 54 extern void frame_low_arch_init(void); 55 extern void frame_high_arch_init(void); 56 #define physmem_print() 57 58 #endif 59 48 60 #endif 49 61 
- 
      kernel/arch/sparc64/include/arch/mm/sun4u/frame.hr1b34360 r730ff63 72 72 typedef union frame_address frame_address_t; 73 73 74 extern uintptr_t end_of_identity;75 76 extern void frame_low_arch_init(void);77 extern void frame_high_arch_init(void);78 #define physmem_print()79 80 74 #endif 81 75 
- 
      kernel/arch/sparc64/include/arch/mm/sun4v/frame.hr1b34360 r730ff63 42 42 #define FRAME_SIZE (1 << FRAME_WIDTH) 43 43 44 #ifndef __ASM__45 46 #include <typedefs.h>47 48 extern void frame_low_arch_init(void);49 extern void frame_high_arch_init(void);50 #define physmem_print()51 52 #endif53 54 44 #endif 55 45 
- 
      kernel/arch/sparc64/include/arch/trap/sun4v/mmu.hr1b34360 r730ff63 102 102 nop 103 103 104 /* exclude pages beyond the end of memory from the identity mapping */ 105 sethi %hi(end_of_identity), %g4 106 ldx [%g4 + %lo(end_of_identity)], %g4 107 cmp %g1, %g4 108 bgeu %xcc, 0f 109 nop 110 104 111 /* 105 112 * Installing the identity does not fit into 32 instructions, call 
- 
      kernel/arch/sparc64/src/mm/sun4v/frame.cr1b34360 r730ff63 101 101 */ 102 102 frame_mark_unavailable(ADDR2PFN(KA2PA(PFN2ADDR(0))), 1); 103 104 /* PA2KA will work only on low-memory. */ 105 end_of_identity = PA2KA(config.physmem_end - FRAME_SIZE) + PAGE_SIZE; 103 106 } 104 107 
- 
      kernel/arch/sparc64/src/mm/sun4v/tlb.cr1b34360 r730ff63 251 251 uintptr_t va = DMISS_ADDRESS(page_and_ctx); 252 252 uint16_t ctx = DMISS_CONTEXT(page_and_ctx); 253 as_t *as = AS; 253 254 254 255 if (ctx == ASID_KERNEL) { … … 256 257 /* NULL access in kernel */ 257 258 panic("NULL pointer dereference."); 259 } else if (va >= end_of_identity) { 260 /* Kernel non-identity */ 261 as = AS_KERNEL; 262 } else { 263 panic("Unexpected kernel page fault."); 258 264 } 259 panic("Unexpected kernel page fault."); 260 } 261 262 t = page_mapping_find(AS, va, true); 265 } 266 267 t = page_mapping_find(as, va, true); 263 268 if (t) { 264 269 /* … … 295 300 uintptr_t va = DMISS_ADDRESS(page_and_ctx); 296 301 uint16_t ctx = DMISS_CONTEXT(page_and_ctx); 297 298 t = page_mapping_find(AS, va, true); 302 as_t *as = AS; 303 304 if (ctx == ASID_KERNEL) 305 as = AS_KERNEL; 306 307 t = page_mapping_find(as, va, true); 299 308 if (t && PTE_WRITABLE(t)) { 300 309 /* 
- 
      kernel/arch/sparc64/src/sun4v/start.Sr1b34360 r730ff63 345 345 .quad 0 346 346 347 /* 348 * This variable is used by the fast_data_access_MMU_miss trap handler. 349 * In runtime, it is modified to contain the address of the end of physical 350 * memory. 351 */ 352 .global end_of_identity 353 end_of_identity: 354 .quad -1 355 347 356 .global kernel_8k_tlb_data_template 348 357 kernel_8k_tlb_data_template: 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
