Lines Matching refs:pte
52 #define pte_ERROR(pte) __pte_error(__FILE__, __LINE__, pte) argument
181 #define pte_pfn(pte) ((pte_val(pte) & PHYS_MASK) >> PAGE_SHIFT) argument
184 #define pte_page(pte) pfn_to_page(pte_pfn(pte)) argument
189 #define pte_isset(pte, val) ((u32)(val) == (val) ? pte_val(pte) & (val) \ argument
190 : !!(pte_val(pte) & (val)))
191 #define pte_isclear(pte, val) (!(pte_val(pte) & (val))) argument
193 #define pte_none(pte) (!pte_val(pte)) argument
194 #define pte_present(pte) (pte_isset((pte), L_PTE_PRESENT)) argument
195 #define pte_valid(pte) (pte_isset((pte), L_PTE_VALID)) argument
196 #define pte_accessible(mm, pte) (mm_tlb_flush_pending(mm) ? pte_present(pte) : pte_valid(pte)) argument
197 #define pte_write(pte) (pte_isclear((pte), L_PTE_RDONLY)) argument
198 #define pte_dirty(pte) (pte_isset((pte), L_PTE_DIRTY)) argument
199 #define pte_young(pte) (pte_isset((pte), L_PTE_YOUNG)) argument
200 #define pte_exec(pte) (pte_isclear((pte), L_PTE_XN)) argument
202 #define pte_valid_user(pte) \ argument
203 (pte_valid(pte) && pte_isset((pte), L_PTE_USER) && pte_young(pte))
205 static inline bool pte_access_permitted(pte_t pte, bool write) in pte_access_permitted() argument
213 return (pte_val(pte) & mask) == needed; in pte_access_permitted()
228 static inline pte_t clear_pte_bit(pte_t pte, pgprot_t prot) in clear_pte_bit() argument
230 pte_val(pte) &= ~pgprot_val(prot); in clear_pte_bit()
231 return pte; in clear_pte_bit()
234 static inline pte_t set_pte_bit(pte_t pte, pgprot_t prot) in set_pte_bit() argument
236 pte_val(pte) |= pgprot_val(prot); in set_pte_bit()
237 return pte; in set_pte_bit()
240 static inline pte_t pte_wrprotect(pte_t pte) in pte_wrprotect() argument
242 return set_pte_bit(pte, __pgprot(L_PTE_RDONLY)); in pte_wrprotect()
245 static inline pte_t pte_mkwrite(pte_t pte) in pte_mkwrite() argument
247 return clear_pte_bit(pte, __pgprot(L_PTE_RDONLY)); in pte_mkwrite()
250 static inline pte_t pte_mkclean(pte_t pte) in pte_mkclean() argument
252 return clear_pte_bit(pte, __pgprot(L_PTE_DIRTY)); in pte_mkclean()
255 static inline pte_t pte_mkdirty(pte_t pte) in pte_mkdirty() argument
257 return set_pte_bit(pte, __pgprot(L_PTE_DIRTY)); in pte_mkdirty()
260 static inline pte_t pte_mkold(pte_t pte) in pte_mkold() argument
262 return clear_pte_bit(pte, __pgprot(L_PTE_YOUNG)); in pte_mkold()
265 static inline pte_t pte_mkyoung(pte_t pte) in pte_mkyoung() argument
267 return set_pte_bit(pte, __pgprot(L_PTE_YOUNG)); in pte_mkyoung()
270 static inline pte_t pte_mkexec(pte_t pte) in pte_mkexec() argument
272 return clear_pte_bit(pte, __pgprot(L_PTE_XN)); in pte_mkexec()
275 static inline pte_t pte_mknexec(pte_t pte) in pte_mknexec() argument
277 return set_pte_bit(pte, __pgprot(L_PTE_XN)); in pte_mknexec()
280 static inline pte_t pte_modify(pte_t pte, pgprot_t newprot) in pte_modify() argument
284 pte_val(pte) = (pte_val(pte) & ~mask) | (pgprot_val(newprot) & mask); in pte_modify()
285 return pte; in pte_modify()
308 #define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) }) argument