1. 01 4月, 2009 1 次提交
  2. 23 10月, 2008 1 次提交
  3. 06 2月, 2008 3 次提交
    • J
      uml: 64-bit tlb fixes · 909e90d3
      Jeff Dike 提交于
      Some 64-bit tlb fixes -
      	moved pmd_page_vaddr to pgtable.h since it's the same for both
      2-level and 3-level page tables
      	fixed a bogus cast on pud_page_vaddr
      	made the address checking in update_*_range more careful
      Signed-off-by: NJeff Dike <jdike@linux.intel.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      909e90d3
    • J
      uml: fix page table data sizes · 655e4ed0
      Jeff Dike 提交于
      Get the sizes of various pieces of data right when using three-level
      page tables.  pgd and pmd entries remain at 32 bits in a 32-bit
      compilation because page tables will remain in low memory.  So,
      PGDIR_SHIFT, the PTRS_PER_* values, set_pud, set_pmd are conditional
      on 64BIT.
      
      More use of phys_t is made when there are physical memory addresses
      floating around.
      
      ObCheckpatchViolationJustification - the new typedef is an alternate
      definition of pmd_t, which I can't really live without.
      Signed-off-by: NJeff Dike <jdike@linux.intel.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      655e4ed0
    • J
      uml: header untangling · 8192ab42
      Jeff Dike 提交于
      Untangle UML headers somewhat and add some includes where they were
      needed explicitly, but gotten accidentally via some other header.
      
      arch/um/include/um_uaccess.h loses asm/fixmap.h because it uses no
      fixmap stuff and gains elf.h, because it needs FIXADDR_USER_*, and
      archsetjmp.h, because it needs jmp_buf.
      
      pmd_alloc_one is uninlined because it needs mm_struct, and that's
      inconvenient to provide in asm-um/pgtable-3level.h.
      
      elf_core_copy_fpregs is also uninlined from elf-i386.h and
      elf-x86_64.h, which duplicated the code anyway, to
      arch/um/kernel/process.c, so that the reference to current_thread
      doesn't pull sched.h or anything related into asm/elf.h.
      
      arch/um/sys-i386/ldt.c, arch/um/kernel/tlb.c and
      arch/um/kernel/skas/uaccess.c got sched.h because they dereference
      task_structs.  Its includes of linux and asm headers got turned from
      "" to <>.
      
      arch/um/sys-i386/bug.c gets asm/errno.h because it needs errno
      constants.
      
      asm/elf-i386 gets asm/user.h because it needs user_regs_struct.
      
      asm/fixmap.h gets page.h because it needs PAGE_SIZE and PAGE_MASK and
      system.h for BUG_ON.
      
      asm/pgtable doesn't need sched.h.
      
      asm/processor-generic.h defined mm_segment_t, but didn't use it.  So,
      that definition is moved to uaccess.h, which defines a bunch of
      mm_segment_t-related stuff.  thread_info.h uses mm_segment_t, and
      includes uaccess.h, which causes a recursion.  So, the definition is
      placed above the include of thread_info. in uaccess.h.  thread_info.h
      also gets page.h because it needs PAGE_SIZE.
      
      ObCheckpatchViolationJustification - I'm not adding a typedef; I'm
      moving mm_segment_t from one place to another.
      Signed-off-by: NJeff Dike <jdike@linux.intel.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      8192ab42
  4. 15 11月, 2007 1 次提交
    • J
      uml: update address space affected by pud_clear · 8cd8fa55
      Jeff Dike 提交于
      pud_clear wasn't setting the _PAGE_NEWPAGE bit, fooling tlb_flush into
      thinking that this area of the address space was up-to-date and not unmapping
      whatever was covered by the pud.
      
      This manifested itself as ldconfig on x86_64 complaining about the first
      library it looked at not being a valid ELF file.  A config file is mapped at
      0x4000000, as the only thing mapped under its pud, and unmapped.  The
      unmapping caused a pud_clear, which, due to this bug, didn't actually unmap
      the config file data on the host.  The first library is then mapped at the
      same location, but is not actually mapped on the host because accesses to it
      cause no page faults.  As a result, ldconfig sees the old config file data.
      
      [akpm@linux-foundation.org: coding-style cleanups]
      Signed-off-by: NJeff Dike <jdike@linux.intel.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      8cd8fa55
  5. 17 10月, 2007 1 次提交
  6. 26 9月, 2006 1 次提交
    • D
      [PATCH] Standardize pxx_page macros · 46a82b2d
      Dave McCracken 提交于
      One of the changes necessary for shared page tables is to standardize the
      pxx_page macros.  pte_page and pmd_page have always returned the struct
      page associated with their entry, while pte_page_kernel and pmd_page_kernel
      have returned the kernel virtual address.  pud_page and pgd_page, on the
      other hand, return the kernel virtual address.
      
      Shared page tables needs pud_page and pgd_page to return the actual page
      structures.  There are very few actual users of these functions, so it is
      simple to standardize their usage.
      
      Since this is basic cleanup, I am submitting these changes as a standalone
      patch.  Per Hugh Dickins' comments about it, I am also changing the
      pxx_page_kernel macros to pxx_page_vaddr to clarify their meaning.
      Signed-off-by: NDave McCracken <dmccr@us.ibm.com>
      Cc: Hugh Dickins <hugh@veritas.com>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      46a82b2d
  7. 05 9月, 2005 2 次提交
  8. 06 5月, 2005 1 次提交
  9. 01 5月, 2005 1 次提交
  10. 20 4月, 2005 1 次提交
  11. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4