| #ifndef __PAT_INTERNAL_H_ | 
 | #define __PAT_INTERNAL_H_ | 
 |  | 
 | extern int pat_debug_enable; | 
 |  | 
 | #define dprintk(fmt, arg...) \ | 
 | 	do { if (pat_debug_enable) printk(KERN_INFO fmt, ##arg); } while (0) | 
 |  | 
 | struct memtype { | 
 | 	u64			start; | 
 | 	u64			end; | 
 | 	u64			subtree_max_end; | 
 | 	unsigned long		type; | 
 | 	struct rb_node		rb; | 
 | }; | 
 |  | 
 | static inline char *cattr_name(unsigned long flags) | 
 | { | 
 | 	switch (flags & _PAGE_CACHE_MASK) { | 
 | 	case _PAGE_CACHE_UC:		return "uncached"; | 
 | 	case _PAGE_CACHE_UC_MINUS:	return "uncached-minus"; | 
 | 	case _PAGE_CACHE_WB:		return "write-back"; | 
 | 	case _PAGE_CACHE_WC:		return "write-combining"; | 
 | 	default:			return "broken"; | 
 | 	} | 
 | } | 
 |  | 
 | #ifdef CONFIG_X86_PAT | 
 | extern int rbt_memtype_check_insert(struct memtype *new, | 
 | 					unsigned long *new_type); | 
 | extern struct memtype *rbt_memtype_erase(u64 start, u64 end); | 
 | extern struct memtype *rbt_memtype_lookup(u64 addr); | 
 | extern int rbt_memtype_copy_nth_element(struct memtype *out, loff_t pos); | 
 | #else | 
 | static inline int rbt_memtype_check_insert(struct memtype *new, | 
 | 					unsigned long *new_type) | 
 | { return 0; } | 
 | static inline struct memtype *rbt_memtype_erase(u64 start, u64 end) | 
 | { return NULL; } | 
 | static inline struct memtype *rbt_memtype_lookup(u64 addr) | 
 | { return NULL; } | 
 | static inline int rbt_memtype_copy_nth_element(struct memtype *out, loff_t pos) | 
 | { return 0; } | 
 | #endif | 
 |  | 
 | #endif /* __PAT_INTERNAL_H_ */ |