Lines Matching refs:pte

61 #define pte_ERROR(pte)		__pte_error(__FILE__, __LINE__, pte)  argument
168 #define pte_pfn(pte) ((pte_val(pte) & PHYS_MASK) >> PAGE_SHIFT) argument
171 #define pte_page(pte) pfn_to_page(pte_pfn(pte)) argument
176 #define pte_isset(pte, val) ((u32)(val) == (val) ? pte_val(pte) & (val) \ argument
177 : !!(pte_val(pte) & (val)))
178 #define pte_isclear(pte, val) (!(pte_val(pte) & (val))) argument
180 #define pte_none(pte) (!pte_val(pte)) argument
181 #define pte_present(pte) (pte_isset((pte), L_PTE_PRESENT)) argument
182 #define pte_valid(pte) (pte_isset((pte), L_PTE_VALID)) argument
183 #define pte_accessible(mm, pte) (mm_tlb_flush_pending(mm) ? pte_present(pte) : pte_valid(pte)) argument
184 #define pte_write(pte) (pte_isclear((pte), L_PTE_RDONLY)) argument
185 #define pte_dirty(pte) (pte_isset((pte), L_PTE_DIRTY)) argument
186 #define pte_young(pte) (pte_isset((pte), L_PTE_YOUNG)) argument
187 #define pte_exec(pte) (pte_isclear((pte), L_PTE_XN)) argument
189 #define pte_valid_user(pte) \ argument
190 (pte_valid(pte) && pte_isset((pte), L_PTE_USER) && pte_young(pte))
192 static inline bool pte_access_permitted(pte_t pte, bool write) in pte_access_permitted() argument
200 return (pte_val(pte) & mask) == needed; in pte_access_permitted()
218 static inline pte_t clear_pte_bit(pte_t pte, pgprot_t prot) in clear_pte_bit() argument
220 pte_val(pte) &= ~pgprot_val(prot); in clear_pte_bit()
221 return pte; in clear_pte_bit()
224 static inline pte_t set_pte_bit(pte_t pte, pgprot_t prot) in set_pte_bit() argument
226 pte_val(pte) |= pgprot_val(prot); in set_pte_bit()
227 return pte; in set_pte_bit()
230 static inline pte_t pte_wrprotect(pte_t pte) in pte_wrprotect() argument
232 return set_pte_bit(pte, __pgprot(L_PTE_RDONLY)); in pte_wrprotect()
235 static inline pte_t pte_mkwrite_novma(pte_t pte) in pte_mkwrite_novma() argument
237 return clear_pte_bit(pte, __pgprot(L_PTE_RDONLY)); in pte_mkwrite_novma()
240 static inline pte_t pte_mkclean(pte_t pte) in pte_mkclean() argument
242 return clear_pte_bit(pte, __pgprot(L_PTE_DIRTY)); in pte_mkclean()
245 static inline pte_t pte_mkdirty(pte_t pte) in pte_mkdirty() argument
247 return set_pte_bit(pte, __pgprot(L_PTE_DIRTY)); in pte_mkdirty()
250 static inline pte_t pte_mkold(pte_t pte) in pte_mkold() argument
252 return clear_pte_bit(pte, __pgprot(L_PTE_YOUNG)); in pte_mkold()
255 static inline pte_t pte_mkyoung(pte_t pte) in pte_mkyoung() argument
257 return set_pte_bit(pte, __pgprot(L_PTE_YOUNG)); in pte_mkyoung()
260 static inline pte_t pte_mkexec(pte_t pte) in pte_mkexec() argument
262 return clear_pte_bit(pte, __pgprot(L_PTE_XN)); in pte_mkexec()
265 static inline pte_t pte_mknexec(pte_t pte) in pte_mknexec() argument
267 return set_pte_bit(pte, __pgprot(L_PTE_XN)); in pte_mknexec()
270 static inline pte_t pte_modify(pte_t pte, pgprot_t newprot) in pte_modify() argument
274 pte_val(pte) = (pte_val(pte) & ~mask) | (pgprot_val(newprot) & mask); in pte_modify()
275 return pte; in pte_modify()
303 #define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) }) argument
306 static inline int pte_swp_exclusive(pte_t pte) in pte_swp_exclusive() argument
308 return pte_isset(pte, L_PTE_SWP_EXCLUSIVE); in pte_swp_exclusive()
311 static inline pte_t pte_swp_mkexclusive(pte_t pte) in pte_swp_mkexclusive() argument
313 return set_pte_bit(pte, __pgprot(L_PTE_SWP_EXCLUSIVE)); in pte_swp_mkexclusive()
316 static inline pte_t pte_swp_clear_exclusive(pte_t pte) in pte_swp_clear_exclusive() argument
318 return clear_pte_bit(pte, __pgprot(L_PTE_SWP_EXCLUSIVE)); in pte_swp_clear_exclusive()