~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/loongarch/include/asm/hugetlb.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/loongarch/include/asm/hugetlb.h (Architecture sparc) and /arch/ppc/include/asm-ppc/hugetlb.h (Architecture ppc)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 
  2 /*                                                
  3  * Copyright (C) 2020-2022 Loongson Technology    
  4  */                                               
  5                                                   
  6 #ifndef __ASM_HUGETLB_H                           
  7 #define __ASM_HUGETLB_H                           
  8                                                   
  9 #include <asm/page.h>                             
 10                                                   
 11 uint64_t pmd_to_entrylo(unsigned long pmd_val)    
 12                                                   
 13 #define __HAVE_ARCH_PREPARE_HUGEPAGE_RANGE        
 14 static inline int prepare_hugepage_range(struc    
 15                                          unsig    
 16                                          unsig    
 17 {                                                 
 18         unsigned long task_size = STACK_TOP;      
 19         struct hstate *h = hstate_file(file);     
 20                                                   
 21         if (len & ~huge_page_mask(h))             
 22                 return -EINVAL;                   
 23         if (addr & ~huge_page_mask(h))            
 24                 return -EINVAL;                   
 25         if (len > task_size)                      
 26                 return -ENOMEM;                   
 27         if (task_size - len < addr)               
 28                 return -EINVAL;                   
 29         return 0;                                 
 30 }                                                 
 31                                                   
 32 #define __HAVE_ARCH_HUGE_PTEP_GET_AND_CLEAR       
 33 static inline pte_t huge_ptep_get_and_clear(st    
 34                                             un    
 35 {                                                 
 36         pte_t clear;                              
 37         pte_t pte = ptep_get(ptep);               
 38                                                   
 39         pte_val(clear) = (unsigned long)invali    
 40         set_pte_at(mm, addr, ptep, clear);        
 41         return pte;                               
 42 }                                                 
 43                                                   
 44 #define __HAVE_ARCH_HUGE_PTEP_CLEAR_FLUSH         
 45 static inline pte_t huge_ptep_clear_flush(stru    
 46                                           unsi    
 47 {                                                 
 48         pte_t pte;                                
 49                                                   
 50         pte = huge_ptep_get_and_clear(vma->vm_    
 51         flush_tlb_page(vma, addr);                
 52         return pte;                               
 53 }                                                 
 54                                                   
 55 #define __HAVE_ARCH_HUGE_PTE_NONE                 
 56 static inline int huge_pte_none(pte_t pte)        
 57 {                                                 
 58         unsigned long val = pte_val(pte) & ~_P    
 59         return !val || (val == (unsigned long)    
 60 }                                                 
 61                                                   
 62 #define __HAVE_ARCH_HUGE_PTEP_SET_ACCESS_FLAGS    
 63 static inline int huge_ptep_set_access_flags(s    
 64                                              u    
 65                                              p    
 66                                              i    
 67 {                                                 
 68         int changed = !pte_same(ptep_get(ptep)    
 69                                                   
 70         if (changed) {                            
 71                 set_pte_at(vma->vm_mm, addr, p    
 72                 /*                                
 73                  * There could be some standar    
 74                  * get them all.                  
 75                  */                               
 76                 flush_tlb_range(vma, addr, add    
 77         }                                         
 78         return changed;                           
 79 }                                                 
 80                                                   
 81 #include <asm-generic/hugetlb.h>                  
 82                                                   
 83 #endif /* __ASM_HUGETLB_H */                      
 84                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php